@font-face {
  font-family: "Merlo";
  src: url("../fonts/merlo/merlo-medium/webfonts/merlo-medium.eot");
  src: url("../fonts/merlo/merlo-medium/webfonts/merlo-medium.eot?#iefix") format("embedded-opentype"), url("../fonts/merlo/merlo-medium/webfonts/merlo-medium.woff2") format("woff2"), url("../fonts/merlo/merlo-medium/webfonts/merlo-medium.woff") format("woff"), url("../fonts/merlo/merlo-medium/webfonts/merlo-medium.ttf") format("truetype"), url("../fonts/merlo/merlo-medium/webfonts/merlo-medium.svg#youworkforthem") format("svg");
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: "Merlo";
  src: url("../fonts/merlo/merlo-bold/webfonts/merlo-bold.eot");
  src: url("../fonts/merlo/merlo-bold/webfonts/merlo-bold.eot?#iefix") format("embedded-opentype"), url("../fonts/merlo/merlo-bold/webfonts/merlo-bold.woff2") format("woff2"), url("../fonts/merlo/merlo-bold/webfonts/merlo-bold.woff") format("woff"), url("../fonts/merlo/merlo-bold/webfonts/merlo-bold.ttf") format("truetype"), url("../fonts/merlo/merlo-bold/webfonts/merlo-bold.svg#youworkforthem") format("svg");
  font-weight: 700;
  font-style: normal;
}
h1, h2, h3, h4, h5, h6 {
  font-weight: 500;
  margin: 0 0 0.5em;
  line-height: 1.15;
}

.semibold, .bold {
  font-weight: 700;
}

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

h3, h4 {
  font-size: 1.3333rem;
}

h5, h6 {
  font-size: 1rem;
  font-weight: bold;
}

@media (min-width: 600px) {
  h1, h2 {
    font-size: 2.5rem;
  }

  h3 {
    font-size: 1.5rem;
  }

  h4 {
    font-size: 1.25rem;
  }

  h5, h6 {
    font-size: 1.125rem;
  }
}
ul {
  margin: 0;
}

p, main ul {
  margin: 0 0 1.25rem;
}

a {
  color: #006666;
  text-decoration: none;
}
a:hover, a:focus {
  color: #66b7a0;
}
main a {
  font-weight: 700;
}

article .appointment-link a {
  font-weight: 1200;
}

ul {
  list-style: none;
  padding: 0;
}

article ul li:not(:last-child), .dotted-bottom {
  margin-bottom: 0.5em;
  padding-bottom: 0.5em;
  position: relative;
}
article ul li:not(:last-child)::after, .dotted-bottom::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 1px;
  background: transparent url("../images/icons/dot-padded.svg") repeat-x left top/contain;
}

.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute !important;
  width: 1px;
  word-wrap: normal !important;
}

figure {
  margin: 0;
}
figure img {
  width: 100%;
}

button.btn {
  border: none;
  background: transparent;
  cursor: pointer;
}

.scrolldown {
  width: 3rem;
}

.mb-0 {
  margin-bottom: 0;
}

:root {
  box-sizing: border-box;
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  font-size: 21px;
  line-height: 1.25;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  --vh: 1vh;
  --header-height: 3rem;
}
@media (max-width: 599.8px) {
  :root {
    font-size: 18px;
  }
}
@media (min-width: 1500px) {
  :root {
    font-size: 24px;
  }
}

/**
 * * Disable smooth scrolling when users have prefers-reduced-motion enabled
 * */
@media screen and (prefers-reduced-motion: reduce) {
  :root {
    scroll-behavior: auto;
  }
}
*, *::before, *::after {
  box-sizing: inherit;
}

body {
  min-height: 100vh;
  margin: 0;
  padding: 3rem 0 0;
  font-family: "Merlo", "Helvetica Neue", sans-serif;
  background-color: #e1f5ef;
  font-weight: 500;
  color: #006666;
}

main {
  overflow: hidden;
}

article:not(.home-article):not(:first-of-type) {
  margin: 2rem auto;
}
article:not(.home-article):not(:first-of-type) article {
  margin: 2rem 0;
}
@media (min-width: 600px) {
  article:not(.home-article):not(:first-of-type) {
    margin: 4rem auto;
  }
}
@media (min-width: 900px) {
  article:not(.home-article):not(:first-of-type) {
    margin: 8rem auto;
  }
}
article.flex {
  justify-content: space-between;
  flex-flow: column nowrap;
}
@media (min-width: 900px) {
  article.flex {
    flex-flow: row nowrap;
  }
}

