/* ------------------------------ */
/* ----- Typography / Colors ---- */
/* ------------------------------ */

@font-face {
  font-family: 'Dax';
  font-weight: normal;
  font-style: normal;
  src: url('/wp-content/themes/veganwebagency_child/fonts/ff_dax_pro_regular.woff2') format('woff2'),
       url('/wp-content/themes/veganwebagency_child/fonts/ff_dax_pro_regular.woff') format('woff');
  font-display: swap;
}


/* ------------------------------ */
/* ---------- Variables --------- */
/* ------------------------------ */

:root {
  /* Brand Fonts */
  --brand-font: 'Dax';

  /* Brand Colors*/
  --brand-black: #001D14;
  --brand-color: #005239;
  --brand-white: #ffffff;

  /* Additional Colors */
  --brand-list-color: rgba(0, 82, 57, .3);
  --brand-link-color: rgba(0, 82, 57, .15);
  --brand-background-color-transparent: rgba(0, 82, 57, .05);
  --color-white-transparent: rgba(255, 255, 255, .6);

  /* Layout */
  --nav-width: 20%;
  --quote-position: 3rem;
}


/* ------------------------------ */
/* ----------- General ---------- */
/* ------------------------------ */

::-moz-selection {
  background: var(--brand-color);
  color: var(--brand-white);
}

::selection {
  background: var(--brand-color);
  color: var(--brand-white);
}

::-moz-selection {
  background: var(--brand-color);
  color: var(--brand-white);
}

img::selection, video::selection, iframe::selection {
  background-color: transparent;
}

img::-moz-selection, video::-moz-selection, iframe::-moz-selection {
  background-color: transparent;
}

html {
  font-size: 20px;
}

body {
  font-family: var(--brand-font);
  font-size: 1rem;
  line-height: 1.7;
  color: var(--brand-black);
  background-color: var(--brand-white);
  -webkit-tap-highlight-color: transparent;
}

.site_wrapper {
  background-color: var(--brand-white);
}

main {
  margin-left: var(--nav-width);
  margin-bottom: 6rem;
}

.blog main {
  min-height: calc(100vh - 159px);
}

h1, h2, h3, h4, .typography--h2 {
  font-weight: normal;
  color: var(--brand-color);
}

h2:first-child, h3:first-child, h4:first-child {
  margin-top: 0;
}

h1 {
  font-size: 2.25rem;
  line-height: 1.2;
  margin-top: 0;
  margin-bottom: .5rem;
}

h2, .typography--h2 {
  font-size: 1.6rem;
  line-height: 1.35;
  margin-bottom: .25rem;
}

h3, .typography--h3 {
  font-size: 1.45rem;
  line-height: 1.35;
  margin-bottom: 0;
}

h4, .typography--h4 {
  font-size: 1.2rem;
  margin-bottom: 0;
}

a {
  color: var(--brand-black);
  text-decoration: none;
}

a.full {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  max-width: 100%;
  text-indent: -30000px;
  z-index: 10;
  text-decoration: none;
  text-align: left;
}

a.full > span {
  position: absolute;
  height: 1px;
  width: 1px;
  clip: rect(1px,1px,1px,1px);
  border: 0;
  overflow: hidden;
}

p {
  margin: 0 0 .75rem;
}

p:last-child, main ul:last-child {
  margin-bottom: 0;
}

main ul {
  margin: 0 0 1.25rem;
}

main p + ul {
  margin-top: -.25rem;
}

main ul li {
  position: relative;
  padding-left: 1.05em;
}

main ul li + li {
  margin-top: .4rem;
}

main ul li::before {
  content: "";
  position: absolute;
  top: 15px;
  left: 0;
  width: 10px;
  height: 2px;
  background-color: var(--brand-list-color);
}

.macos main ul li::before, .ios main ul li::before {
  top: 16px;
}

.android main ul li::before {
  top: 12px;
}

main a:not(.full):not(.page-numbers) {
  position: relative;
  display: inline-block;
}

main a:not(.full):not(.page-numbers)::before, main a:not(.full):not(.page-numbers)::after {
  content: "";
  position: absolute;
  height: 2px;
  bottom: 2px;
  left: 0;
}

