/* FONTS start */

/****** poppins ******/
@font-face {
  font-family: 'Poppins';
  src: url('/static/bucher-gartengestaltung/assets/fonts/Poppins-Light.eot');
  src: url('/static/bucher-gartengestaltung/assets/fonts/Poppins-Light.eot?#iefix') format('embedded-opentype'),
    url('/static/bucher-gartengestaltung/assets/fonts/Poppins-Light.woff2') format('woff2'),
    url('/static/bucher-gartengestaltung/assets/fonts/Poppins-Light.woff') format('woff');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Poppins';
  src: url('/static/bucher-gartengestaltung/assets/fonts/Poppins-Regular.eot');
  src: url('/static/bucher-gartengestaltung/assets/fonts/Poppins-Regular.eot?#iefix') format('embedded-opentype'),
    url('/static/bucher-gartengestaltung/assets/fonts/Poppins-Regular.woff2') format('woff2'),
    url('/static/bucher-gartengestaltung/assets/fonts/Poppins-Regular.woff') format('woff');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Poppins';
  src: url('/static/bucher-gartengestaltung/assets/fonts/Poppins-Medium.eot');
  src: url('/static/bucher-gartengestaltung/assets/fonts/Poppins-Medium.eot?#iefix') format('embedded-opentype'),
    url('/static/bucher-gartengestaltung/assets/fonts/Poppins-Medium.woff2') format('woff2'),
    url('/static/bucher-gartengestaltung/assets/fonts/Poppins-Medium.woff') format('woff');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Poppins';
  src: url('/static/bucher-gartengestaltung/assets/fonts/Poppins-SemiBold.eot');
  src: url('/static/bucher-gartengestaltung/assets/fonts/Poppins-SemiBold.eot?#iefix') format('embedded-opentype'),
    url('/static/bucher-gartengestaltung/assets/fonts/Poppins-SemiBold.woff2') format('woff2'),
    url('/static/bucher-gartengestaltung/assets/fonts/Poppins-SemiBold.woff') format('woff');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Poppins';
  src: url('/static/bucher-gartengestaltung/assets/fonts/Poppins-Bold.eot');
  src: url('/static/bucher-gartengestaltung/assets/fonts/Poppins-Bold.eot?#iefix') format('embedded-opentype'),
    url('/static/bucher-gartengestaltung/assets/fonts/Poppins-Bold.woff2') format('woff2'),
    url('/static/bucher-gartengestaltung/assets/fonts/Poppins-Bold.woff') format('woff');
  font-weight: bold;
  font-style: normal;
  font-display: swap;
}

/****** kaushan script ******/
@font-face {
  font-family: 'Kaushan Script';
  src: url('/static/bucher-gartengestaltung/assets/fonts/KaushanScript-Regular.eot');
  src: url('/static/bucher-gartengestaltung/assets/fonts/KaushanScript-Regular.eot?#iefix') format('embedded-opentype'),
    url('/static/bucher-gartengestaltung/assets/fonts/KaushanScript-Regular.woff2') format('woff2'),
    url('/static/bucher-gartengestaltung/assets/fonts/KaushanScript-Regular.woff') format('woff');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

/* FONTS end */

/* STYLES start */

/* DATA ATTRIBUTES start */

/* DATA ATTRIBUTES end */

/* GLOBAL start */

/****** root ******/
:root {
  /* >>>>> background <<<<< */
  --background-white: #FFFFFF;
  --background-green-accent: #C3EA55;
  --background-green-contrast: #202B22;
  --background-green-contrast-hover: #181F1A;
  --background-green-contrast-alt: #1B231C;
  --background-grey-offer-icon: #E8E9E8;
  --background-grey-offer-icon-hover: #3F4A40;
  --background-green-shade-3: #353F37;
  --background-green-shade-4: #626A63;
  --background-green-shade-5: #A5AAA6;
  --background-green-shade-6: #BBBFBC;
  /* >>>>> text <<<<< */
  --text-white: #FFFFFF;
  --text-black: #1A1A1A;
  --text-grey: #D2D4D2;
  --text-grey-paragraph: #767676;
  --text-green-accent: #C3EA55;
  --text-green-accent-alt: #77922D;
  --text-green-contrast: #202B22;
  /* >>>>> border <<<<< */
  --border-white: #FFFFFF;
  --border-grey: #BBBFBC;
  --border-grey-offer-icon-hover: #3F4A40;
  --border-green-contrast: #202B22;
  --border-green-contrast-hover: #181F1A;
  --border-green-accent-hover: #B1BF8B; 
  --border-green-accent: #C3EA55;
  --border-green-logo-dark: #316337;
  /* >>>>> container width <<<<< */
  --container-desktop-xxl: 1860px;
  --container-desktop-xl: 1680px;
  --container-desktop-l: 1500px;
  --container-desktop-m: 1320px;
  --container-desktop-s: 1140px;
  --container-tablet: 960px;
  --container-mobile-l: 720px;
  --container-mobile-m: 540px;
  --container-mobile-s: calc(100vw - 44px);
}

/****** body ******/
body {
  margin: 0;
  padding: 0;
  font-family: 'Poppins', sans-serif;
}

/****** list ******/
ul {
  list-style-type: none;
  margin: 0;
  padding: 0;
}

/****** anchor ******/
a {
  color: inherit;
  text-decoration: none;
}

/****** figure ******/
figure {
  margin: 0;
}

/****** container ******/
.container {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
}

/****** page-content ******/
#page-content {
  position: relative;
  min-height: 100vh;
}

/****** content-wrap ******/
#content-wrap {
  /* !!!!! has to have the same height as footer, can also be set dynamically with javascript !!!!! */
  padding-bottom: 345px;
}

/****** header ******/
#header {
  height: 80px;
}

#header-wrap {
  /*
  position: relative;
  */
  height: 100%;
}

#header-subcontainer {
  height: 100%;
}

/****** footer ******/
#footer {
  position: absolute;
  bottom: 0;
  width: 100%;
  /* !!!!! has to have the same height as content-wrap !!!!! */
  height: 345px;
  overflow: hidden;
}


/****** button ******/
/* >>>>> btn-standard <<<<< */
.btn-standard {
  display: flex;
  width: fit-content;
  width: -moz-fit-content;
  font-size: 0.813rem;
  background-color: var(--background-green-contrast);
  color: var(--text-white);
  font-weight: normal;
  padding: 13px 25px;
  border: 1px solid var(--border-green-contrast);
  border-radius: 99px;
  box-shadow: 0px 0px 0px rgba(47, 63, 50, 0.2);
  transition: background-color 150ms ease-in-out, box-shadow 150ms ease-in-out, border-color 150ms ease-in-out;
}

/* >>>>> hover effects <<<<< */
.btn-standard:hover,
.btn-standard:focus {
  background-color: var(--background-green-contrast-hover);
  box-shadow: 3px 3px 10px rgba(47, 63, 50, 0.2);
  transition: background-color 200ms ease-in-out, box-shadow 250ms ease-in-out, border-color 200ms ease-in-out;
}

/*
.btn-standard.hover-special:hover,
.btn-standard.hover-special:focus {
background-color: var(--background-green-accent);
color: var(--text-green-contrast);
box-shadow: 3px 3px 10px rgba(47, 63, 50, 0.2);
transition: background-color 200ms ease-in-out, box-shadow 250ms ease-in-out;
}
*/

/* >>>>> disabled <<<<< */

/****** attributes ******/
[data-hidden] {
  display: none;
}

