/*Haupt CSS Datei*/

/**********
*Variablen*
***********/
/*CSS Variablen - https://www.w3schools.com/css/css3_variables.asp*/



:root {
/*CI-Farben*/    
--MWgelb: #E5E03E;
--MWweiss: #ffffff;
--MWgrau: #212424;

/*Headder Höhe*/
--header-height: 100px;

/*Scrollverhalten*/
scroll-behavior: smooth;
overflow-x: hidden;
}

/*Header Höhe in Abhängigkeit des Ausgabebildschirms*/
@media (min-width: 600px) {
    :root {
      --header-height: 120px;
    }
  }
  
  @media (min-width: 900px) {
    :root {
      --header-height: 100px;
    }
  }
  
  @media (min-width: 1200px) {
    :root {
      --header-height: 130px;
    }
  }

/********
*Schrift*
*********/

/* montserrat-300 - latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 300;
  src: url('../../fonts/montserrat-v25-latin-300.eot'); /* IE9 Compat Modes */
  src: local(''),
       url('../../fonts/montserrat-v25-latin-300.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../../fonts/montserrat-v25-latin-300.woff2') format('woff2'), /* Super Modern Browsers */
       url('../../fonts/montserrat-v25-latin-300.woff') format('woff'), /* Modern Browsers */
       url('../../fonts/montserrat-v25-latin-300.ttf') format('truetype'), /* Safari, Android, iOS */
       url('../../fonts/montserrat-v25-latin-300.svg#Montserrat') format('svg'); /* Legacy iOS */
}

/* montserrat-800 - latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 800;
  src: url('../../fonts/montserrat-v25-latin-800.eot'); /* IE9 Compat Modes */
  src: local(''),
       url('../../fonts/montserrat-v25-latin-800.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../../fonts/montserrat-v25-latin-800.woff2') format('woff2'), /* Super Modern Browsers */
       url('../../fonts/montserrat-v25-latin-800.woff') format('woff'), /* Modern Browsers */
       url('../../fonts/montserrat-v25-latin-800.ttf') format('truetype'), /* Safari, Android, iOS */
       url('../../fonts/montserrat-v25-latin-800.svg#Montserrat') format('svg'); /* Legacy iOS */
}

/* montserrat-900 - latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 900;
  src: url('../../fonts/montserrat-v25-latin-900.eot'); /* IE9 Compat Modes */
  src: local(''),
       url('../../fonts/montserrat-v25-latin-900.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../../fonts/montserrat-v25-latin-900.woff2') format('woff2'), /* Super Modern Browsers */
       url('../../fonts/montserrat-v25-latin-900.woff') format('woff'), /* Modern Browsers */
       url('../../fonts/montserrat-v25-latin-900.ttf') format('truetype'), /* Safari, Android, iOS */
       url('../../fonts/montserrat-v25-latin-900.svg#Montserrat') format('svg'); /* Legacy iOS */
}

/* montserrat-300italic - latin */
@font-face {
  font-family: 'Montserrat';
  font-style: italic;
  font-weight: 300;
  src: url('../../fonts/montserrat-v25-latin-300italic.eot'); /* IE9 Compat Modes */
  src: local(''),
       url('../../fonts/montserrat-v25-latin-300italic.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../../fonts/montserrat-v25-latin-300italic.woff2') format('woff2'), /* Super Modern Browsers */
       url('../../fonts/montserrat-v25-latin-300italic.woff') format('woff'), /* Modern Browsers */
       url('../../fonts/montserrat-v25-latin-300italic.ttf') format('truetype'), /* Safari, Android, iOS */
       url('../../fonts/montserrat-v25-latin-300italic.svg#Montserrat') format('svg'); /* Legacy iOS */
}





/*********************
*Globale Definitionen*
**********************/
body {
    font-size: 1.2rem;
    line-height: 1.3;
    margin-bottom: 0em;
    color: var(--MWgrau);
    font-family: 'Montserrat', sans-serif;
  }

  body {
    min-height: 100vh;
    min-height: var(--min-browser-height);
    display: flex;
    flex-flow: column;
    font-size: 1rem;
    line-height: 1.2;
    font-weight: 400;
    color: var(--MWgrau);
    --side-width: calc((100% - 78rem) / 2);
    --big-width: calc(var(--side-width) + (78rem / 3) * 2);
    --small-width: calc(var(--side-width) + (78rem / 3));
  }

  .visualy-hidden {
    display: block;
    position: absolute;
    height: 1px;
    width: 1px;
    opacity: 0;
    margin: 0;
    padding: 0;
    line-height: 0;
  }