main a:not(.full):not(.page-numbers)::before {
  width: 100%;
  background-color: var(--brand-link-color);
}

main a:not(.full):not(.page-numbers)::after {
  width: 0;
  background-color: var(--brand-color);
  -webkit-transition: .75s;
  -o-transition: .75s;
  transition: .75s;
}

.no-touchevents main a:not(.full):not(.page-numbers):hover::after {
  width: 100%;
}

p > a + br + a {
  margin-top: 1px;
}

address {
  line-height: 1.5;
}

address + p {
  margin-top: .5rem;
}

address b {
  font-size: 1.05rem;
}


/* Visually hidden */
a.visually-hidden:not(.skip-link):focus-visible, a.visually-hidden:not(.skip-link):focus {
  position: static !important;
  display: block;
  overflow: visible;
  clip: auto;
  height: auto;
  width: auto;
  margin: var(--spacing-0) 0;
  text-decoration: underline;
}

a.skip-link:focus-visible, a.skip-link:focus {
  overflow: visible;
  clip: auto;
  width: auto;
  height: auto;
  z-index: 10000;
  font-size: var(--font-size-2);
  font-weight: 500;
  color: var(--brand-black);
  padding: 5px 12px;
  outline: 2px solid !important;
}



/* ------------------------------ */
/* ----------- Layout ----------- */
/* ------------------------------ */

.site_wrapper {
  margin: 0 auto;
}

.section {
  padding-top: 6rem;
}

.section:first-of-type {
  padding-top: 4rem;
}

.section.section--small-gap {
  padding-top: 4.5rem;
}

.header.header--no-cover + main .section:first-child {
  padding-top: 6rem;
}

.header:not(.header--no-cover) .section:first-child {
  padding-top: 3rem;
}

.inside {
  max-width: 1200px;
  padding: 0 1.5rem;
}

.inside, .wpb_content_element, .vc_row .vc_row {
  margin: 0;
}

.section > div {
  padding: 0 3rem;
  max-width: 1200px;
}

.section.section--no-gap, .section > div, .section__row > .row > div > div {
  padding-top: 3rem;
}

.section__row {
  margin-top: 3rem;
}

.section > div:first-child, .section__row > .row > div > div:first-child {
  padding-top: 0;
}


/* Title */
.section__title + div {
  padding-top: 0 !important;
}


/* ------------------------------ */
/* ------------ Media ----------- */
/* ------------------------------ */

/* Images */
.picture_container {
  position: relative;
  display: block;
  overflow: hidden;
  line-height: 0;
}