[data-unselectable] {
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

/****** title, text & hierarchy ******/

/* GLOBAL end */

/* COMPONENTS start */

/****** banner carousel ******/
section.slideshow {
  position: relative;
  height: 100vh;
  width: 100%;
  overflow: hidden;
  max-height: 680px;
}

section.slideshow .title {
  position: absolute;
  pointer-events: none;
  z-index: 0;
  color: var(--text-white);
}

section.slideshow .slides {
  position: absolute;
  transition: .5s;
  transition-timing-function: ease-out;
  transition-property: right;
  right: 0;
}

section.slideshow .slides[data-onload] {
  transition: unset;
}

section.slideshow .slides:not(:nth-child(3)) {
  right: -100vw;
}

section.slideshow .slides img {
  width: 100vw;
  height: 680px;
  max-height: 680px;
  object-fit: cover;
  object-position: center center;
}

section.slideshow button {
  position: absolute;
  top: 50%;
  margin-top: -24px;
  z-index: 1000;
  background: transparent;
  border: none;
  width: 48px;
  height: 48px;
  padding: 0;
  cursor: pointer;
}

section.slideshow button:hover svg #fill,
section.slideshow button:focus svg #fill {
  opacity: 0.8;
}

section.slideshow button:focus {
  outline: none;
  box-shadow: none;
}

section.slideshow button svg {
  width: 48px;
  height: 48px;
}

section.slideshow button.slide_left {
  left: 4%;
}

section.slideshow button.slide_right {
  right: 4%;
}

section.slideshow .slideshow__overlay {
  position: absolute;
  top: 0;
  left: 0;
  background-color: rgba(0, 0, 0, 0.5);
  width: 100%;
  height: 100%;
  z-index: 100;
}

section.slideshow .slideshow__content {
  position: absolute;
  z-index: 1000;
  top: 50%;
  /*
  max-width: 750px;
  */
  max-width: 50%;
  opacity: 0;
  /*
  transform: translate(250px, -50%);
  */
  transform: translate(250px, -45%);
  margin-left: 40px;
  pointer-events: none;
}

.slideshow__content__cta {
  display: flex;
  margin-top: 30px;
}

section.slideshow .slideshow__content--active {
  transition: opacity 500ms ease-in-out, transform 500ms ease-in-out;
  opacity: 1 !important;
  /*
  transform: translate(0, -50%) !important;
  */
  transform: translate(0, -45%) !important;
  pointer-events: auto;
}

section.slideshow .slideshow__content span {
  font-family: 'Kaushan Script';
  font-size: 16px;
  font-weight: normal;
  color: var(--text-green-accent);
  /*
  text-transform: uppercase;
  */
}

section.slideshow .slideshow__content__title {
  font-size: 2.5rem;
  letter-spacing: 1px;
  font-weight: 600;
  color: var(--text-white);
  line-height: 1.3;
  margin-top: 15px;
  /*
  max-width: 620px;
  */
  max-width: unset;
}

section.slideshow .slideshow__content p {
  font-size: 1rem;
  font-weight: normal;
  color: var(--text-white);
  margin: 13px 0 0;
  line-height: 1.8;
}

section.slideshow .slideshow__progress {
  width: 100%;
  position: absolute;
  bottom: 0;
  z-index: 1000;
}

section.slideshow .slideshow__progress__bar {
  background-color: var(--border-green-accent);
  height: 6px;
  width: 0%;
}

/* >>>>> progress animation <<<<< */
@keyframes progressAnimation {
  0% {
    width: 0%;
  }

  100% {
    width: 100%;
  }
}

section.slideshow .slideshow__progress__bar[data-animation="active"] {
	animation-name: progressAnimation;
  animation-duration: 7.9s;
  animation-timing-function: linear;
  animation-direction: normal;
  animation-fill-mode: backwards;
  /*
  animation-iteration-count: infinite;
  */
}

section.slideshow .slideshow__progress__bar[data-animation="reset"] {
	animation: none;
}


/* COMPONENTS end */

/* CUSTOM start */

/****** header / navigation ******/
#header {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10000;
  width: 100%;
}

section.header-section,
section.header-section > div.container,
section.header-section div.subcontainer {
  height: 100%;
}

section.header-section div.subcontainer:not(.burger-dropdown .subcontainer) {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
}	

section.header-section nav ul {
  display: flex;
  flex-direction: row;
  align-items: center;
  column-gap: 40px;
}

section.header-section nav ul a {
  display: flex;
  flex-direction: row;
  column-gap: 5px;
  font-size: 0.813rem;
  font-weight: 600;
  color: var(--text-white);
}

div.nav-icon {
  display: grid;
  align-items: center;
}

section.header-section nav ul a svg {
  opacity: 0;
  display: none;
  width: 13px;
  height: 13px;
}	

section.header-section nav ul a[data-nav-active="true"] {
  color: var(--text-green-accent);
}

section.header-section nav ul a svg g path#leaf_icon {
  fill: var(--background-green-accent);
}	

section.header-section nav ul a[data-nav-active="true"] svg {
  display: block;
  opacity: 1;
}

section.header-section .contact a {
  display: flex;
  flex-direction: row;
  align-items: center;
  column-gap: 5px;
  font-size: 0.813rem;
  color: var(--text-white);
  font-weight: normal;
}

section.header-section .contact a svg {
  width: 15px;
  height: 15px;
}

section.header-section div.burger-menu {
  display: none;
  cursor: pointer;
  position: relaitve;
  z-index: 10;
}

section.header-section div.burger-menu .icon {
  display: flex;
}

section.header-section div.burger-menu g rect:not(.burger_background) {
  fill: var(--background-white);
}

section.header-section div.burger-menu g rect.burger_menu__line--mid {
  opacity: 0.6;
}

section.header-section div.burger-dropdown {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  height: 100svh;
  width: 100%;
  transform: translateY(-150px);
  pointer-events: none;
  background: var(--background-green-contrast-alt);
}

section.header-section div.burger-dropdown[data-active="true"] {
  opacity: 1;
  transform: translateY(0);
  transition: transform 200ms ease-out;
  pointer-events: auto;
}

section.header-section div.burger-dropdown .subcontainer {
  display: flex;
  flex-direction: column;
  row-gap: 45px;
  padding: 32px 0 0;
}

section.header-section div.burger-dropdown ul {
  flex-direction: column;
  align-items: start;
  row-gap: 15px;
}

section.header-section div.burger-dropdown ul li {
  border-bottom: 1px solid var(--border-green-logo-dark);
  width: 100%;
  padding-bottom: 15px;
}

section.header-section div.burger-dropdown ul li:last-of-type {
  border: unset;
}

section.header-section div.burger-dropdown .logo img {
  width: 170px;
}

section.header-section div.burger-dropdown ul a {
  font-size: 1.125rem;
  justify-content: space-between;
  padding-right: 6px;
}

section.header-section div.burger-dropdown ul a .nav-icon svg {
  width: 18px;
  height: 18px;
}

section.header-section div.burger-dropdown .contact.burger a {
  font-size: 1rem;
  column-gap: 7px;
}

section.header-section div.burger-dropdown .contact.burger svg {
  width: 16px;
  height: 16px;
}

/* >>>>> burger animation <<<<< */
/*
#burger_icon {
width: 30px;
height: 30px;
}
*/

@keyframes burgerAnimationTopForward {
  0% {
    transform: translate(1009px, 1028px) rotate(0deg);
    fill: var(--background-white);
  }

  100% {
    transform: translate(1013px, 1027px) rotate(45deg);
    fill: var(--background-green-accent);
  }
}

