/*@import url("uikit-base.css");
@import url("mmenu.css");
@import url("font-awesome.min.css");
@import url("hamburgers.css");*/

/* oswald-500 - latin_latin-ext */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 500;
  src: url('../fonts/oswald-v57-latin_latin-ext-500.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
       url('../fonts/oswald-v57-latin_latin-ext-500.ttf') format('truetype'); /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
}

/* roboto-300 - latin_latin-ext */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  src: url('../fonts/roboto-v51-latin_latin-ext-300.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
       url('../fonts/roboto-v51-latin_latin-ext-300.ttf') format('truetype'); /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
}

/* roboto-500 - latin_latin-ext */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 500;
  src: url('../fonts/roboto-v51-latin_latin-ext-500.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
       url('../fonts/roboto-v51-latin_latin-ext-500.ttf') format('truetype'); /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
}

/* roboto-600 - latin_latin-ext */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 600;
  src: url('../fonts/roboto-v51-latin_latin-ext-600.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
       url('../fonts/roboto-v51-latin_latin-ext-600.ttf') format('truetype'); /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android Browser 2.2+ */
}




:root {
  --rot: #e3000b;
  --grau: #f2f5f7;
  --schwarz: #000000;
}
* {
  margin: 0;
  padding: 0;
  outline: none !important;
  /*-webkit-appearance: none;
-moz-appearance: none;*/
}
*, *:before, *:after {
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
html {
  font-size: 20px;
}
body {
  height: 100%;
  font-family: 'Roboto', Helvetica, Arial, SansSerif, "sans-serif";
  font-weight: 300;
  letter-spacing: 0.02em;

  
}
::-moz-selection {
  background: var(--rot);
  color: #fff;
}
::selection {
  background: var(--rot);
  color: #fff;
}
a {
  text-decoration: none;
  color: inherit;
    -webkit-transition: all 0.5s;
transition: all 0.5s;
}
a img {
  border: none;
}
img {
  max-width: 100%;
  height: auto;
}
table {
  /*width: 100%;
table-layout:fixed;*/
}
figure.image {
  display: inline-block;
  border: 1px solid gray;
  margin: 0 2px 0 1px;
  background: #f5f2f0;
}
figure.align-left {
  float: left;
}
figure.align-right {
  float: right;
}
figure.image img {
  margin: 8px 8px 0 8px;
}
figure.image figcaption {
  margin: 6px 8px 6px 8px;
  text-align: center;
}
.noIcon span.uk-icon {
  display: none;
}

/*============================================
           Header
============================================*/

#header {
  border-bottom: 1px solid var(--grau);
  background-color: #fff;
}

/*=================================
            Navigation
=================================*/

#navi {
	
}

#navi ul {
	
}

#navi ul li {
	list-style: none;
}

#navi ul li {
	font-size: 0.9rem;
  font-weight: 500;
}

#navi ul li a {
	font-size: 0.9rem;
  font-weight: 500;
  margin-right: 2rem;
    position: relative;
    display: block;
}

#navi ul li.active > a {
    color: var(--rot);
}

#navi ul > li:has(div):hover > a:after {
    content: '';
    position: absolute;
    bottom: -47px;
    left: 50%;
    transform: translateX(-50%);
    clip-path: polygon(50% 100%, 0 0, 100% 0);
    width: 23px;
    height: 10px;
    background-color: #ffffff;
    z-index: 1030;
}
#navi ul > li:has(div):hover > a::before {
	content: '';
	position: absolute;
	bottom: -48px;
	left: 50%;
	transform: translateX(-50%);
	clip-path: polygon(50% 100%, 0 0, 100% 0);
	width: 25px;
	height: 11px;
	background-color: var(--rot);
	z-index: 1029;
}

#navi ul li a:hover {
	color: var(--rot);
}

#navi .unavColumn {
	float: left;
	margin-right: 35px;
}

#navi .uNavi {
    padding: 35px 0;
}
.subNavTitle {
	font-size: 1.1rem;
	font-weight: 500;
    /*padding-bottom: 10px;*/
    display: block;
}

.uNavi {
    /*position: relative;*/
}