main > article:not(.home-article) {
  max-width: calc(1200px + 5rem);
  margin: 8rem auto;
  padding: 0 5vw;
}
@media (min-width: 600px) {
  main > article:not(.home-article) {
    padding: 0 5rem;
  }
}
main > article:not(.home-article):first-of-type {
  margin-top: 2rem;
}

.article-images {
  order: -1;
  margin: 2rem 0;
}

@media (min-width: 900px) {
  .article-item {
    width: calc(50% - 2rem);
  }

  .article-images {
    margin: 0;
  }

  .images-right .article-images {
    order: 1;
  }
}
.desk {
  display: none;
}
@media (min-width: 900px) {
  .desk {
    display: block;
  }
}

@media (min-width: 900px) {
  .mobile {
    display: none;
  }
}

.flex {
  display: flex;
}

.anchor {
  display: block;
  height: 1px;
  position: relative;
  top: -70px;
}
@media (min-width: 600px) {
  .anchor {
    top: -100px;
  }
}

footer {
  font-size: 0.75rem;
  max-width: calc(1200px + 5rem);
  margin: 3rem auto 0;
  justify-content: center;
}
footer nav {
  margin-left: 0.333em;
}
footer nav li {
  position: relative;
}
footer nav li:not(:last-child) {
  margin-right: 0.333em;
}
footer nav li::before {
  content: " ";
  display: inline-block;
  width: 1em;
  height: 1em;
  background: url("../images/icons/dot.svg") no-repeat center center/3px;
  margin-right: 0.1em;
  font-size: 0.75em;
}

.kontakt-images figure img {
  width: 70%;
}

header#masthead {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  min-height: 3rem;
  padding: 1rem 5vw;
  background: #e1f5ef;
  z-index: 9;
}
@media (min-width: 600px) {
  header#masthead {
    padding: 1rem 5rem;
  }
}
@media (min-width: 900px) {
  header#masthead {
    display: flex;
    justify-content: flex-end;
    padding: 1rem 1rem 1rem 5rem;
  }
}
@media (min-width: 1200px) {
  header#masthead {
    padding: 1rem 5rem;
  }
}
@media (max-width: 899.8px) {
  header#masthead.open {
    height: 100vh;
    overflow: auto;
  }
  header#masthead.open .nav-wrapper {
    display: block;
  }
}

#logo, #menu_toggle {
  position: fixed;
  top: 0;
  padding: 1rem 5vw;
  z-index: 99;
}
@media (min-width: 600px) {
  #logo, #menu_toggle {
    padding: 1rem;
  }
}

#logo {
  box-sizing: content-box;
  width: 10vw;
  left: 0;
}
@media (min-width: 900px) {
  #logo {
    width: 5rem;
  }
}

#menu_toggle {
  right: 0;
}
#menu_toggle #menu_close {
  display: none;
}
#menu_toggle.open #menu_open {
  display: none;
}
#menu_toggle.open #menu_close {
  display: initial;
}

@media (max-width: 899.8px) {
  .nav-wrapper {
    display: none;
    margin-top: 4rem;
  }
}
@media (min-width: 900px) {
  .nav-wrapper nav ul {
    display: flex;
  }
}
@media (max-width: 899.8px) {
  .nav-wrapper nav li {
    position: relative;
    margin-bottom: 0.2em;
    padding-bottom: 0.2em;
  }
  .nav-wrapper nav li::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 1px;
    background: transparent url("../images/icons/dot-padded.svg") repeat-x left top/contain;
  }
  .nav-wrapper nav li:nth-child(2), .nav-wrapper nav li:nth-child(3) {
    padding-left: 0.6667rem;
  }
  .nav-wrapper nav li:nth-child(6), .nav-wrapper nav li:last-child {
    margin-bottom: 1.5rem;
  }
}
@media (min-width: 900px) {
  .nav-wrapper nav {
    font-weight: bold;
  }
  .nav-wrapper nav ul li:not(:last-child) {
    margin-right: 1rem;
  }
}
.nav-wrapper figure {
  transform: translateX(-5vw);
}
@media (min-width: 600px) {
  .nav-wrapper figure {
    transform: translateX(-5rem);
  }
}