@keyframes burgerAnimationTopBackwards {
  0% {
    transform: translate(1013px, 1027px) rotate(45deg);
    fill: var(--background-green-accent);
  }

  100% {
    transform: translate(1009px, 1028px) rotate(0deg);
    fill: var(--background-white);
  }
}

@keyframes burgerAnimationMidForward {
  0% {
    opacity: 0.4;
    transform: translate(1009px, 1034px);
  }

  100% {
    opacity: 0;
    transform: translate(986px, 1034px);
  }
}

@keyframes burgerAnimationMidBackwards {
  0% {
    opacity: 0;
    transform: translate(986px, 1034px);
  }

  100% {
    opacity: 0.4;
    transform: translate(1009px, 1034px);
  }
}

@keyframes burgerAnimationBotForward {
  0% {
    transform: translate(1009px, 1040px) rotate(0deg);
    fill: var(--background-white);
  }

  100% {
    transform: translate(1011px, 1042px) rotate(-45deg);
    fill: var(--background-green-accent);
  }
}

@keyframes burgerAnimationBotBackwards {
  0% {
    transform: translate(1011px, 1042px) rotate(-45deg);
    fill: var(--background-green-accent);
  }

  100% {
    transform: translate(1009px, 1040px) rotate(0deg);
    fill: var(--background-white);
  }
}

.burger_menu__line--top[data-burger-animation="active"] {
  animation: burgerAnimationTopForward 0.5s ease 1;
  animation-direction: normal;
  animation-fill-mode: both;
}

.burger_menu__line--top[data-burger-animation="passive"] {
  animation: burgerAnimationTopBackwards 0.5s ease 1;
  animation-direction: normal;
  animation-fill-mode: both;
}

.burger_menu__line--mid[data-burger-animation="active"] {
  animation: burgerAnimationMidForward 0.5s ease 1;
  animation-direction: normal;
  animation-fill-mode: both;
}

.burger_menu__line--mid[data-burger-animation="passive"] {
  animation: burgerAnimationMidBackwards 0.5s ease 1;
  animation-direction: normal;
  animation-fill-mode: both;
}

.burger_menu__line--bot[data-burger-animation="active"] {
  animation: burgerAnimationBotForward 0.5s ease 1;
  animation-direction: normal;
  animation-fill-mode: both;
}

.burger_menu__line--bot[data-burger-animation="passive"] {
  animation: burgerAnimationBotBackwards 0.5s ease 1;
  animation-direction: normal;
  animation-fill-mode: both;
}

/* >>>>> hover effects <<<<< */
section.header-section nav ul a:hover,
section.header-section nav ul a:focus {
  color: var(--text-green-accent);
}

section.header-section .contact a:hover,
section.header-section .contact a:focus {
  color: var(--text-green-accent);
}

section.header-section .contact a:hover svg g path#comment_icon,
section.header-section .contact a:focus svg g path#comment_icon {
  fill: var(--background-green-accent);
}

/****** offer overview ******/
section.offer_overview {
  padding: 35px 0;
  overflow: hidden;
}

section.offer_overview .header {
  display: flex;
  flex-direction: row;
  align-items: center;
  column-gap: 50px;
}

section.offer_overview h2 {
  font-size: 1.625rem;
  font-weight: bold;
  margin: 5px 0 0;
}

section.offer_overview .headline span {
  font-family: 'Kaushan Script', serif;
  font-size: 1rem;
  color: var(--text-green-accent-alt);
}

section.offer_overview .header p {
  flex: 1;
  color: var(--text-grey-paragraph);
  font-size: 0.938rem;
  margin: 0;
  line-height: 1.8;
}

section.offer_overview .offering {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
  column-gap: 30px;
  margin-top: 50px;
}

section.offer_overview .offering .entry {
  display: flex;
  flex-direction: column;
  position: relative;
  border: 1px solid var(--border-grey);
  border-radius: 20px;
  padding: 45px 35px 35px 35px;
}

section.offer_overview .offering .entry h3 {
  margin: 0 0 30px 0;
  font-size: 21px;
  font-weight: 600;
}

section.offer_overview .offering .entry p {
  margin: 0 0 80px 0;
  font-size: 0.875rem;
  line-height: 2;
  color: var(--text-black);
}

section.offer_overview .offering .entry > h3,
section.offer_overview .offering .entry > p,
section.offer_overview .offering .entry > a {
  position: relative;
  z-index: 10;
}

section.offer_overview .offering .entry > a {
  margin-top: auto;
}

section.offer_overview .offering .entry svg {
  width: 250px;
  height: 250px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 0;
}

section.offer_overview .offering .entry svg g path {
  fill: var(--background-grey-offer-icon);
}

/* >>>>> hover effects <<<<< */
section.offer_overview .offering .entry:hover,
section.offer_overview .offering .entry:focus {
  background-color: var(--background-green-contrast);
  border-color: var(--border-green-accent-hover);
  color: var(--text-white);
}

section.offer_overview .offering .entry:hover p,
section.offer_overview .offering .entry:focus p {
  color: var(--text-white);
}

section.offer_overview .offering .entry:hover svg g path,
section.offer_overview .offering .entry:focus svg g path {
  fill: var(--background-grey-offer-icon-hover);
}

section.offer_overview .offering .entry:hover a,
section.offer_overview .offering .entry:focus a {
  background-color: var(--background-green-contrast-hover);
  border-color: var(--border-green-contrast-hover);
}

section.offer_overview .offering .entry a.hover-special:hover,
section.offer_overview .offering .entry a.hover-special:focus {
  background-color: var(--background-grey-offer-icon-hover);
  border-color: var(--border-grey-offer-icon-hover);
  color: var(--text-white);
}

/****** testimonial ******/
section.testimonial {
  padding: 20px 0 60px;
  overflow: hidden;
}

section.testimonial .subcontainer {
  display: flex;
  align-items: center;
  column-gap: 45px;
}

section.testimonial img {
  width: 90px;
  height: 90px;
  border-radius: 99px;
}

section.testimonial .headline span {
  font-family: 'Kaushan Script', serif;
  font-size: 1rem;
  color: var(--text-green-accent-alt);
}

section.testimonial .headline h2 {
  font-size: 1.625rem;
  font-weight: bold;
  margin: 5px 0 0;
}

section.testimonial .testimonial_text {
  flex: 1;
}

section.testimonial .testimonial_text p {
  margin: 0;
  font-size: 1.125rem;
  font-weight: 500;
  color: var(--text-black);
  line-height: 1.8;
}

section.testimonial .testimonial_text span {
  font-size: 0.875rem;
  color: var(--text-green-accent-alt);
}

/****** CTA ******/
section.cta {
  height: 400px;
  overflow: hidden;
  position: relative;
  display: grid;
  align-items: center;
  text-align: center;
}

section.cta img {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
}

section.cta .overlay {
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  position: absolute;
  top: 0;
  left: 0;
}

section.cta .subcontainer {
  position: relative;
  display: grid;
  justify-items: center;
}

section.cta h2 {
  font-size: 1.875rem;
  font-weight: 600;
  color: var(--text-white);
  margin: 0;
}

section.cta p {
  max-width: 740px;
  font-size: 1rem;
  color: var(--text-white);
  line-height: 2;
  margin: 30px 0 40px;
}

/****** banner standard ******/
section.banner-standard {
  height: 420px;
  overflow: hidden;
  position: relative;
  display: grid;
  align-items: center;
}

section.banner-standard img {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
}

section.banner-standard .overlay {
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  position: absolute;
  top: 0;
  left: 0;
}

section.banner-standard .subcontainer {
  position: relative;
  display: grid;
}