.uNavi a {
    font-weight: 300 !important;
    font-size: 0.9rem !important;
    padding: 10px 0 !important;
    display: block;
}

.active-dropbar {
    border-top: 1px solid var(--rot);
    border-bottom: 1px solid var(--rot);
    box-shadow: none;
}

.uk-dropdown {
	color: var(--schwarz);
}

/*---------- Navi Mobil ------------*/

.naviMob ul li {
    list-style: none;
}

.naviMob ul li a {
	font-size: 0.9rem;
  font-weight: 500;
  margin-right: 2rem;
    position: relative;
    display: block;
    margin-bottom: 10px;
}

.naviMob ul li ul li a {
    font-weight: 300;
    padding-left: 25px;
}

.naviMobSub li a {
    font-weight: 300 !important;
}

/*=================================
            Formatierung
=================================*/

h1, h2, h3, h4 {
	font-family: Oswald, Arial, Helvetica, sans-serif;
  font-weight: 500;
  line-height: 1.14;
}

h1, h2 {
	font-size: 2.4rem;
  
}

h2 {
	
}

h3 {
	font-size: 1.35rem;
}

h4 {
	
}

h5 {
	
}

p, section li {
	line-height: 1.35;
}

* + p, * + h1, * + h2, * + h3 {
  margin-top: 1rem;
}

section a:hover, footer a:hover {
    color: var(--rot);
}

section li {
	margin-left: 27px;
	padding-left: 7px;
}

section * + ul {
    margin-top: 1rem;
}

button {
	border: none;
	font-family: inherit;
    cursor: pointer;
}

/*============================================
           Footer
============================================*/
#footer {
  font-weight: 500;
  font-size: 1.1rem;
}

/*=================================
            formular
=================================*/

::placeholder { /* Chrome, Firefox, Opera, Safari 10.1+ */

    color: #959595;
	font-weight: 300;
    opacity: 1; /* Firefox */
}

:-ms-input-placeholder { /* Internet Explorer 10-11 */
    color: #959595;
	font-weight: 300;
}

::-ms-input-placeholder { /* Microsoft Edge */
    color: #959595;
	font-weight: 300;
}

.error {
	color: var(--rot);
	display: block;
	font-weight: 300;
font-size: 0.8rem;
}

.success {
	background: var(--grau);
    color: var(--schwarz);
	text-align: center;
	padding: 20px 0;
	margin-bottom: 25px;
}

.fiSpecial {
	display: none;
	}

.uk-radio:checked, .uk-checkbox:checked, .uk-checkbox:indeterminate {
	background-color: var(--rot);
	border-color: transparent;
}

.uk-radio:focus, .uk-checkbox:focus {
	background-color: #ffffff;
	outline: none;
	border-color: var(--rot);
}

/* Focus */
.uk-input:focus, .uk-select:focus, .uk-textarea:focus {
  outline: none;
  background-color: #fff;
  color: #666;
  border-color: var(--rot);
}

.uk-radio:checked, .uk-checkbox:checked, .uk-checkbox:indeterminate {
  background-color: var(--rot);
  border-color: transparent;
}

.uk-search-default .uk-search-input:focus {
  background-color: rgba(0, 0, 0, 0);
  border-color: var(--rot);
}

.uk-radio:checked:focus, .uk-checkbox:checked:focus, .uk-checkbox:indeterminate:focus {
	background-color: var(--rot);
}

.uk-radio, .uk-checkbox {
	background-color: #fff;
    margin-right: 5px;
}
/*=================================
            KLASSEN
=================================*/

.mid {
	width: 92%;
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
}

.midBreit {
	width: 92%;
	max-width: 1800px;
	margin-left: auto;
	margin-right: auto;
}

.buttonGross {
  width: 150px;
  /* background-color: var(--rot); */
  color: #fff;
  font-weight: 500;
  padding: 15px;
  text-align: center;
  overflow: hidden;
z-index: 1000;
    position: relative;
}

.buttonGross:after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  background-color: var(--rot);
  border-radius: 150px;
  z-index: -2;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}
.buttonGross::before {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: 100%;
  left: -100%;
  opacity: 1;
  background-color: var(--schwarz);
  border-radius: 150px;
  z-index: -1;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}