.scrolldown {
  display: none;
}

article.home-article {
  display: flex;
  flex-flow: column nowrap;
}
article.home-article .intro {
  order: 2;
  max-width: 18rem;
}
@media (max-width: 899.8px) {
  article.home-article {
    margin-top: 2rem;
  }
}
@media (max-width: 599.8px) {
  article.home-article h1, article.home-article .intro {
    padding: 0 2rem;
  }
  article.home-article .intro {
    justify-self: flex-end;
  }
}
@media (min-width: 600px) {
  article.home-article {
    display: grid;
  }
  article.home-article h1 {
    margin: 0;
  }
  article.home-article .intro {
    font-size: 0.875rem;
    max-width: 17rem;
  }
  article.home-article .scrolldown {
    grid-column-start: 1;
    grid-column-end: -1;
    grid-row-start: bottom;
    justify-self: center;
  }
}
@media screen and (min-width: 600px) and (max-width: 899.8px) and (orientation: landscape) {
  article.home-article h1 {
    padding: 0 1.5rem 1rem;
  }
  article.home-article .intro {
    justify-self: center;
  }
}
@media screen and (min-width: 768px) and (min-height: 1024px) {
  article.home-article {
    height: calc(var(--vh, 1vh) * 100 - 6rem);
  }
}
@media (min-width: 600px) and (orientation: portrait) {
  article.home-article {
    grid-template-columns: [flower] 2fr [headline] 1fr [intro] 1fr [right] 2fr;
    grid-template-rows: [headline] 1fr [flower] 2fr [intro] 2fr [bottom] 3rem;
  }
  article.home-article h1 {
    grid-column-start: headline;
    grid-column-end: -1;
    grid-row-start: headline;
    align-self: end;
  }
  article.home-article figure {
    grid-column-start: flower;
    grid-column-end: right;
    grid-row-start: flower;
    align-self: end;
    margin-bottom: 1rem;
  }
  article.home-article .intro {
    grid-column-start: intro;
    grid-column-end: -1;
    grid-row-start: intro;
    padding-right: 5vw;
    align-self: center;
  }
}
@media (min-width: 600px) and (orientation: portrait) and (min-width: 600px) {
  article.home-article .intro {
    padding-right: 5rem;
  }
}
@media (min-width: 600px) and (orientation: portrait) {
  article.home-article .scrolldown {
    display: block;
    align-self: center;
  }
}
@media (min-width: 600px) and (orientation: portrait) {
  article.home-article .home-contact {
    display: block;
  }
}
@media (min-width: 600px) and (orientation: portrait) {
  article.home-article p.dotted-bottom::after {
    display: block;
  }
}
@media (min-width: 900px) {
  article.home-article {
    /* 2nd var() arg is for browsers that don't support custom properties */
    min-height: calc(var(--vh, 1vh) * 100 - 6rem);
    margin-top: 3rem;
    grid-template-columns: [flower] 5fr [headline] 3fr [scrolldown] 4rem [intro] 4fr;
    grid-template-rows: [headline] 1fr [intro] 2fr [bottom] 3rem;
  }
  article.home-article h1 {
    grid-column-start: headline;
    grid-column-end: -1;
    grid-row-start: headline;
  }
  article.home-article figure {
    grid-column-start: flower;
    grid-column-end: scrolldown;
    grid-row-start: headline;
    grid-row-end: bottom;
    align-self: center;
  }
  article.home-article .intro {
    grid-column-start: intro;
    grid-row-start: intro;
    padding-right: 5vw;
    align-self: end;
  }
}
@media (min-width: 900px) and (min-width: 600px) {
  article.home-article .intro {
    padding-right: 5rem;
  }
}
@media (min-width: 900px) {
  article.home-article .scrolldown {
    display: block;
  }
}
@media (min-width: 900px) {
  article.home-article .home-contact {
    display: block;
  }
}
@media (min-width: 900px) {
  article.home-article p.dotted-bottom::after {
    display: block;
  }
}
@media (min-width: 1800px) {
  article.home-article h1 {
    font-size: 3rem;
  }
}

/*# sourceMappingURL=style.css.map */