section.banner-standard .content {
  max-width: 60%;
  transform: translateY(11%);
}

section.banner-standard .content span {
  font-family: 'Kaushan Script';
  font-size: 16px;
  font-weight: normal;
  color: var(--text-green-accent);
}

section.banner-standard .content h1 {
  font-size: 2.5rem;
  letter-spacing: 1px;
  font-weight: 600;
  color: var(--text-white);
  line-height: 1.3;
  margin: 15px 0 0 0;
  max-width: 630px;
}

section.banner-standard .content p {
  font-size: 1rem;
  font-weight: normal;
  color: var(--text-white);
  margin: 13px 0 0;
  line-height: 1.8;
}

/****** banner standard ******/
section.selection .header {
  padding: 40px 0;
}

section.selection .header .subcontainer {
  display: flex;
  flex-direction: row;
  align-items: center;
  column-gap: 50px;
}

section.selection .headline span {
  font-family: 'Kaushan Script', serif;
  font-size: 1rem;
  color: var(--text-green-accent-alt);
}

section.selection h2 {
  font-size: 1.625rem;
  font-weight: bold;
  margin: 5px 0 0;
}

section.selection .header p {
  flex: 1;
  color: var(--text-grey-paragraph);
  font-size: 0.938rem;
  margin: 0;
  line-height: 1.8;
}

/****** selection ******/
section.selection .tiles_small {
  background: var(--background-green-shade-5);
}

section.selection .tiles_small .container {
  position: relative;
  max-width: unset;
}

section.selection .tiles_small .subcontainer {
  display: flex;
  flex-direction: row;
  align-items: center;
}

section.selection .tiles_small .arrow-left,
section.selection .tiles_small .arrow-right {
  display: flex;
  position: absolute;
  top: 50%;
  cursor: pointer;
}

section.selection .tiles_small .arrows {
  display: none;
}

section.selection .tiles_small .arrows svg {
  width: 30px;
  height: 30px;
}

section.selection .tiles_small .arrow-left {
  transform: translate(-70px, -50%);
  left: 0;
}

section.selection .tiles_small .arrow-right {
  transform: translate(70px, -50%);
  right: 0;
}

section.selection .tiles_small .entry {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: var(--background-green-shade-3);
  flex: 1;
  aspect-ratio: 1;
  color: var(--text-white);
  padding: 20px;
  cursor: pointer;
}

section.selection .tiles_small[data-aspect-ratio="landscape"] .entry {
  aspect-ratio: unset;
  padding: 60px 20px 60px 20px;
}

section.selection .tiles_small .entry:nth-child(even) {
  background-color: var(--background-green-shade-4);
}

section.selection .tiles_small .entry[data-active="true"] {
  color: var(--text-green-accent);
}


section.selection .tiles_small .entry img {
  height: 50px;
  width: 50px;
  margin-bottom: 25px;
}

section.selection .tiles_small .entry img.active {
  display: none;
}

section.selection .tiles_small .entry[data-active="true"] img.passive {
  display: none;
}

section.selection .tiles_small .entry[data-active="true"] img.active {
  display: block;
}

section.selection .tiles_small .entry h3 {
  margin: 0 0 2px 0;
  font-size: 0.813rem;
  font-weight: 600;
}

section.selection .tiles_small .entry span {
  font-size: 0.75rem;
  font-weight: 300;
  text-align: center;
}

section.selection .content {
  background-color: var(--background-green-contrast);
  color: var(--text-white);
}

section.selection .content[data-background="alternative"] {
  background-color: var(--background-grey-offer-icon);
  color: var(--text-black);
}

section.selection .content .subcontainer {
  position: relative;
  min-height: 250px;
  display: flex;
  align-items: center;
  padding: 60px 0;
  overflow: hidden;
}

section.selection .content .entry {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translate(100px, 0);
  opacity: 0;
  width: 100%;
  pointer-events: none;
}

/*
section.selection .content .entry[data-active="true"] {
opacity: 1;
transform: translate(0, -50%);
transition: opacity 200ms ease-in-out, transform 200ms ease-in-out;
pointer-events: auto;
}
*/

section.selection .content .entry[data-active="true"] {
  opacity: 1;
  transform: translate(0, 0);
  transition: opacity 200ms ease-in-out, transform 200ms ease-in-out;
  pointer-events: auto;
  position: relative;
}

section.selection .content .entry span:not(section.selection .content .additional-information span) {
  font-family: 'Kaushan Script';
  font-size: 16px;
  font-weight: normal;
  color: var(--text-green-accent);
}

section.selection .content[data-background="alternative"] .entry span:not(section.selection .content .additional-information span) {
  color: var(--text-green-accent-alt);
}

section.selection .content h4 {
  margin: 7px 0 28px 0;
  font-size: 1.25rem;
  font-weight: 600;
}

section.selection .content p {
  margin: 0;
  font-size: 0.875rem;
  font-weight: 300;
  line-height: 2;
}

section.selection .content p:not(section.selection .content .entry .team-entry p) {
  max-width: 70%;
}

section.selection .content[data-background="alternative"] p {
  font-weight: 400;
}

section.selection .content img:not(.team-entry img) {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 180px;
  height: 180px;
}

section.selection .content .additional-information {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  column-gap: 30px;
  text-transform: uppercase;
  max-width: 80%;
  margin-top: 19px;
  row-gap: 7px;
}

section.selection .content .additional-information .additional-information-entry {
  display: flex;
  flex-direction: row;
  column-gap: 30px;
}

section.selection .content .additional-information span {
  font-family: 'Poppins';
  font-size: 0.813rem;
  font-weight: 600;
  color: var(--text-white);
}

section.selection .content[data-background="alternative"] .additional-information span {
  color: var(--text-black);
}

section.selection .content .additional-information svg {
  width: 14px;
  height: 14px;
}

section.selection .content .additional-information svg path {
  fill: var(--background-green-shade-6);
}

section.selection .content .additional-information-entry:last-child div.icon {
  display: none;
}

section.selection .content .subcontainer .abo {
  display: flex;
  flex-direction: row;
  align-items: center;
  column-gap: 7px;
  margin-top: 40px;
}

section.selection .content .subcontainer .abo .abo_text {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-green-accent);
}

section.selection .content .subcontainer .abo svg {
  width: 24px;
  height: 24px;
}

section.selection .content .subcontainer .abo svg path {
  fill: var(--background-green-accent);
}

section.selection .content a {
  font-weight: 500;
}

section.selection .content .entry .team {
  display: grid;
  row-gap: 50px;
  margin-top: 40px;
}

section.selection .content .entry .team-entry {
  display: flex;
  flex-direction: row;
  align-items: center;
  column-gap: 30px;
  max-width: 65%
}

section.selection .content .entry .team-entry h5 {
  margin: 0;
  font-size: 1rem;
  font-weight: 600;
}

section.selection .content .entry .team-entry span {
  font-size: 0.875rem;
}

section.selection .content .entry .team-entry p {
  font-size: 0.813rem;
  margin-top: 10px;
}

section.selection .content .entry .team img {
  border-radius: 99px;
  width: 100px;
  height: 100px;
}

/* >>>>> hover effects <<<<< */
section.selection .tiles_small .arrows .arrow-left:hover svg path,
section.selection .tiles_small .arrows .arrow-left:focus svg path,
section.selection .tiles_small .arrows .arrow-right:hover svg path, 
section.selection .tiles_small .arrows .arrow-right:focus svg path {
  fill: var(--background-green-accent);
}

section.selection .tiles_small .entry:hover,
section.selection .tiles_small .entry:focus {
  color: var(--text-green-accent);
}