.buttonGross:hover:before {
  right: 0;
  left: 0;
  opacity: 1;
}




.button {
  font-size: 0.9rem;
  display: inline-block;
  color: #fff;
  font-weight: 500;
  /* background-color: var(--rot); */
  padding: 10px 25px;
  border-radius: 50px;
  position: relative;
  overflow: hidden;
z-index: 10;
}
.button:after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  background-color: var(--rot);
  border-radius: 50px;
  z-index: -2;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}
.button::before {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: 100%;
  left: -100%;
  opacity: 1;
  background-color: var(--schwarz);
  border-radius: 50px;
  z-index: -1;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}


.button:hover:before {
  right: 0;
  left: 0;
  opacity: 1;
}

.buttonGross:hover, .button:hover {
    color: #ffffff;
}

.bgSchwarz {
  background-color: var(--schwarz);
  color: #fff;
}

.bgGrau {
  background-color: var(--grau);
   /* position: relative;
  z-index: -5;*/
}

.imgGal {
	color: #fff !important;
}

.listSm ul, .listSm > li {
	margin-top: 0;
	margin-bottom: 20px;
}

/*=================================
            UiKit
=================================*/

.uk-overlay-primary {
	--uk-inverse: light;
	background: rgba(34, 34, 34, 0.5);
}


/*=================================
            Mobile Navigation
=================================*/

.hamburger {
  padding: 0;
  display: inline-block;
  cursor: pointer;
  transition-property: opacity, filter;
  transition-duration: 0.15s;
  transition-timing-function: linear;
  font: inherit;
  color: inherit;
  text-transform: none;
  background-color: transparent;
  border: 0;
  margin: 0;
  overflow: visible; }
  .hamburger:hover {
    opacity: 0.7; }
  .hamburger.is-active:hover {
    opacity: 0.7; }
  .hamburger.is-active .hamburger-inner,
  .hamburger.is-active .hamburger-inner::before,
  .hamburger.is-active .hamburger-inner::after {
    background-color: #000; }

.hamburger-box {
  width: 40px;
  height: 24px;
  display: inline-block;
  position: relative; }

.hamburger-inner {
  display: block;
  top: 50%;
  margin-top: -2px; }
  .hamburger-inner, .hamburger-inner::before, .hamburger-inner::after {
    width: 40px;
    height: 4px;
    background-color: #000;
    border-radius: 4px;
    position: absolute;
    transition-property: transform;
    transition-duration: 0.15s;
    transition-timing-function: ease; }
  .hamburger-inner::before, .hamburger-inner::after {
    content: "";
    display: block; }
  .hamburger-inner::before {
    top: -10px; }
  .hamburger-inner::after {
    bottom: -10px; }


/*
   * Slider Reverse
   */
.hamburger--slider-r .hamburger-inner {
  top: 2px; }
  .hamburger--slider-r .hamburger-inner::before {
    top: 10px;
    transition-property: transform, opacity;
    transition-timing-function: ease;
    transition-duration: 0.15s; }
  .hamburger--slider-r .hamburger-inner::after {
    top: 20px; }

.hamburger--slider-r.is-active .hamburger-inner {
  transform: translate3d(0, 10px, 0) rotate(-45deg); }
  .hamburger--slider-r.is-active .hamburger-inner::before {
    transform: rotate(45deg) translate3d(5.71429px, -6px, 0);
    opacity: 0; }
  .hamburger--slider-r.is-active .hamburger-inner::after {
    transform: translate3d(0, -20px, 0) rotate(90deg); }

/*=================================
            Responsive
=================================*/

@media (max-width: 960px) {
.buttonKopf {
	margin: 25px;
}
    
    .buttonGross {
	width: 110px;
	font-size: 0.9rem;
}
    
    #header {
	z-index: 1000;
}
    
    /*.startIcons > div:nth-child(1) {
	order: 1;
}
    
      .startIcons > div:nth-child(2) {
	order: 3;
}
    
          .startIcons > div:nth-child(3) {
	order: 2;
}
    
          .startIcons > div:nth-child(4) {
	order: 4;
}*/
}