*,
*::after,
*::before {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
/******************
*Text Definitionen*
*******************/

.headline {
    text-transform: uppercase;
    font-weight: 900;
    font-size: 3rem;
    line-height: 0.91;
    margin-bottom: 0.455em;
    line-height: 0.97;
}

.text {
    font-weight: 300;
    font-size: 1.2rem;
    line-height: 1.3;
    margin-bottom: 0.65em;
  }

/************
*Layout-Grid*
*************/


/*Center nav - kommt im header vor*/
.center-nav {
    display: flex;
    max-width: 78rem;
    min-height: 120px;
    min-height: var(--header-height, 120px);
    margin: auto;
    padding: 1rem 0;
  }
  
  .center-nav__list {
    display: flex;
    margin: auto;
    justify-content: space-around;
    list-style: none;
  }
  
  @media (max-width: 599px) {
    .center-nav__list {
      flex-flow: column;
      text-align: center;
    }
  }
  
  .center-nav__item {
    margin: 0.5rem 1rem;
    align-self: center;
  }
  
  @media (min-width: 600px) {
    .center-nav__item:first-of-type {
      margin-left: 0;
    }
    .center-nav__item:last-of-type {
      margin-right: 0;
    }
  }
  
  .center-nav__link {
    margin: 0;
    text-transform: uppercase;
    background: none;
  }

/********************
*Header-Formatierung*
*********************/
.main-header {
    padding: 0 1rem;
    color: #212424;
    font-weight: 700;
    position: fixed;
    top: 0;
    z-index: 10;
    background-color: #ffffff;
    left: 0;
    right: 0;
    width: 100%;
    transition: transform 250ms ease-in-out;
    transform: none;
    height: 120px;
    height: var(--header-height, 120px);
    -ms-grid-column-span: 5;
    -ms-grid-column: 1;
    display: block;
  }
  
  @supports (grid-column: 1) {
    .main-header {
      grid-column: 1/6;
    }
  }
  
  .main-header .center-nav__list {
    margin-right: 0;
    display: none;
  }
  
  @media (min-width: 900px) {
    .main-header .center-nav__list {
      display: flex;
    }
  }
  
  .main-header .center-nav__link {
    position: relative;
    background: none;
    font-size: 1.68rem;
    line-height: 1.161;
    margin-bottom: 0.58em;
  }
  
  .main-header .center-nav__link::after {
    content: '';
    display: block;
    position: absolute;
    z-index: -1;
    top: -0.66em;
    left: 33.33%;
    width: 1em;
    height: 1em;
    transform: translateX(-50%) rotate(-45deg);
    background-image: linear-gradient(45deg, #E5E03E, #E5E03E 49%, transparent 49.05%);
    background-size: 0 0;
    background-position: center;
    background-repeat: no-repeat;
    transition: 100ms ease-in-out;
    transition-property: background-size, transform;
  }
  
  .main-header .center-nav__link:focus, .main-header .center-nav__link:hover {
    background: none;
  }
  
  .main-header .center-nav__link:focus::after, .main-header .center-nav__link:hover::after {
    background-size: 100% 100%;
    animation: point-down 3s infinite ease-in-out;
  }
  
  .main-header .center-nav__link:active {
    background: none;
  }
  
  .main-header .center-nav__link:active::after {
    background-image: linear-gradient(45deg, #E5E03E, #E5E03E 49%, transparent 49.05%);
    background-size: 100% 100%;
    transform: translateX(-50%) rotate(-45deg) scale(3.5);
  }
  
  .main-header .header-icon {
    padding: 0;
    margin: 0;
    line-height: 0;
    display: inline-block;
    margin-left: 1rem;
  }
  
  @media (min-width: 600px) {
    .main-header .header-icon {
      margin-left: 0.5rem;
    }
  }
  
  @media (min-width: 1200px) {
    .main-header .header-icon {
      margin-left: 0;
    }
  }
  
  .main-header .header-icon svg {
    width: 240px;
    height: 120px;
    width: calc(var(--header-height, 120px) * 2);
    height: calc(var(--header-height, 120px));
    padding: 0;
    margin: -1rem 0 -30px -1rem;
    margin: -1rem 0 calc(var(--header-height, 120px) * -0.25) -1rem;
  }

  .scrolling-down.page-has-scrolled .main-header {
    transform: translateY(120px * -1);
    transform: translateY(calc(var(--header-height, 120px) * -1));
  }
  
  .scrolling-up .main-header {
    transform: none;
  }

/*************
*Main Content*
**************/

.main-content {
    margin-top: 120px;
    margin-top: var(--header-height, 120px);
    width: 100%;

  }

/*Linkformatierung*/
a,
button {
  font-family: inherit;
  font-size: inherit;
  font-weight: 700;
  line-height: inherit;
  color: inherit;
  text-decoration: none;
}

/*Link Animation*/

.figure {
    position: relative;
  }

.main-content .button,
.main-content .link,
.main-content .text a,
.main-content .text button {
  background-color: transparent;
  background-image: linear-gradient(45deg, #E5E03E, #E5E03E 49%, transparent 49.1%);
  background-size: 1.25em 1.25em;
  background-position: 0 100%;
  background-repeat: no-repeat;
  border: none;
  transition: all 250ms ease-in-out;
  padding: 0 0.25em;
}  

.main-content .button:focus, .main-content .button:hover,
.main-content .link:focus,
.main-content .link:hover,
.main-content .text a:focus,
.main-content .text a:hover,
.main-content .text button:focus,
.main-content .text button:hover {
  cursor: pointer;
  background-size: 250% 250%;
}

.main-content .button:active,
.main-content .link:active,
.main-content .text a:active,
.main-content .text button:active {
  background-size: 250% 250%;
}

.main-content .button {
  font-weight: 700;
  text-transform: uppercase;
  padding: 0.05em 0.5em 0;
  max-height: 1.5em;
}

.main-content .button--icon {
  max-height: none;
  background-size: 100% 100%;
}

.main-content .text--alt a:hover, .main-content .text--alt a:focus,
.main-content .text--alt button:hover,
.main-content .text--alt button:focus {
  color: #2B2E2F;
}

.main-content .button--alt:hover, .main-content .button--alt:focus,
.main-content .link--alt:hover,
.main-content .link--alt:focus {
  color: #2B2E2F;
}

.main-content .button,
.main-content .link {
  font-weight: 400;
  font-size: 1.68rem;
  line-height: 1.161;
  margin-bottom: 0.58em;
}
/*******************
*Hauptteil Temporär*
********************/

/*Side By Side - Template*/
.sidebyside {
    display: flex;
    flex-flow: column;
    

  }
  
  @media (min-width: 900px) {
    .sidebyside {
      flex-flow: row;
    }
  }
  
  @media (min-width: 1200px) {
    .sidebyside {
      min-height: 100vh;
      min-height: var(--min-browser-height);
    }
  }
  
  .sidebyside__article {
    display: flex;
    flex-flow: column;
    overflow-x: hidden;
    position: relative;
    z-index: 1;
    padding: 2rem 2rem 4rem;
  }
  
  @media (max-width: 360px) {
    .sidebyside__article {
      flex: 1 100%;
    }
  }
  
  @media (min-width: 600px) {
    .sidebyside__article {
      flex: 0 50%;
      padding: 2rem;
    }
  }
  
  @media (min-width: 900px) {
    .sidebyside__article {
      flex: 0 40%;
      padding: 2rem 4rem 4rem 2rem;
    }
  }
  
  @media (min-width: 1200px) {
    .sidebyside__article {
      flex: 0 var(--small-width);
      padding: 2rem var(--side-width) 8rem 2rem;
    }
  }
  
  @media (min-width: 600px) {
    .sidebyside__article {
      overflow-x: visible;
    }
  }
  
  .sidebyside__figure {
    position: relative;
    z-index: 0;
  }
  
  @media (min-width: 600px) {
    .sidebyside__figure {
      flex: 0 50%;
    }
  }
  
  @media (min-width: 900px) {
    .sidebyside__figure {
      flex: 0 66.66%;
    }
  }
  
  @media (min-width: 1200px) {
    .sidebyside__figure {
      flex: 0 var(--big-width);
    }
  }
  
  .sidebyside__image {
    display: block;
    width: 100%;
    height: auto;
    min-height: 100vh;
    min-height: var(--min-browser-height);
  }
  
  @supports (object-fit: cover) {
    .sidebyside__image {
      height: 100%;
      object-fit: cover;
      object-position: 50% 33%;
    }
  }
  
  .sidebyside__logo {
    margin-bottom: 2rem;
    transform: translateX(-11%);
    width: calc(100vw * 0.072 - -104.989px);
    height: auto;
  }
  
  .sidebyside__headline {
    margin-top: auto;
    position: relative;
  }
  
  .sidebyside__headline::before {
    content: '';
    display: block;
    position: absolute;
    width: 8em;
    padding-top: 8em;
    background-image: linear-gradient(45deg, #E5E03E, #E5E03E 49%, transparent 49.05%);
    overflow: visible;
    top: 0;
    right: auto;
    bottom: auto;
    left: 0;
    transform: rotate(90deg);
    z-index: -1;
    top: -1em;
    left: -1.25em;
  }
  
  @media (min-width: 1200px) {
    .sidebyside__headline::before {
      left: -2.25em;
    }
  }


/********************
*Footer Formatierung*
*********************/

  .main-footer {
    padding: 0 2rem;
    background: var(--MWgrau);
    margin-top: auto;
    color: var(--MWweiss);
    overflow: hidden;
    -ms-grid-column-span: 5;
    -ms-grid-column: 1;
    
  }

  /* Adressdaten: Telefonnummer und E-mail-Adresse Linkformatierung und Hover-Over-effekt*/

  .contact-info {
    z-index: 1;
    position: relative;
    padding: 4rem 0 0;
    text-align: center;
  }

  .contact-info a {
    padding: 0 0.25ch;
    background-image: linear-gradient(45deg, #949a9d, #949a9d 80%, transparent 80%);
    background-size: 0 100%;
    background-position: 0 100%;
    background-repeat: no-repeat;
    transition: all 250ms ease-in-out;
    text-decoration: none;
    color: var(--MWweiss);
  }

  .contact-info a {
    font-weight: 400;
    font-size: 1.2rem;
    line-height: 1.3;
    margin-bottom: 0.65em;
  }

  .contact-info a:hover {
    background-size: 140% 100%;
  }
  

  .contact-info__adress p {
    word-break: keep-all;
    white-space: nowrap;
    display: inline;
  }

  /*Gelbe Dreiecke im Footer*/
  .contact-info span {
    color: transparent;
    position: relative;
  }
  
  .contact-info span::after {
    content: '';
    display: block;
    position: absolute;
    width: 0.5em;
    padding-top: 0.5em;
    background-image: linear-gradient(45deg, var(--MWgelb), var(--MWgelb) 49%, transparent 49.05%);
    overflow: visible;
    top: 0;
    right: auto;
    bottom: auto;
    left: 0;
    transform: rotate(90deg);
    transform: translate(-80%, -50%) rotate(-135deg);
    top: 50%;
    left: 50%;
  }

  
  /*Hoverover Dreieck Impressum & Datenschutz*/

  .main-footer .center-nav a {
    font-weight: 400;
    font-size: 1.68rem;
    line-height: 1.161;
    margin-bottom: 0.58em;
    position: relative;
    z-index: 1;
    background: none;
  }
  
  .main-footer .center-nav a::after {
    content: '';
    display: block;
    position: absolute;
    z-index: -1;
    top: -1.125rem;
    left: 33%;
    width: 1rem;
    height: 1rem;
    transform: translateX(-50%) rotate(-45deg);
    background-image: linear-gradient(45deg, var(--MWweiss), var(--MWweiss) 49%, transparent 49.05%);
    background-size: 0 0;
    background-position: center;
    background-repeat: no-repeat;
    transition: 100ms ease-in-out;
    transition-property: background-size, transform;
  }

  .main-footer .center-nav a:focus, .main-footer .center-nav a:hover {
    background: none;
  }
  
  .main-footer .center-nav a:focus::after, .main-footer .center-nav a:hover::after {
    background-size: 100% 100%;
  }
  
  .main-footer .center-nav a:active {
    background: none;
  }
  
  .main-footer .center-nav a:active::after {
    background-image: linear-gradient(45deg, #949a9d, #949a9d 49%, transparent 49.05%);
    background-size: 100% 100%;
    transform: translateX(-50%) rotate(-45deg) scale(3.5);
  }

  .footer-link {
    color: var(--MWweiss);
    text-decoration:none;
  }