section.selection .tiles_small .entry:hover svg g path,
section.selection .tiles_small .entry:focus svg g path{
  fill: var(--background-green-accent);
}

section.selection .tiles_small .entry:hover img.active,
section.selection .tiles_small .entry:focus img.active {
  display: block;
}

section.selection .tiles_small .entry:hover img.passive,
section.selection .tiles_small .entry:focus img.passive {
  display: none;
}

section.selection .content a:hover,
section.selection .content a:focus {
  color: var(--text-green-accent);
}

/****** project overview ******/
section.project-overview {
  padding-bottom: 70px;
}

section.project-overview .header {
  padding: 40px 0 50px 0;
  display: flex;
  flex-direction: row;
  align-items: center;
  column-gap: 50px;
}

section.project-overview .headline span {
  font-family: 'Kaushan Script', serif;
  font-size: 1rem;
  color: var(--text-green-accent-alt);
}

section.project-overview h2 {
  font-size: 1.625rem;
  font-weight: bold;
  margin: 5px 0 0;
}

section.project-overview .header p {
  flex: 1;
  color: var(--text-grey-paragraph);
  font-size: 0.938rem;
  margin: 0;
  line-height: 1.8;
}

section.project-overview .projects {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(330px, 1fr));
}

section.project-overview .projects .entry {
  position: relative;
  height: 255px;
}

section.project-overview .projects a {
  overflow: hidden;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

section.project-overview .projects .overlay {
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.25);
  position: absolute;
  top: 0;
  left: 0;
}

section.project-overview .projects a img {
  object-fit: cover;
  object-position: center center;
  width: 100%;
}

section.project-overview .projects div.icon {
  position: absolute;
  opacity: 0;
  transform: translateY(-52%);
}

section.project-overview .projects div.icon svg {
  height: 40px;
  width: 40px;
}

section.project-overview .projects div.icon svg g path {
  fill: var(--background-green-accent);
}

section.project-overview .projects span {
  position: absolute;
  color: var(--text-white);
  font-weight: 500;
  max-width: 160px;
  text-align: center;
  transition: transform 150ms ease-in-out;
  text-transform: uppercase;
}

/* >>>>> hover effects <<<<< */
section.project-overview .projects a:hover span,
section.project-overview .projects a:focus span {
  transform: translateY(40px);
  transition: transform 250ms ease-in-out;
}

section.project-overview .projects a:hover div.icon,
section.project-overview .projects a:focus div.icon {
  opacity: 1;
  transition: opacity 150ms ease-in-out;
  transition-delay: 250ms;
}

/****** project detail ******/
section.project-detail {
  padding-bottom: 45px;
}

section.project-detail.last {
  padding-bottom: unset;
}

section.project-detail .header {
  padding: 40px 0 50px 0;
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  align-items: center;
  column-gap: 50px;
}

section.project-detail .headline span {
  font-family: 'Kaushan Script', serif;
  font-size: 1rem;
  color: var(--text-green-accent-alt);
}

section.project-detail h2 {
  font-size: 1.625rem;
  font-weight: bold;
  margin: 5px 0 0;
}

section.project-detail .header p {
  flex: 1;
  color: var(--text-grey-paragraph);
  font-size: 0.938rem;
  margin: 0;
  line-height: 1.8;
  min-width: 700px;
}

section.project-detail .header .additional-information {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  column-gap: 30px;
  text-transform: uppercase;
  margin-top: 30px;
  row-gap: 7px;
  min-width: 400px;
}

section.project-detail .header .additional-information .additional-information-entry {
  display: flex;
  flex-direction: row;
  column-gap: 30px;
}

section.project-detail .header .additional-information .additional-information-entry:last-child div.icon {
  display: none;
}

section.project-detail .header .additional-information span {
  font-family: 'Poppins';
  font-size: 0.813rem;
  font-weight: 600;
  color: var(--text-black);
}

section.project-detail .header .additional-information svg {
  width: 14px;
  height: 14px;
}

section.project-detail .header .additional-information svg path {
  fill: var(--background-green-shade-6);
}

section.project-detail .content .project-images {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(500px, 1fr));
}

section.project-detail .content .project-images .left,
section.project-detail .content .project-images .right {
  height: 600px;
}

section.project-detail .content .project-images .left {
  position: relative;
}

section.project-detail .content .project-images .right {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(310px, 1fr));
}

section.project-detail .content .project-images .right figure {
  height: 300px;
  position: relative;
}

section.project-detail .content .project-images img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  pointer-events: none;
}

section.project-detail .content .project-images .optional-description {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background: rgba(0, 0, 0, 0.3);
  color: var(--text-white);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  opacity: 0;
  cursor: pointer;
}

section.project-detail .optional-description .icon svg {
  width: 85px;
  height: 85px;
  opacity: 0.6;
}

section.project-detail .optional-description .icon svg g path {
  fill: var(--background-green-shade-5);
}

section.project-detail .optional-description h3 {
  margin: 30px 0 7px 0;
  padding: 0 30px;
  font-size: 1rem;
  font-weight: 500;
  text-transform: uppercase;
}

section.project-detail .optional-description p {
  margin: 0;
  font-size: 0.875rem;
  font-weight: 300;
  text-align: center;
  line-height: 1.6;
}

section.project-detail .right .optional-description .icon svg {
  width: 70px;
  height: 70px;
}

section.project-detail .right .optional-description h3 {
  margin-top: 15px;
}

section.project-detail .right .optional-description p {
  line-height: 1.4;
  padding: 0 30px;
}

/* >>>>> hover effects <<<<< */
section.project-detail .content .project-images .optional-description:hover,
section.project-detail .content .project-images .optional-description:focus {
  opacity: 1;
  transition: opacity 100ms ease-in-out;
}

/****** legalities ******/
section.legalities {
  padding: 60px 0 70px;
}

section.legalities .content {
  display: grid;
  row-gap: 50px;
}

section.legalities h2 {
  margin: 0 0 20px 0;
}

section.legalities p {
  margin: 0;
  font-size: 0.938rem;
  line-height: 1.8;
  color: var(--text-grey-paragraph);
}

/****** footer ******/
section.footer-section {
  background-color: var(--background-green-contrast-alt);
  color: var(--text-white);
  display: grid;
  align-items: center;
  height: 345px;
  /*
  padding: 70px 0;
  */
}

section.footer-section .subcontainer {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
}

section.footer-section .left-side,
section.footer-section .right-side {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

section.footer-section .right-side {
  align-items: end;
}

section.footer-section .left-side .address h2 {
  font-size: 1rem;
  font-weight: 600;
  margin: 0;
  margin-bottom: 2px;
}

section.footer-section .left-side .address_content {
  display: flex;
  flex-direction: row;
  align-items: center;
  column-gap: 20px;
  font-size: 0.938rem;
}

section.footer-section .left-side .address_content svg {
  width: 14px;
  height: 14px;
}

section.footer-section .left-side .address_content svg g path {
  fill: var(--background-green-shade-4);
}

section.footer-section .left-side .links {
  display: flex;
  flex-direction: row;
  align-items: center;
  column-gap: 25px;
}

section.footer-section .left-side .links > a {
  display: flex;
  flex-direction: row;
  align-items: center;
  column-gap: 10px;
  font-size: 0.938rem;
}

section.footer-section .left-side .links > a div.icon {
  display: flex;
  flex-direction: unset;
  align-items: center;
  justify-content: center;
  border-radius: 99px;
  padding: 5px;
  border: 1px solid var(--border-green-accent);
}

section.footer-section .left-side .links > a svg {
  width: 14px;
  height: 14px;
}

section.footer-section .left-side .links > a svg g path {
  fill: var(--background-white);
}

section.footer-section nav ul {
  display: flex;
  flex-direction: row;
  align-items: center;
  column-gap: 40px;
  margin: 35px 0 10px 0;
}

section.footer-section nav ul a {
  display: flex;
  flex-direction: row;
  column-gap: 5px;
  font-size: 0.813rem;
  font-weight: 600;
  color: var(--text-white);
}

section.footer-section nav ul a[data-nav-active="true"] {
  color: var(--text-green-accent);
}

section.footer-section div.nav-icon {
  display: grid;
  align-items: center;
}

section.footer-section nav ul a svg {
  opacity: 0;
  display: none;
  width: 13px;
  height: 13px;
}

section.footer-section nav ul a[data-nav-active="true"] svg {
  display: block;
  opacity: 1;
}

section.footer-section nav ul a svg g path#leaf_icon {
  fill: var(--background-green-accent);
}

