p a {
  color:#000
}

h2 + p, p + p {
  margin-top:20px
}

@media screen and (min-width: 48em) {
  h2 + p, p + p {
      margin-top:24px
  }
}

*, ::before, ::after {
  -webkit-box-sizing: border-box;
  box-sizing:border-box
}

body {
  margin: 0;
  min-height:100vh
}

.wrapper {
  max-width: 100%; /* 90rem --> Kontainer anpassen! */
  width: 93%;
  margin: 0 auto;
  padding:0 20px
}

@media screen and (min-width: 48em) { 
  .wrapper {
    max-width: 100%; /* 90rem --> Kontainer anpassen! */
    width: 82%;
    margin: 0 auto;
    padding:0 20px
  }
}

input[type=checkbox] {
  display:none
}

img {
  max-width: 100%;
  height:auto
}

main {
  padding-top: 64px;
  display:block
}

@media screen and (min-width: 48em) {
  main {
      padding-top: 129px
  }
}

header {
  position: fixed;
  width: 100%;
  z-index: 1;
  background-color: #fff;
  will-change: transform;
  -webkit-transition: opacity 300ms ease-in-out, -webkit-transform 200ms linear;
  transition: opacity 300ms ease-in-out, -webkit-transform 200ms linear;
  transition: transform 200ms linear, opacity 300ms ease-in-out;
  transition: transform 200ms linear, opacity 300ms ease-in-out, -webkit-transform 200ms linear;
  opacity:1
}

header.headroom--pinned {
  -webkit-transform: translateY(0%);
  transform:translateY(0%)
}

header.headroom--unpinned {
  -webkit-transform: translateY(-100%);
  transform: translateY(-100%);
  opacity: 0;
  -webkit-transition: opacity 300ms ease-in-out, -webkit-transform 500ms linear;
  transition: opacity 300ms ease-in-out, -webkit-transform 500ms linear;
  transition: transform 500ms linear, opacity 300ms ease-in-out;
  transition:transform 500ms linear, opacity 300ms ease-in-out, -webkit-transform 500ms linear
}

header .wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position:relative
}

header .wrapper .logo {
  margin: 30px 0;
  max-width:95px
}

@media screen and (min-width: 48em) {
  header .wrapper .logo {
      margin: 50px 0;
      max-width:115px
  }
}

header .wrapper .logo img {
  display:block
}

header nav {
  visibility: hidden;
  background-color: #fff;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 10;
  overflow: hidden;
  opacity: 0;
  -webkit-transition: all 0.25s ease;
  transition:all 0.25s ease
}

header nav ul {
  margin: 0;
  padding: 11px 0 0 0;
  list-style-type:none
}

@media screen and (min-width: 48em) {
  header nav ul {
      padding:21px 0 0 0
  }
}

label[for=menu-switch] {
  display: block;
  height: 32px;
  width: 32px;
  position: relative;
  text-indent: 100%;
  overflow: hidden;
  cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Ccircle cx='12' cy='12' r='10.5' stroke='black' stroke-width='1.5' fill='transparent' vector-effect='non-scaling-stroke' shape-rendering='geometricPrecision'/%3E%3Ccircle cx='12' cy='12' r='9.5' stroke='white' stroke-width='1.5' fill='transparent' vector-effect='non-scaling-stroke' shape-rendering='geometricPrecision'/%3E%3C/svg%3E") 12 12, auto !important;
}

label[for=menu-switch] span {
  display: block;
  width: 4px;
  height: 4px;
  border-radius: 100%;
  background-color: #000;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  -webkit-transition: all 0.25s ease;
  transition:all 0.25s ease
}

label[for=menu-switch] span::before, label[for=menu-switch] span::after {
  content: '';
  display: block;
  width: 4px;
  height: 4px;
  border-radius: 100%;
  background-color: #000;
  opacity: 1;
  -webkit-transition: all 0.01s ease;
  transition: all 0.01s ease;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  -webkit-transition: opacity 0.1s ease, -webkit-transform 0.25s ease;
  transition: opacity 0.1s ease, -webkit-transform 0.25s ease;
  transition: transform 0.25s ease, opacity 0.1s ease;
  transition:transform 0.25s ease, opacity 0.1s ease, -webkit-transform 0.25s ease
}

label[for=menu-switch] span::before {
  -webkit-transform: translate(-8px, -50%);
  transform:translate(-8px, -50%)
}

label[for=menu-switch] span::after {
  -webkit-transform: translate(8px, -50%);
  transform:translate(8px, -50%)
}

#menu-switch:checked + header .wrapper label {
  z-index: 11;
  position: absolute;
  right:20px
}

#menu-switch:checked + header .wrapper label span {
  width: 16px;
  height: 16px;
  border-radius: 100%;
  -webkit-transition: all 0.35s ease;
  transition:all 0.35s ease
}

#menu-switch:checked + header .wrapper label span::before {
  opacity: 0;
  -webkit-transform: translate(-20px, -50%);
  transform: translate(-20px, -50%);
  -webkit-transition: opacity 0.1s ease, -webkit-transform 0.25s ease;
  transition: opacity 0.1s ease, -webkit-transform 0.25s ease;
  transition: transform 0.25s ease, opacity 0.1s ease;
  transition:transform 0.25s ease, opacity 0.1s ease, -webkit-transform 0.25s ease
}

#menu-switch:checked + header .wrapper label span::after {
  opacity: 0;
  -webkit-transform: translate(28px, -50%);
  transform: translate(28px, -50%);
  -webkit-transition: opacity 0.1s ease, -webkit-transform 0.25s ease;
  transition: opacity 0.1s ease, -webkit-transform 0.25s ease;
  transition: transform 0.25s ease, opacity 0.1s ease;
  transition:transform 0.25s ease, opacity 0.1s ease, -webkit-transform 0.25s ease
}

#menu-switch:checked + header nav {
  height: 100vh;
  visibility: visible;
  opacity: 1;
  -webkit-transition: opacity 0.5s ease;
  transition:opacity 0.5s ease
}