.picture_container--cover img {
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.picture_container--cover, .picture_container--cover picture {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}

@media (max-width: 413.98px) {

  .picture_container:not(.picture_container--cover) img {
    width: 100%;
  }

}


/* Section */
.section__text + .section__image {
  padding-top: 1rem;
}

.section__image .picture_description {
  font-size: 16px;
  margin-top: 6px;
  color: var(--brand-color);
}

.section__row .section__image {
  margin-top: -2rem;
}


/* LazyLoad */
img[data-lazy-src] {
  opacity: 0;
}

img.lazyloaded {
  -webkit-transition: opacity .5s linear 0.25s;
  -moz-transition: opacity .5s linear 0.25s;
  transition: opacity .5s linear 0.25s;
  opacity: 1;
}


/* Position */
.picture_container--left img {
  -o-object-position: left center;
     object-position: left center;
}

.picture_container--right img {
  -o-object-position: right center;
     object-position: right center;
}


/* Videos */
.video_container {
  position: relative;
  display: block;
  overflow: hidden;
  line-height: 0;
}

.video_container--embed {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16 / 9;
}

.video_container--embed iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.video_container--cover iframe {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.video_container--cover video {
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
  height: 100%;
}

/* Video thumbs */
.video_container--cover {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}


/* iFrames */
.iframe_container {
  position: relative;
  overflow: hidden;
}

.iframe_container iframe {
  max-width: 100%;
}

/* Touchevents */
.no-touchevents .hide-no-touchevents {
  display: none;
}


/* ------------------------------ */
/* ---------- Animations -------- */
/* ------------------------------ */

.intro-animation {
  -webkit-transition: all .5s;
  -o-transition: all .5s;
  transition: all .5s;
  -webkit-transition-delay: .25s;
       -o-transition-delay: .25s;
          transition-delay: .25s;
}

.intro-animation.is-visible {
  opacity: 1;
}

.intro-animation {
  -webkit-transform: translateX(-30px);
      -ms-transform: translateX(-30px);
          transform: translateX(-30px);
}

.intro-animation.animation-delay0 {
  -webkit-transition-delay: 0s;
       -o-transition-delay: 0s;
          transition-delay: 0s;
}

.intro-animation.is-visible {
  -webkit-transform: translateX(0);
      -ms-transform: translateX(0);
          transform: translateX(0);
}



/* ------------------------------ */
/* ------------ Icon ------------ */
/* ------------------------------ */

.pagination a.next::before, .pagination a.next::after, .pagination a.prev::before, .pagination a.prev::after, .site__language_switcher a > span::before, .site__language_switcher a > span::after,
.site_cover__content__quote::before, .cta::before, .cta::after, .accordion_trigger::before {
    content: "";
    position: absolute;
    background: url(/wp-content/themes/veganwebagency_child/img/iconset.svg) no-repeat;
    background-size: 156px;
    -webkit-transition: .5s;
    -o-transition: .5s;
    transition: .5s;
}

.no-touchevents .pagination a.next:hover::before, .pagination a.next::after, .no-touchevents .pagination a.prev:hover::before, .pagination a.prev::after,
.no-touchevents .cta:hover::before, .cta::after, .site__language_switcher a > span::after, .no-touchevents .site__language_switcher a:hover> span::before {
    opacity: 0;
}

.no-touchevents .pagination a.next:hover::after, .no-touchevents .pagination a.prev:hover::after, .no-touchevents .cta:hover::after, .no-touchevents .site__language_switcher a:hover> span::after {
    opacity: 1;
}

.pagination a.next::before, .pagination a.next::after, .pagination a.prev::before, .pagination a.prev::after {
    width: 12px;
    height: 18px;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
}

.pagination a.prev::before {
    background-position: 0px 0px;
}

.pagination a.prev::after {
    background-position: -22px 0;
}

.pagination a.next::before {
    background-position: -9px 0;
}

.pagination a.next::after {
    background-position: -31px 0;
}

.site__language_switcher a > span::before, .site__language_switcher a > span::after{
    width: 17px;
    height: 17px;
    top: 5px;
    left: 0;
}

.macos .site__language_switcher a > span::before, .macos .site__language_switcher a > span::after, .ios .site__language_switcher a > span::before, .ios .site__language_switcher a > span::after {
    top: 6px;
}

.site__language_switcher a > span::before {
    background-position: -1px -20px;
}

.site__language_switcher a > span::after {
    background-position: -19px -20px;
}

.safari .site__language_switcher a > span::before {
    bottom: 1px;
}

.site_cover__content__quote::before {
    top: 13px;
    left: 8px;
    width: 47px;
    height: 36px;
    background-position: -108px -2px;
    -webkit-transform: scale(.7);
        -ms-transform: scale(.7);
            transform: scale(.7);
}

.macos .site_cover__content__quote::before, .ios .site_cover__content__quote::before {
    margin-top: 2px;
}

.cta::before, .cta::after {
    width: 32px;
    height: 62px;
    top: 50%;
    right: 1.2rem;
    -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    transition: opacity .5s, right .25s;
}

.cta::before {
    background-position: -41px 2px;
}

.cta::after {
    background-position: -73px 2px;
}

.no-touchevents .cta:hover::before, .no-touchevents .cta:hover::after {
    right: 1rem;
}

.accordion_trigger::before {
    width: 18px;
    height: 31px;
    top: 50%;
    right: 1.5rem;
    -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    transition: .5s;
}

.accordion_trigger::before {
    background-position: -1px -58px;
}

.no-touchevents .accordion_trigger:hover::before {
    -webkit-transform: translateY(-50%) rotate(90deg);
        -ms-transform: translateY(-50%) rotate(90deg);
            transform: translateY(-50%) rotate(90deg);
}

.no-touchevents .accordion:hover .accordion_trigger::before, .accordion--active .accordion_trigger::before {
    -webkit-transform: translateY(-50%) rotate(90deg);
    -ms-transform: translateY(-50%) rotate(90deg);
    transform: translateY(-50%) rotate(90deg);
}

.accordion--active .accordion_trigger::before {
    opacity: 0;
}




/* ------------------------------ */
/* ------------ Footer ---------- */
/* ------------------------------ */

/* General */
footer {
  padding-bottom: 16px;
  margin-left: var(--nav-width);
}

.footer__inside {
  padding: 0 3rem;
}

footer a, footer span {
  display: inline-block;
  font-size: 16px;
  opacity: .5;
}

.footer__nav ul li {
  display: inline-block;
}

.footer__nav ul li + li {
  margin-left: 1.25rem;
}

footer a {
  text-decoration: none;
  -webkit-transition: .5s;
  -o-transition: .5s;
  transition: .5s;
}

.no-touchevents footer a:hover {
  opacity: 1;
}



/* ------------------------------ */
/* -------- Pages ------- */
/* ------------------------------ */

/* Contact */
.page-id-85 .section__row .col-l-8 {
  -ms-flex-preferred-size: 58.33333333%;
  flex-basis: 58.33333333%;
  max-width: 58.33333333%;
}

.page-id-85 .section__row .col-l-4 {
  -ms-flex-preferred-size: 41.66666667%;
  flex-basis: 41.66666667%;
  max-width: 41.66666667%;
}

.page-id-85 .section__text + .section__row {
  padding-top: 1rem;
  margin-top: 0;
}


/* Datenschutz */
.privacy-policy p + h3 {
  margin-top: 2.25rem;
}

.privacy-policy h3 + h4 {
  margin-top: .5rem;
}



/* ------------------------------ */
/* -------- Media Queries ------- */
/* ------------------------------ */

@media only screen and (min-width: 2000px) {

  :root {
      --nav-width: 440px;
  }

}

@media only screen and (min-width: 1921px) {

  .section > div, .inside {
    margin: 0 auto;
  }

}

@media only screen and (max-width: 1535.98px) {

  :root {
      --quote-position: 2rem;
  }

}

@media only screen and (max-width: 1439.98px) {

  :root {
    --nav-width: 22%;
  }

  main {
    margin-bottom: 4.5rem;
  }

  h1 {
    font-size: 2.2rem;
  }

  .section, .header.header--no-cover + main .section:first-child {
    padding-top: 4.5rem;
  }

}


@media only screen and (max-width: 1365.98px) {

  h1 {
    font-size: 2.1rem;
  }

  h2, .typography--h2 {
    font-size: 1.5rem;
  }

  h3, .typography--h3 {
    font-size: 1.35rem;
  }

  h4, .typography--h4 {
    font-size: 1.15rem;
  }

}


@media only screen and (max-width: 1199.98px) {  
    
  /* General */
  :root {
    --nav-width: 25%;
    --quote-position: 15px;
  }

  html {
    font-size: 19px;
  }

  h1 {
    font-size: 2rem;
  }

  h2, .typography--h2 {
    font-size: 1.4rem;
  }

  h3, .typography--h3 {
    font-size: 1.25rem;
  }

  h4, .typography--h4 {
    font-size: 1.1rem;
  }

  .section > div {
    padding-left: 2rem;
    padding-right: 2rem;
  }

  main ul li {
    padding-left: 18px;
  }

  main ul li::before {
    top: 13px;
  }

  .macos main ul li::before, .ios main ul li::before {
    top: 14px;
  }

  main {
    margin-bottom: 3.5rem;
  }

  .section, .header.header--no-cover + main .section:first-child {
    padding-top: 3.5rem;
  }

  .section:first-of-type {
    padding-top: 3rem;
  }

  .section.section--no-gap, .section > div, .section__row > .row > div > div {
    padding-top: 2rem;
  }

  .section__row {
    margin-top: 2rem;
  }

  /* Icons */
  .accordion_trigger::before {
    right: 1rem;
    -webkit-transform: translateY(-50%) scale(.75);
    -ms-transform: translateY(-50%) scale(.75);
    transform: translateY(-50%) scale(.75);
  }

  .no-touchevents .accordion:hover .accordion_trigger::before, .accordion--active .accordion_trigger::before {
      -webkit-transform: translateY(-50%) rotate(90deg) scale(.75);
      -ms-transform: translateY(-50%) rotate(90deg) scale(.75);
      transform: translateY(-50%) rotate(90deg) scale(.75);
  }

  /* Footer */
  .footer__inside {
    padding-left: 2rem;
    padding-right: 2rem;
  }

}


@media only screen and (max-width: 1023.98px) {

  /* General */
  :root {
    --header-height: 78px;
    --nav-width: 0;
    --quote-position: 1.5rem;
  }

  html {
    font-size: 18px;
  }

  .inside {
    max-width: 100%;
  }

  h1 {
    font-size: 2.2rem;
  }

  .section, .header.header--no-cover + main .section:first-child {
    padding-top: 3rem;
  }

  .header.header--no-cover + main {
    margin-top: 4.5rem;
  }

  .section:first-of-type {
    padding-top: 2.5rem;
  }

  .section > div {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }


  /* Icons */
  .site__language_switcher a > span::before {
    background-position: -19px -20px;
  }

  /* Footer */
  .footer__inside {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }

}

@media all and (max-width: 1023.98px) and (min-width: 768px) {

  .section__row .col-l-4:nth-child(3), .section__row .col-l-8 + .col-l-4, .section__row .col-l-4 + .col-l-8, .section__row .col-l-3:nth-child(3), .section__row .col-l-3:nth-child(4) {
    margin-top: 1.25rem;
    padding-top: 1.25rem;
  }

}


@media (max-width: 767.98px) {  

  /* General */
  :root {
    --header-height: 64px;
  }
  
  h1 br, h2 br, h3 br {
    content: "";
  }

  h1 br::after, h2 br::after, h3 br::after {
    content: " ";
  }

  h1 {
    font-size: 1.9rem;
    margin-bottom: 0.65rem;
  }

  .header.header--no-cover + main {
    margin-top: var(--header-height);
  }

  .section.section--no-gap, .section > div, .section__row > .row > div > div, .section.section--small-gap {
    padding-top: 2.5rem;
  }

  .section__row {
    margin-top: 2.5rem;
  }

  .section > div {
    padding-left: 15px;
    padding-right: 15px;
  }

  .section__row .section__image {
    margin-top: -1.5rem;
  }

  .section__row > .row > div + div .section__image {
    margin-top: 15px;
  }

  main ul li + li {
    margin-top: .2rem;
  }


  /* Icons */
  .site_cover__content__quote::before {
    display: none;
  }

  /* Footer */
  footer {
    padding-bottom: 20px;
  }

  .footer__inside {
    padding-left: 15px;
    padding-right: 15px;
  }

  footer a, footer span {
    font-size: 15px;
  }

  .footer__nav ul li + li {
    margin-left: 15px;
  }

}


@media only screen and (max-width: 575.98px) {

  .picture_container--cover, .picture_container--cover picture {
    position: relative;
  }

}


@media (max-width: 413.98px) {  

  /* General */
  h1 {
    font-size: 1.75rem;
  }

  h2, .typography--h2 {
    font-size: 1.3rem;
  }

  h3, .typography--h3, h4, .typography--h4 {
    font-size: 1.1rem;
  }


  /* Icons */
  .site_cover__content__quote::before {
      content: none;
  }

  .accordion_trigger::before {
      right: .95rem;
      -webkit-transform: translateY(-50%) scale(.6);
      -ms-transform: translateY(-50%) scale(.6);
      transform: translateY(-50%) scale(.6);
  }

  .no-touchevents .accordion:hover .accordion_trigger::before, .accordion--active .accordion_trigger::before {
      -webkit-transform: translateY(-50%) rotate(90deg) scale(.6);
      -ms-transform: translateY(-50%) rotate(90deg) scale(.6);
      transform: translateY(-50%) rotate(90deg) scale(.6);
  }

}