section.footer-section .right-side .logo img {
  width: 190px;
}

section.footer-section .right-side .legalities {
  display: flex;
  flex-direction: row;
  align-items: center;
  column-gap: 20px;
  font-size: 0.813rem;
  font-weight: 500;
  margin: 25px 0 10px;
}

section.footer-section .right-side .legalities a[data-nav-active="true"] {
  color: var(--text-green-accent);
}

section.footer-section .right-side .copyright {
  font-size: 0.813rem;
  color: var(--text-grey);
}

section.footer-section .right-side .powered-by {
  display: flex;
  flex-direction: row;
  align-items: center;
  color: var(--text-green-accent);
  font-size: 0.813rem;
  font-weight: normal;
  column-gap: 4px;
  margin-top: 20px;
}

section.footer-section .right-side .powered-by div.icon {
  display: grid;
}

section.footer-section .right-side .powered-by svg {
  width: 14px;
  height: 14px;
}

section.footer-section .right-side .powered-by svg g path {
  fill: var(--background-green-accent);
}

/* >>>>> hover effects <<<<< */
section.footer-section nav ul a:hover,
section.footer-section nav ul a:focus {
  color: var(--text-green-accent);
}

section.footer-section .right-side .legalities a:hover,
section.footer-section .right-side .legalities a:focus {
  color: var(--text-green-accent);
}

section.footer-section .left-side .links > a:hover,
section.footer-section .left-side .links > a:focus {
  color: var(--text-green-accent);
}

section.footer-section .left-side .links > a:hover svg g path,
section.footer-section .left-side .links > a:focus svg g path {
  fill: var(--background-green-accent);
}


/* CUSTOM end */

/* RESPONSIVENESS start */
/****** container ******/
@media screen and (min-width: 1px) {
  .container {
    max-width: var(--container-mobile-s);
  }
  .container.switch {
    max-width: unset;
  }
}

@media screen and (min-width: 375px) {
  .container {
    max-width: var(--container-mobile-s);
  }
  .container.switch {
    max-width: unset;
  }
}

@media screen and (min-width: 576px) {
  .container {
    max-width: var(--container-mobile-m);
  }
  .container.switch {
    max-width: unset;
  }
}
@media screen and (min-width: 768px) {
  .container {
    max-width: var(--container-mobile-l);
  }
  .container.switch {
    max-width: unset;
  }
}
@media screen and (min-width: 992px) {
  .container {
    max-width: var(--container-tablet);
  }
  .container.switch {
    max-width: unset;
  }
}
@media screen and (min-width: 1200px) {
  .container {
    max-width: var(--container-desktop-s);
  }
  .container.switch {
    max-width: unset;
  }
}
@media screen and (min-width: 1400px) {
  .container {
    max-width: var(--container-desktop-m);
  }
  .container.switch {
    max-width: unset;
  }
}
@media screen and (min-width: 1600px) {
  .container {
    max-width: var(--container-desktop-m);
  }
}
/*
@media screen and (min-width: 1800px) {
.container {
max-width: 1680px;
}
}
@media screen and (min-width: 2000px) {
.container {
max-width: 1860px;
}
}
*/

/* tablet */
@media screen and (max-width: 992px) {

  /****** banner carousel ******/
  section.header-section .logo img {
    width: 120px;
  }

  section.header-section nav ul {
    column-gap: 24px;
  }

  section.header-section .contact a .contact-text:not(.contact.burger a .contact-text) {
    display: none;
  }

  /****** banner carousel ******/
  section.slideshow {
    height: 450px;
  }

  /*
  section.slideshow .slideshow__overlay {
  height: 100%;
  left: 0;
  top: 0;
  transform: rotate(0);
  background-color: rgba(0, 0, 0, 0.6);
}
  */

  section.slideshow button,
  section.slideshow button svg {
    width: 40px;
    height: 40px;
  }

  section.slideshow button.slide_left {
    left: 1.5%;
  }

  section.slideshow button.slide_right {
    right: 1.5%;
  }

  section.slideshow .slideshow__content {
    margin-left: 40px;
    max-width: 65%;
  }

  section.slideshow .slideshow__content__title {
    line-height: 1.2;
    font-size: 1.875rem;
    margin-top: 7px;
  }

  section.slideshow .slideshow__content p {
    font-size: 0.875rem;
  }

  .slideshow__content__cta {
    margin-top: 22px;
  }

  /****** banner standard ******/
  section.banner-standard .content {
    max-width: 80%;
  }

  section.banner-standard .content h1 {
    line-height: 1.2;
    font-size: 1.875rem;
    margin-top: 7px;
    max-width: unset;
  }

  section.banner-standard .content p {
    font-size: 0.875rem;
    max-width: unset;
  }

  /****** offer overview ******/ 
  section.offer_overview .header {
    flex-direction: column;
    align-items: start;
    row-gap: 12px;
  }

  section.offer_overview .offering {
    margin-top: 35px;
    row-gap: 25px;
    grid-template-columns: 1fr;
  }

  /****** testimonial ******/
  section.testimonial .subcontainer {
    display: block;
  }

  section.testimonial .subcontainer figure {
    display: inline-flex;
  }

  section.testimonial .subcontainer figure img {
    width: 65px;
    height: 65px;
  }

  section.testimonial .subcontainer .headline {
    display: inline-block;
    transform: translate(18px, -9px);
  }

  section.testimonial .subcontainer .headline h2 {
    margin: 0;
  }

  section.testimonial .testimonial_text p {
    margin-top: 5px;
  }

  /****** selection ******/
  section.selection .header .subcontainer {
    flex-direction: column;
    align-items: start;
    row-gap: 12px;
  }

  section.selection .content .subcontainer {
    min-height: 210px;
  }

  section.selection .tiles_small .entry img {
    margin-bottom: unset;
  }

  section.selection .tiles_small .entry h3 {
    display: none;
  }

  section.selection .tiles_small .entry span {
    display: none;
  }

  section.selection .content p:not(section.selection .content .entry .team-entry p) {
    max-width: 80%;
  }

  section.selection .content img:not(.team-entry img) {
    width: 90px;
    height: 90px;
  }

  section.selection .content .additional-information {
    column-gap: 15px;
  }

  section.selection .content .additional-information .additional-information-entry {
    column-gap: 15px;
  }

  /****** projects overview ******/
  section.project-overview .header {
    flex-direction: column;
    align-items: start;
    row-gap: 12px;
  }

  /****** projects detail ******/
  section.project-detail .header {
    flex-direction: column;
    align-items: start;
    row-gap: 12px;
  }

  section.project-detail .header .additional-information {
    margin-top: 15px;
    column-gap: 15px;
    min-width: unset;
  }


  section.project-detail .header .additional-information .additional-information-entry {
    column-gap: 15px;
  }

  section.project-detail .content .project-images .right {
    grid-template-columns: 1fr 1fr;
    height: unset;
  }

  section.project-detail .content .project-images .right figure {
    height: 400px;
  }

  section.project-detail .header p {
    min-width: unset;
  }

  /****** footer ******/
  #content-wrap {
    padding-bottom: 390px;
  }

  #footer {
    height: 390px;
  }

  section.footer-section {
    height: 390px;
  }

  section.footer-section .subcontainer {
    flex-direction: column;
    position: relative;
  }

  section.footer-section .right-side {
    align-items: start;
    margin-top: 20px;
  }

  section.footer-section .right-side .logo {
    position: absolute;
    right: 0;
    bottom: 0;
  }

  section.footer-section nav ul {
    margin-top: 21px;
  }

  section.footer-section .left-side .links {
    margin-top: 19px;
  }

}

/* smartphone */
@media screen and (max-width: 768px) {

  /****** header / navigation ******/
  section.header-section nav.main,
  section.header-section .contact.main {
    display: none;
  }

  section.header-section div.burger-menu {
    display: flex;
  }

  /****** banner carousel ******/
  section.slideshow .slideshow__content__title {
    line-height: 1.2;
  }

  section.slideshow .slideshow__content__title {
    font-size: 1.75rem;
    max-width: 425px;
  }

  section.slideshow .slideshow__content p {
    font-size: 0.875rem;
    max-width: 425px;
  }

  /****** banner standard ******/
  section.banner-standard .content h1 {
    font-size: 1.75rem;
  }

  /****** offer overview ******/
  section.offer_overview h2 {
    font-size: 1.438rem;
  }

  section.offer_overview .offering .entry {
    padding: 30px;
  }

  section.offer_overview .offering .entry p {
    margin-bottom: 55px;
  }	

  section.offer_overview .offering .entry svg {
    width: 60%;
    height: 60%;
  }

  /****** testimonial ******/
  section.testimonial .headline h2 {
    font-size: 1.438rem;
  }

  section.testimonial .subcontainer .headline {
    transform: translate(18px, -13px);
  }

  section.testimonial .testimonial_text p {
    font-size: 1rem;
    line-height: 1.6;
  }

  /****** cta ******/
  section.cta h2 {
    font-size: 1.438rem;
  }

  section.cta p {
    margin: 15px 0 30px;
    line-height: 1.6;
    font-size: 0.938rem;
  }

  /****** selection ******/ 
  section.selection .content .subcontainer {
    padding: 45px 0;
  }

  section.selection .tiles_small .entry img {
    width: 55%;
    height: 55%;
    max-width: 45px;
    max-height: 45px;
  }

  section.selection .tiles_small[data-aspect-ratio="landscape"] .entry img {
    width: 45px;
    height: 45px;
  }

  section.selection .content img:not(.team-entry img) {
    display: none;
  }

  section.selection .content p:not(section.selection .content .entry .team-entry p) {
    max-width: unset;
  }

  section.selection .content .additional-information {
    max-width: unset;
  }

  section.selection .tiles_small[data-aspect-ratio="landscape"] .entry {
    padding: unset;
    aspect-ratio: 1;
  }
  section.selection .content h4 {
    margin-bottom: 20px;
  }

  section.selection .content p {
    line-height: 1.8;
  }

  section.selection .content .entry .team-entry {
    max-width: unset;
  }

  /****** projects overview ******/
  section.project-overview h2 {
    font-size: 1.438rem;
  }

  /****** projects detail ******/
  section.project-detail .content .project-images .right {
    grid-template-columns: 1fr 1fr;
  }

  section.project-detail .content .project-images .left {
    height: 450px;
  }

  section.project-detail .content .project-images .right figure {
    aspect-ratio: 1;
    width: 100%;
    height: unset;
    display: flex;
  }

  /****** legalities *****/
  section.legalities {
    padding: 40px 0 40px;
  }

  section.legalities h2 {
    font-size: 1.313rem;
  }

  section.legalities .content {
    row-gap: 40px;
  }

  /****** footer ******/
  section.footer-section .left-side .address h2 {
    font-size: 0.938rem;
  }

  section.footer-section .left-side .address_content {
    font-size: 0.75rem;
  }

  section.footer-section .left-side .links > a {
    font-size: 0.813rem;
  }

  section.footer-section .right-side {
    margin-top: 10px;
  }

  section.footer-section .right-side .logo img {
    width: 140px;
  }

}

@media screen and (max-width: 576px) {
  /****** navigation / header ******/
  section.header-section div.burger-dropdown ul a {
    font-size: 1rem;
  }

  section.header-section div.burger-dropdown ul a .nav-icon svg {
    width: 16px;
    height: 16px;
  }

  /****** banner carousel ******/
  section.slideshow .slideshow__content {
    margin-left: 0;
    top: 46%;
  }

  section.slideshow .slideshow__content {
    padding-right: 22px;
    max-width: unset;
  }

  section.slideshow .slideshow__content__title {
    font-size: 1.313rem;
    line-height: 1.3;
    max-width: unset;
  }

  section.slideshow .slideshow__content p {
    font-size: 0.875rem;
    max-width: unset;
  }

  section.slideshow button, 
  section.slideshow button svg {
    width: 40px; 
    height: 40px;
  }

  section.slideshow button {
    top: 87%;
  }

  section.slideshow button.slide_left {
    left: 7%;
  }

  section.slideshow button.slide_right {
    right: 7%;
  }

  .slideshow__content__cta {
    margin-top: 12px;
  }

  /****** banner standard *******/ 
  section.banner-standard .content {
    max-width: unset;
  }

  section.banner-standard .content h1 {
    font-size: 1.625rem;
    line-height: 1.3;
    max-width: unset;
  }

  section.banner-standard .content p {
    font-size: 0.875rem;
  }

  /****** offer overview ******/
  section.offer_overview .offering .entry h3 {
    margin-bottom: 25px;
  }

  section.offer_overview .offering .entry p {
    margin-bottom: 35px;
  }

  /****** testimonial ******/ 
  section.testimonial {
    padding-bottom: 55px;
  }

  section.testimonial .subcontainer figure {
    display: block;
  }

  section.testimonial .subcontainer .headline {
    transform: unset;
    margin: 9px 0 3px 0;
  }

  /****** cta ******/ 
  section.cta {
    height: 330px;
  }

  section.cta p {
    font-size: 0.875rem;
  }

  /****** selection ******/ 
  section.selection .header {
    padding: 35px 0;
  }

  section.selection h2 {
    font-size: 1.313rem;
  }

  section.selection .content .subcontainer {
    padding: 40px 0;
    min-height: unset;
  }

  section.selection .tiles_small .entry {
    padding: unset;
  }

  section.selection .tiles_small .entry img {
    width: 32px;
    height: 32px;
    max-width: unset;
    max-height: unset;
  }

  section.selection .tiles_small[data-aspect-ratio="landscape"] .entry img {
    width: 40px;
    height: 40px;
  }

  section.selection .content h4 {
    margin-bottom: 15px;
  }

  section.selection .content .additional-information {
    column-gap: 10px;
    row-gap: 4px;
  }

  section.selection .content .additional-information .additional-information-entry {
    column-gap: 10px;
  }

  section.selection .content .entry .team-entry {
    flex-direction: column;
    align-items: start;
    row-gap: 20px;
  }

  section.selection .content .subcontainer .abo {
    margin-top: 30px;
    column-gap: 13px;
  }

  section.selection .content .subcontainer .abo svg {
    width: 40px;
    height: 40px;
  }

  /****** projects overview ******/
  section.project-overview .header {
    padding: 35px 0;
  }

  section.project-overview {
    padding-bottom: 45px;
  }

  /****** projects detail ******/
  section.project-detail .header {
    padding: 35px 0;
  }

  section.project-detail h2 {
    font-size: 1.313rem;
  }

  section.project-detail .header .additional-information {
    margin-top: 8px;
    column-gap: 10px;
    row-gap: 6px;
    flex-direction: column;
    align-items: start;
  }

  section.project-detail .header .additional-information .additional-information-entry {
    column-gap: 10px;
  }

  section.project-detail .header .additional-information svg {
    display: none;
  }

  section.project-detail .content .project-images {
    grid-template-columns: 1fr;
  }

  section.project-detail .content .project-images .left {
    height: unset;
    aspect-ratio: 1;
    display: flex;
    max-height: 450px;
    width: 100%;
  }

  section.project-detail .content .project-images .right {
    grid-template-columns: 1fr;
  }

  section.project-detail .content .project-images .right figure {
    max-height: 450px;
  }

  /****** footer ******/
  #content-wrap {
    padding-bottom: 400px;
  }

  #footer {
    height: 400px;
  }

  section.footer-section {
    height: 400px;
  }

  section.footer-section .left-side .address_content {
    flex-direction: column;
    align-items: start;
    row-gap: 1px;
  }

  section.footer-section .left-side .links {
    flex-direction: column;
    align-items: start; 	
    row-gap: 10px;
    margin-top: 23px;
  }

  section.footer-section .left-side .address_content svg {
    display: none;
  }

  section.footer-section div.navigation {
    display: none;
  }

  section.footer-section .right-side {
    margin-top: 0;
  }

  section.footer-section .right-side .logo {
    display: none;
  }

  section.footer-section .right-side .legalities {
    margin-top: 23px;
  }

}

@media screen and (max-width: 375px) {
  /****** banner carousel ******/
  section.slideshow .slideshow__content__title {
    font-size: 1.313rem;
  }

  .slideshow__content__cta {
    margin-top: 12px;
  }

  /****** banner standard ******/
  section.banner-standard .content h1 {
    font-size: 1.5rem;
  }

  /****** cta ******/
  section.cta h2 {
    font-size: 1.313rem;
  }

  /****** selection ******/
  section.selection .tiles_small .entry img {
    width: 24px;
    height: 24px;
  }

  section.selection .tiles_small[data-aspect-ratio="landscape"] .entry img {
    width: 32px;
    height: 32px;
  }

  section.selection .content .additional-information {
    row-gap: 2px;
  }

  /****** projects overview ******/
  section.project-overview .projects {
    grid-template-columns: 1fr;
  }

  section.project-overview .projects a img {
    height: 100%;
  }

  /****** projects detail ******/
  /*
  section.project-detail .header .additional-information {
  row-gap: 2px;
}
  */

}

/* laptop & desktop */
@media screen and (min-width: 992px) {

}

@media screen and (min-width: 992px) and (max-width: 1200px) {

  /****** banner carousel ******/
  section.slideshow button.slide_left {
    left: 1.5%;
  }

  section.slideshow button.slide_right {
    right: 1.5%
  }

  section.slideshow .slideshow__content {
    margin-left: 45px;
  }

  /*
  section.slideshow .slideshow__overlay {
  left: -880px;
}
  */

  section.slideshow .slideshow__content {
    max-width: 60%;
  }

  section.slideshow .slideshow__content {
    transform: translate(250px, -45%);
  }

  section.slideshow .slideshow__content--active {
    transform: translate(0, -45%) !important;
  }

  /****** selection ******/
  section.selection .content .subcontainer {
    min-height: 210px;
  }

  section.selection .tiles_small .entry span:not(section.selection .tiles_small[data-aspect-ratio="landscape"] .entry span) {
    display: none;
  }

  section.selection .tiles_small .entry img:not(section.selection .tiles_small[data-aspect-ratio="landscape"] .entry img) {
    height: 45px;
    width: 45px;
    margin-bottom: 19px;
  }

  section.selection .content img:not(.team-entry img) {
    width: 120px;
    height: 120px;
  }

  /****** projects detail ******/ 
  section.project-detail .content .project-images .right {
    grid-template-columns: 1fr 1fr;
  }

  section.project-detail .content .project-images .left,
  section.project-detail .content .project-images .right {
    height: 500px;
  }

  section.project-detail .content .project-images .right figure {
    height: 250px;
  }

  /****** footer ******/
  section.footer-section .left-side .address_content {
    font-size: 0.875rem;
  }

  section.footer-section .left-side .links > a {
    font-size: 0.875rem;
  }

  section.footer-section .left-side .address h2 {
    margin-bottom: 3px;
  }

  section.footer-section .right-side .copyright {
    font-size: 0.75rem;
  }

  section.footer-section .right-side .powered-by {
    font-size: 0.75rem;
  }

}

@media screen and (min-width: 1200px) and (max-width: 1400px) {

  /****** banner carousel ******/
  section.slideshow button.slide_left {
    left: 1.5%;
  }

  section.slideshow button.slide_right {
    right: 1.5%;
  }

  section.slideshow .slideshow__content {
    transform: translate(250px, -45%);
  }

  section.slideshow .slideshow__content--active {
    transform: translate(0, -45%) !important;
  }

  section.slideshow .slideshow__content {
    max-width: 55%;
    margin-left: 40px;
  }

  /****** selection ******/
  section.selection .content .subcontainer {
    min-height: 210px;
  }

  section.selection .tiles_small .container {
    max-width: unset;
  }

  section.selection .tiles_small .arrows {
    display: none;
  }

  section.selection .tiles_small .entry span:not(section.selection .tiles_small[data-aspect-ratio="landscape"] .entry span) {
    max-width: 100px;
  }

  section.selection .tiles_small .entry img:not(section.selection .tiles_small[data-aspect-ratio="landscape"] .entry img) {
    height: 45px;
    width: 45px;
    margin-bottom: 19px;
  }

  section.selection .content img:not(.team-entry img) {
    width: 120px;
    height: 120px;
  }

}

@media screen and (min-width: 1550px) {
  section.selection .tiles_small .arrows {
    display: block;
  }

  section.selection .tiles_small .container {
    max-width: var(--container-desktop-m);
  }
}

@media screen and (min-width: 1400px) and (max-width: 1600px) {

  /****** banner carousel ******/
  /*
  section.slideshow .slideshow__overlay {
  left: -953px;
}
  */

  section.slideshow .slideshow__content {
    margin-left: 40px;
  }

  section.slideshow button.slide_left {
    left: 1.5%;
  }

  section.slideshow button.slide_right {
    right: 1.5%;
  }

}

@media screen and (min-width: 1600px) and (max-width: 1920px) {

  /****** banner carousel ******/
  /*
  section.slideshow .slideshow__overlay {
  left: -953px;
}
  */

  section.slideshow .slideshow__content {
    margin-left: 0;
  }

  /****** projects detail ******/
  section.project-detail .content .project-images .right {
    grid-template-columns: 1fr 1fr;
  }

}

@media screen and (min-width: 1920px) and (max-width: 2500px) {

  /****** projects detail ******/
  section.project-detail .content .project-images .right {
    grid-template-columns: 1fr 1fr;
  }

}

/* RESPONSIVENESS end */

/* STYLES end */

