.believe h2 spannav #nav ul li a,
nav #nav ul li a:visited {
  color: white;
}

nav #nav ul li a,
nav #nav ul li a:visited {
  color: white;
}

main {

  h1,
  h2,
  h3,
  h4,
  h5,
  h6,
  p {
    letter-spacing: 0;
    font-family: "Montserrat";
  }
}


h1,
h2,
h3 {
  text-transform: unset;
}

main img {
  display: block;
}

main .row::before {
  display: unset;
  content: unset;
}

nav .logo-holder img.sm-type {
  filter: invert(1);
}

body.dark-mode nav.minimalized .logo-holder img.sm-type {
  filter: invert(1);
}

nav.minimalized .logo-holder img.sm-type {
  filter: invert(0);
}

body.dark-mode nav.minimalized #nav ul li a,
body.dark-mode nav.minimalized #nav ul li a:visited {
  color: white;
}

body.dark-mode .quick-ref-links {
  background-color: #0F0F0F !important;
  color: white;
}

body.dark-mode .c-form .wrap-close {
  color: white !important;
}

body.dark-mode .c-form .wrap-close:hover {
  color: #EB6608 !important;
}

body.dark-mode .c-form a {
  color: #cbcbcb;
}

body.dark-mode .socials .socials-slider-wrap {
  &::before {
    height: calc(100% - 1.5625rem);
    left: 0;
    top: 0.78125rem;
    background: linear-gradient(to right, #2F2F2F 0%, rgba(255, 255, 255, 0) 100%);
  }
}

body.dark-mode .socials .socials-slider-wrap {
  &::after {
    height: calc(100% - 2.5);
    right: 0;
    top: 0.78125rem;
    background: linear-gradient(to left, #2F2F2F 0%, rgba(255, 255, 255, 0) 100%);
  }
}

@media (max-width: 768px) {
  body .socials .socials-slider-wrap {
    &::before {
      display: none;
    }

    &::after {
      display: none;
    }
  }
}


#videotitle iframe {
  width: 100%;
  height: 100%;
  border: none;
}

body.dark-mode .c-form {
  background-color: #252525 !important;
}

body.dark-mode .c-form h3 {
  color: white !important;
}

body.dark-mode .c-form .btn {
  background-color: #EB6608 !important;
  color: white !important;
}

body.dark-mode .c-form .btn:hover {
  background-color: #000 !important;
  color: white !important;
}

#videotitle {
  z-index: 12000;
}

.case-section-tag .content.white {
  background-color: #fff;
  color: #E20516;
  font-weight: bold;
  width: fit-content !important;
  transition: all 0.5s cubic-bezier(0.25, 0.1, 0.25, 1);
}

body.dark-mode .case-section-tag .content.white {
  background-color: #E20516;
  color: #fff;
  font-weight: bold;
}

.case-section-tag .content.red {
  background-color: #E20516;
  color: #fff;
  font-weight: bold;
}

body.dark-mode .case-section-tag .content.red {
  background-color: #E20516;
  color: #fff;
  font-weight: bold;
}

.play-ico {
  display: inline-block;
  width: 1em;
  height: 1em;
  -webkit-mask-image: url('/media/cases/lion/icons/play-button.svg');
  mask-image: url('/media/cases/lion/icons/play-button.svg');
  -webkit-mask-size: contain;
  mask-size: contain;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  background-color: #E20516;
  margin-right: 5px;
  transition: transform 250ms ease;
}

body.dark-mode .play-ico {
  background-color: #fff;
}

.c-form h3 {
  font-size: 2.1875rem;
}

@media (max-width: 768px) {
  .row .col-xs-9 {
    width: 75%;
  }

  .row .col-xs-3 {
    width: 25%;
  }
}

.dark-mode .bg-white {
  background-color: #252525 !important;
}

.container-fluid {
  padding-right: 15px !important;
  padding-left: 15px !important;
  margin-right: auto !important;
  margin-left: auto !important;
}

footer:not(.footer) p {
  color: #4f4f4f !important;
}

footer .socials {
  background-color: unset;
  position: unset;
  padding-top: unset;
  padding-bottom: unset;
}

/*
html, body {
    -height: calc(var(--vh) * 100) !important;
}*/

main {
  font-family: "Montserrat", serif !important;
  height: 100% !important;
  scroll-behavior: smooth;
}

main,
section,
h1,
h2,
h3,
h4,
h5,
h6,
p,
span,
div,
li,
ul {
  transition: background-color 0.4s ease, color 0.4s ease;
}

.content-wrapper {
  overflow: hidden;
}

@media (min-width: 1400px) {
  .container {
    max-width: 1172px !important;
    width: 100%;
  }
}

@media (min-width: 1680px) {
  .container {
    max-width: 1320px !important;
    width: 100%;
  }
}

section,
.pin-spacer:has(section) {
  overflow: hidden;
}

.web_configurator,
.ar,
.visual,
.bpm-header,
.why_pwa,
.client_response {
  overflow: unset;
}

body.light-mode h1,
body.light-mode h2,
body.light-mode h3:not(.pcard-title),
body.light-mode p,
body.light-mode #profiltechnik span {
  color: #252525;
}

body.dark-mode nav.minimalized::before {
  background-color: #0F0F0F;
}

body.dark-mode body {
  background-color: #202020;
}

body.dark-mode .thats-us {
  background-color: #202020;
  color: #FFFFFF;
}

body.dark-mode section.introduction {
  background-color: #202020;
  color: #FFFFFF;
}

body.dark-mode section.introduction h2,
body.dark-mode section.introduction p,
body.dark-mode section.introduction span {
  color: #FFFFFF;
}

body.dark-mode section.logo .image-wrapper--colour img {
  width: 20rem;
}

body.dark-mode section.thats-us {
  background-color: #202020;
  color: #FFFFFF;
}

body.dark-mode section.thats-us .thats-us__content h2,
body.dark-mode section.thats-us .thats-us__content p,
body.dark-mode section.thats-us .thats-us__content span {
  color: #FFFFFF;
}

body.dark-mode section.thats-us .thats-us__content .thats-us__line path {
  stroke: #FFFFFF;
}

body.dark-mode section.thats-us .thats-us__content p {
  color: #FFFFFF;
}

body.dark-mode section.request {
  background-color: #252525;
  color: #FFFFFF;
}

body.dark-mode section.request h2,
body.dark-mode section.request button {
  color: #FFFFFF;
}

body.dark-mode section.request button {
  background-color: #E20516 !important;
}

body.dark-mode section.request button:hover {
  background-color: #b00411 !important;
}

body.dark-mode section.goals .goals__pinned {
  background-color: #202020;
}

body.dark-mode section.bpm-header {
  background-color: #505046;
  color: #FFFFFF;
}

body.dark-mode section.bpm-header h2,
body.dark-mode section.bpm-header h3,
body.dark-mode section.bpm-header p,
body.dark-mode section.bpm-header span {
  color: #FFFFFF;
}

body.dark-mode section.bpm-header ul li {
  color: #FFFFFF;
}

body.dark-mode section.visual {
  background-color: #2F2F2F;
  color: #FFFFFF;
}

body.dark-mode section.visual h2,
body.dark-mode section.visual p,
body.dark-mode section.visual span {
  color: #FFFFFF;
}

body.dark-mode section.video-into {
  background-color: #202020;
  color: #FFFFFF;
}

body.dark-mode section.logo {
  background-color: #202020;
  color: #FFFFFF;
}

body.dark-mode section.grid-gallery {
  background-color: #202020;
  color: #FFFFFF;
}

/* .gallery-container has a hard-coded white background (see .grid-gallery
   .gallery-container) that otherwise stays a white box inside the dark section. */
body.dark-mode section.grid-gallery .gallery-container {
  background: #202020;
}

.grid-gallery {
  background-color: #FFFFFF;
}

body.dark-mode section.web_configurator {
  background-color: #202020;
  color: #FFFFFF;
}

body.dark-mode section.web_configurator span,
body.dark-mode section.web_configurator h2,
body.dark-mode section.web_configurator p {
  color: #FFFFFF;
}

body.dark-mode section.socials .socials__icons .nav__button--active {
  border-bottom: 1px solid #FFFFFF;
}

body.dark-mode section.socials .socials__icons .nav__button:hover {
  border-bottom: 1px solid #FFFFFF;
}

body.dark-mode section.logo div.image-wrapper--video video {
  z-index: 0;
  width: 18rem;
}

body.dark-mode section.logo .logo__description p {
  color: #FFFFFF;
}

body.dark-mode section.why_pwa {
  background-color: #3F3F37;
  color: #FFFFFF;
}

body.dark-mode section.why_pwa h2,
body.dark-mode section.why_pwa p,
body.dark-mode section.why_pwa span {
  color: #FFFFFF;
}

body.dark-mode section.why_pwa ul li {
  color: #FFFFFF !important;
}

body.dark-mode section.socials {
  background-color: #252525;
}

body.dark-mode section.socials div.stat-number,
body.dark-mode section.socials p.stat-text {
  color: #FFFFFF !important;
}

body.dark-mode section.socials .socials__icons h2,
body.dark-mode section.socials .socials__icons h3,
body.dark-mode section.socials .socials__icons p,
body.dark-mode section.socials .socials__icons span {
  color: #FFFFFF;
}

body.dark-mode section.socials .socials__statistics,
body.dark-mode section.socials .socials__header {
  color: #FFFFFF;
}

body.dark-mode section.socials .socials__statistics h2,
body.dark-mode section.socials .socials__statistics h3,
body.dark-mode section.socials .socials__statistics p,
body.dark-mode section.socials .socials__statistics span,
body.dark-mode section.socials .socials__header h2,
body.dark-mode section.socials .socials__header h3,
body.dark-mode section.socials .socials__header p,
body.dark-mode section.socials .socials__header span {
  color: #FFFFFF;
}

body.dark-mode section.believe {
  background-color: #0F0F0F;
  color: #FFFFFF;
}

body.dark-mode section.believe h2,
body.dark-mode section.believe h3,
body.dark-mode section.believe p,
body.dark-mode section.believe span {
  color: #FFFFFF;
}

@media (max-width: 768px) {
  body.dark-mode section.visual .image-wrapper {
    background-color: #2F2F2F;
  }

  body.dark-mode section.visual div.col-lg-6:has(.content) {
    background-color: #202020;
    color: #FFFFFF;
  }

  body.dark-mode section.visual .content {
    background-color: #202020;
  }

  body.dark-mode section.visual .content h2,
  body.dark-mode section.visual .content p,
  body.dark-mode section.visual .content span {
    color: #FFFFFF;
  }
}

.hero {
  top: 0;
  left: 0;
  width: 100%;
  height: calc(var(--vh, 1vh) * 100) !important;
  overflow: hidden;
  z-index: 2;
  position: relative;
}

.hero__video-container {
  /*position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;*/
}

.hero__video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: all 0.7s cubic-bezier(0.4, 0, 0.2, 1);
  pointer-events: auto !important;
  z-index: 1;
}

.hero__video--light {
  opacity: 1;
}

.hero__video--dark {
  opacity: 0;
}

.hero__video.fade-in {
  opacity: 1;
  pointer-events: auto;
}

.hero__video.fade-out {
  opacity: 0;
  pointer-events: none;
}

.hero__image-mobile {
  display: none;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  transition: all 0.7s cubic-bezier(0.4, 0, 0.2, 1);
  animation: slowZoom 20s ease forwards;
  z-index: 1;
  opacity: 1;
}

.hero__image-mobile--light {
  background-image: url("/media/cases/profiltechnik/images/denni-poster.webp");
}

.hero__image-mobile--dark {
  background-image: url("/media/cases/profiltechnik/images/nocni-poster.webp");
  opacity: 0;
}

.hero__content {
  /* Absolute + inset:0 makes the darkening overlay span the FULL .hero box
     (matching the absolutely-positioned hero video/image), instead of a
     relative height:100% that can fall short under the GSAP pin / --vh sizing. */
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  height: 100%;
  background: rgba(0, 0, 0, 0.36);
}

.hero__content .hero__description h1 {
  font-size: 8.625rem;
  font-weight: bold;
  text-transform: uppercase;
  color: #FFFFFF;
  margin: 0;
}

@media (max-width: 1250px) {
  .hero__content .hero__description h1 {
    font-size: 7rem;
  }
}

@media (max-width: 1024px) {
  .hero__content .hero__description h1 {
    font-size: 5.5rem;
  }
}

@media (max-width: 768px) {
  .hero__content .hero__description h1 {
    font-size: 3.5rem;
  }
}

@media (max-width: 550px) {
  .hero__content .hero__description h1 {
    font-size: 2.5rem;
  }
}

.hero__content .hero__description p {
  font-size: 1.875rem;
  color: #FFFFFF;
  margin-top: 0.5rem;
  font-weight: 300;
}

@media (max-width: 1250px) {
  .hero__content .hero__description p {
    font-size: 1.5rem;
  }
}

@media (max-width: 1024px) {
  .hero__content .hero__description p {
    font-size: 1.25rem;
  }
}

@media (max-width: 768px) {
  .hero__content .hero__description p {
    font-size: 1rem;
  }
}

@media (max-width: 768px) {
  .hero__video {
    display: none !important;
  }

  .hero__image-mobile {
    display: block;
  }
}

.hero__toggle {
  position: fixed;
  bottom: 4rem;
  height: fit-content;
  left: 50%;
  transform: translateX(-50%);
  z-index: 9999;
}

.hero__toggle label {
  margin: 0;
}

@media (max-width: 768px) {
  .hero__toggle {
    bottom: 6rem;
  }
}

.hero__toggle .toggle {
  position: relative;
  width: 5.5rem;
  height: 2rem;
  display: inline-block;
}

.hero__toggle .toggle input {
  opacity: 0;
  width: 0;
  height: 0;
}

.hero__toggle .toggle .slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(255, 255, 255, 0.36);
  border-radius: 8rem;
  transition: all 0.5s cubic-bezier(0.25, 0.1, 0.25, 1);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.25rem;
  backdrop-filter: blur(8px);
}

.hero__toggle .toggle .slider::before {
  content: "";
  position: absolute;
  width: 2.3rem;
  height: 1.65rem;
  background-color: #FFFFFF;
  border-radius: 1rem;
  transition: all 0.5s cubic-bezier(0.25, 0.1, 0.25, 1);
}

.hero__toggle .toggle .slider .toggle__icon {
  width: 1.5rem;
  height: 1.5rem;
  transition: all 0.5s cubic-bezier(0.25, 0.1, 0.25, 1);
  -webkit-mask-size: contain;
  -webkit-mask-repeat: no-repeat;
  mask-size: contain;
  mask-repeat: no-repeat;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 2;
}

.hero__toggle .toggle .slider .toggle__icon--sun {
  -webkit-mask-image: url("/media/cases/profiltechnik/images/icons/icon-toggleSun.svg");
  mask-image: url("/media/cases/profiltechnik/images/icons/icon-toggleSun.svg");
  background-color: #252525;
  position: absolute;
  left: 0.85rem;
  opacity: 1;
  width: 1.1rem;
  height: 1.1rem;
}

.hero__toggle .toggle .slider .toggle__icon--moon {
  -webkit-mask-image: url("/media/cases/profiltechnik/images/icons/icon-toggleMoon.svg");
  mask-image: url("/media/cases/profiltechnik/images/icons/icon-toggleMoon.svg");
  background-color: #FFFFFF;
  position: absolute;
  right: 0.85rem;
  width: 1rem;
  height: 1rem;
}

.hero__toggle .toggle input:checked+.slider {
  background: rgba(0, 0, 0, 0.28);
}

.hero__toggle .toggle input:checked+.slider::before {
  transform: translateX(2.6rem);
}

.hero__toggle .toggle input:checked+.slider .toggle__icon--sun {
  background-color: #FFFFFF;
  opacity: 1;
}

.hero__toggle .toggle input:checked+.slider .toggle__icon--moon {
  background-color: #252525;
  opacity: 1;
}

.hero__toggle.toggle-fixed {
  position: fixed;
  height: fit-content;
  bottom: 4rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 9999;
  transition: all 0.5s cubic-bezier(0.25, 0.1, 0.25, 1);
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.2);
  border-radius: 8rem;
}

@media (max-width: 768px) {
  .hero__toggle.toggle-fixed {
    bottom: 6rem;
  }
}

.hero__toggle.toggle-absolute {
  position: absolute;
  height: fit-content;
  left: 50%;
  transform: translateX(-50%);
  border-radius: 8rem;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.2);
  top: 0;
  z-index: 100;
  bottom: unset !important;
}

.hero__toggle.toggle-absolute .slider {
  background: rgba(0, 0, 0, 0.28) !important;
}

.hero__toggle.toggle-sticky {
  height: fit-content;
  bottom: unset !important;
  left: 50%;
  transform: translateX(-50%);
  border-radius: 8rem;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.2);
  top: 0;
  z-index: 999;
}

.hero__toggle.toggle-sticky .slider {
  background: rgba(0, 0, 0, 0.28) !important;
}

@keyframes slowZoom {
  from {
    transform: scale(1);
  }

  to {
    transform: scale(1.3);
  }
}

.zoom-stop {
  animation-play-state: paused !important;
}

.overlay-section {
  position: relative;
  z-index: 10;
  background-color: #FFFFFF;
  min-height: calc(var(--vh, 1vh) * 100) !important;
}

@media (max-width: 768px) {
  .overlay-section {
    max-height: unset;
  }
}

section.introduction {
  background-color: #FFFFFF;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 9.0625rem 0;
}

@media (max-width: 768px) {
  section.introduction {
    padding-top: 10.625rem;
    padding-bottom: 6.25rem;
  }
}

section.introduction>span {
  font-size: 0.875rem;
  text-transform: uppercase;
  margin-bottom: 1rem;
  display: block;
}

section.introduction .introduction__header {
  margin-bottom: 8.75rem;
}

section.introduction .introduction__header img {
  width: 17rem;
  height: 17rem;
  display: block;
}

@media (max-width: 768px) {
  section.introduction .introduction__header {
    margin-bottom: 4rem;
  }
}

section.introduction .introduction__header h2 {
  font-size: 3.625rem;
  color: #E20516;
  font-weight: bold;
}

@media (max-width: 768px) {
  section.introduction .introduction__header h2 {
    font-size: 2.5rem;
    margin-bottom: 0;
    position: relative;
  }
}

@media (max-width: 980px) {
  section.introduction .introduction__header img {
    z-index: -1;
  }
}

@media (max-width: 768px) {
  section.introduction .introduction__header img {
    width: 6rem;
    position: absolute;
    bottom: -1.5rem;
    right: 0.5rem;
    display: none;
  }
}

section.introduction .introduction__header div:has(img) {
  display: flex;
  justify-content: end;
}

section.introduction .introduction__content img {
  width: 15.125rem;
  height: 10.5625rem;
  object-fit: cover;
}

@media (max-width: 768px) {
  section.introduction .introduction__content img {
    display: block;
    margin: 0 auto;
    margin-top: 2rem;
  }
}

section.introduction .introduction__content p {
  font-size: 1.5rem;
  color: #252525;
  font-weight: 300;
}

@media (max-width: 768px) {
  section.introduction .introduction__content p {
    font-size: 1.25rem;
  }
}

.horizontal-scroll {
  position: relative;
  height: calc(var(--vh, 1vh) * 100) !important;
  overflow: hidden;
  z-index: 3;
}

@media (max-width: 768px) {
  .horizontal-scroll {
    height: auto !important;
    overflow: visible !important;
  }
}

.horizontal-scroll .horizontal-wrapper {
  display: flex;
  flex-wrap: nowrap;
  width: 100vw;
  height: calc(var(--vh, 1vh) * 100) !important;
}

@media (max-width: 768px) {
  .horizontal-scroll .horizontal-wrapper {
    overflow: hidden !important;
    height: calc(var(--vh, 1vh) * 91) !important;
  }
}

.horizontal-scroll .slide {
  flex: 0 0 100vw;
  height: calc(var(--vh, 1vh) * 100) !important;
  display: flex;
  width: 100vw;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: 0rem;
  position: relative;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 70% center;
  transition: all 0.5s cubic-bezier(0.25, 0.1, 0.25, 1);
  color: #FFFFFF;
}

.horizontal-scroll .slide::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: calc(var(--vh, 1vh) * 100) !important;
  background: rgba(0, 0, 0, 0.5);
}

.horizontal-scroll .slide h2 {
  font-size: 4.375rem;
  font-weight: bold;
  margin-bottom: 0;
  position: absolute;
  z-index: 3;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  max-width: 60rem;
  width: 100%;
  color: #FFFFFF;
}

@media (max-width: 768px) {
  .horizontal-scroll .slide h2 {
    font-size: 2.5rem;
    max-width: 85vw;
    top: 42%;
  }
}

.horizontal-scroll .slide h2 span {
  display: block;
  font-size: 2rem;
  font-weight: 400;
  margin-top: 0.75rem;
  color: #FFFFFF !important;
}

@media (max-width: 768px) {
  .horizontal-scroll .slide h2 span {
    font-size: 1.5rem;
    margin-top: 0.3125rem;
    line-height: 2.03125rem;
  }
}

.horizontal-scroll .slide p {
  font-size: 1rem;
  font-weight: 400;
  position: absolute;
  bottom: 6rem;
  left: 50%;
  color: #FFFFFF;
  transform: translateX(-50%);
  z-index: 3;
  text-transform: uppercase;
}

@media (max-width: 768px) {
  .horizontal-scroll .slide p {
    font-size: 0.875rem;
    width: 85vw;
    bottom: 10.625rem;
  }
}

.horizontal-scroll .slider-nav {
  position: absolute;
  bottom: 2.25rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 1rem;
}

@media (max-width: 768px) {
  .horizontal-scroll .slider-nav {
    bottom: 2.125rem;
  }
}

.horizontal-scroll .slider-nav__button {
  width: 1.563rem;
  height: 1.563rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  cursor: pointer;
  border: none;
  background-color: rgba(255, 255, 255, 0.08);
  color: #FFFFFF;
  font-size: 0.875rem;
  transition: all 0.5s cubic-bezier(0.25, 0.1, 0.25, 1);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}

.horizontal-scroll .slider-nav__button:hover {
  background-color: rgba(255, 255, 255, 0.2);
}

@media (max-width: 768px) {
  .horizontal-scroll .slider-nav__button:hover {
    background-color: #E20516;
  }
}

.horizontal-scroll .slider-nav__button--active {
  background-color: #E20516;
  color: #FFFFFF;
}

.horizontal-scroll .global-arrow-left,
.horizontal-scroll .global-arrow-right {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 40px;
  height: 40px;
  z-index: 10;
  cursor: pointer;
  user-select: none;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.08);
}

.horizontal-scroll .global-arrow-left::before,
.horizontal-scroll .global-arrow-left::after,
.horizontal-scroll .global-arrow-right::before,
.horizontal-scroll .global-arrow-right::after {
  content: "";
  position: absolute;
  background-color: #fff;
  width: 2px;
  height: 14px;
  top: 50%;
  left: 63%;
  transform-origin: center;
  transition: background-color 0.3s;
}

.horizontal-scroll .global-arrow-left:hover::before,
.horizontal-scroll .global-arrow-left:hover::after,
.horizontal-scroll .global-arrow-right:hover::before,
.horizontal-scroll .global-arrow-right:hover::after {
  background-color: #ccc;
}

.horizontal-scroll .global-arrow-left {
  left: 0.625rem;
}

.horizontal-scroll .global-arrow-left::before {
  transform: translate(-50%, -50%) rotate(45deg) translateY(-6px);
  left: 34%;
}

.horizontal-scroll .global-arrow-left::after {
  transform: translate(-50%, -50%) rotate(-45deg) translateY(6px);
  left: 34%;
}

.horizontal-scroll .global-arrow-right {
  right: 0.625rem;
}

.horizontal-scroll .global-arrow-right::before {
  transform: translate(-50%, -50%) rotate(-45deg) translateY(-6px);
  left: 63%;
}

.horizontal-scroll .global-arrow-right::after {
  transform: translate(-50%, -50%) rotate(45deg) translateY(6px);
  left: 63%;
}

.thats-us {
  position: relative;
  background-color: #FFFFFF;
  z-index: 3;
  overflow: hidden;
  height: calc(var(--vh, 1vh) * 100) !important;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  max-height: 1080px;
}

@media (max-width: 768px) {
  .thats-us {
    max-height: calc(var(--vh, 1vh) * 70) !important;

  }
}

.thats-us .thats-us__content {
  position: relative;
  transform: translateY(-70%) !important;
}

.thats-us .thats-us__content .thats-us__uppertitle {
  font-size: 3.625rem;
  font-weight: bold;
}

@media (max-width: 768px) {
  .thats-us .thats-us__content .thats-us__uppertitle {
    font-size: 2.375rem;
  }
}

.thats-us .thats-us__content h2 {
  font-size: 8rem;
  font-weight: bold;
  margin: 0;
  position: relative;
}

@media (max-width: 768px) {
  .thats-us .thats-us__content h2 {
    font-size: 3rem;
    margin-top: 0;
  }
}

.thats-us .thats-us__content .thats-us__line {
  position: absolute;
  left: 60%;
  transform: translateX(-50%);
  bottom: -15rem;
  z-index: 5;
}

@media (max-width: 768px) {
  .thats-us .thats-us__content .thats-us__line {
    width: 90px;
    height: 200px;
    left: 11%;
    bottom: -10.5rem;
  }
}

.thats-us .thats-us__content .thats-us__subtitle-container {
  display: flex;
  width: 100%;
  justify-content: end;
  flex-direction: column;
  position: absolute;
  bottom: -20rem;
}

@media (max-width: 768px) {
  .thats-us .thats-us__content .thats-us__subtitle-container {
    bottom: -10rem;
    right: 0.5rem;
  }
}

.thats-us .thats-us__content .thats-us__subtitle-container p {
  font-size: 2.5rem;
  font-weight: 400;
  opacity: 1;
  text-align: end;
  color: #252525;
  display: block;
  margin: 0;
}

@media (max-width: 768px) {
  .thats-us .thats-us__content .thats-us__subtitle-container p {
    font-size: 2.125rem;
  }
}




.goals .goals__pinned {
  position: relative;
  height: auto;
  overflow: hidden;
  z-index: 3;
}

.goals .goals__wrapper {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: calc(var(--vh, 1vh) * 100) !important;
  max-height: 100%;
  z-index: 3;
  background: url("/media/cases/profiltechnik/images/goals_background.webp") center top / cover no-repeat;
  background-size: cover;
  background-position: center top;
  background-repeat: no-repeat;
}

.goals__overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(0deg,
      rgb(17, 17, 17) 0%,
      rgba(17, 17, 17, 0.75) 34%,
      rgba(17, 17, 17, 0.32) 80%,
      rgba(17, 17, 17, 0) 100%);
  opacity: 0;
  /* Initially hidden */
  transition: opacity 0.5s ease;
  z-index: 0;
}


@media (max-width: 768px) {
  .goals .goals__wrapper {
    background: url("/media/cases/profiltechnik/images/goals_background.webp") center top / cover no-repeat;
  }
}

.goals .goals__scroll-content {
  position: relative;
  z-index: 3;
  padding: 0;
  height: 100%;
}

.goals .goals__content {
  color: #FFFFFF;
  padding-top: calc(var(--vh, 1vh) * 100) !important;
  height: 100%;
}

.goals .goals__content span {
  color: #FFFFFF;
}

.goals .goals__content h2 {
  font-size: 3.625rem;
  font-weight: bold;
  max-width: 56.25rem;
  margin: 0;
  padding-top: 2rem;
  color: #FFFFFF;
}

@media (max-width: 768px) {
  .goals .goals__content h2 {
    font-size: 2rem;
  }
}

.goals .goals__content .goals__list {
  max-width: 27.5rem;
  margin-top: 2rem;
  margin-left: auto;
}

.goals .goals__content .goals__list p {
  font-size: 1.5rem;
  font-weight: 300;
  line-height: 2.03125rem;
  color: #FFFFFF;
  margin-bottom: 2rem;
}

.goals .goals__content .goals__list p span.red {
  font-weight: bold;
  color: #E20516 !important;
}

.goals .goals__content .goals__list ul {
  list-style: none;
  padding: 2rem 0 0 0;
  margin: 0;
}

.goals .goals__content .goals__list ul li {
  position: relative;
  font-size: 1.25rem;
  font-weight: 300;
  color: #FFFFFF;
  padding-bottom: 3rem;
  line-height: 1.71875rem;
}

.goals .goals__content .goals__list ul li span.bold {
  font-weight: bold;
  color: #FFFFFF !important;
  opacity: 0.2;
}

.goals .goals__content .goals__list ul li span.red {
  display: block;
  font-size: 1rem;
  opacity: 0.2;
  font-weight: bold;
  color: #E20516 !important;
  margin-bottom: 0.5rem;
}

.goals .goals__content p {
  max-width: 34rem;
  margin-right: auto;
  font-size: 1.125rem;
  color: #FFFFFF;
  line-height: 1.5625rem;
  margin-bottom: 12rem;
  margin-top: 8rem;
}

.goals__content .word {
  display: inline-block;
  margin: 0;
  padding-bottom: 0;
  opacity: 0.2;
  transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
  color: #FFFFFF !important;
}


.video-into {
  position: relative;
  height: calc(var(--vh, 1vh) * 100) !important;
  overflow: hidden;
  z-index: 2;
  background: #FFFFFF;
}

.video-into__pin-container {
  position: absolute;
  inset: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}

.video-into__video-container {
  position: relative;
  width: 100vw;
  height: calc(var(--vh, 1vh) * 100) !important;
}

.video-into__video-container video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.video-into__side-images {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.video-into__img {
  position: absolute;
  height: 34rem;
  width: auto;
  transition: all 0.5s cubic-bezier(0.25, 0.1, 0.25, 1);
}

.video-into__img.img1 {
  top: -10rem;
  left: -56rem;
  height: 35rem;
  width: auto;
}

@media (max-height: 890px) and (min-width: 1000px) {
  .video-into__img.img1 {
    top: -13.3333333333vw;
  }
}

@media (max-height: 1050px) {
  .video-into__img.img1 {
    height: 33rem;
  }
}

@media (max-height: 825px) and (min-width: 1000px) {
  .video-into__img.img1 {
    top: -15vw;
  }
}

@media (max-width: 768px) {
  .video-into__img.img1 {
    top: -5rem;
    left: -30rem;
    height: 20rem;
  }
}

.video-into__img.img2 {
  bottom: -9rem;
  left: -66.25rem;
  height: 35rem;
  width: auto;
}

@media (max-height: 890px) and (min-width: 1000px) {
  .video-into__img.img2 {
    bottom: -12.2222222222vw;
  }
}

@media (max-height: 1050px) {
  .video-into__img.img2 {
    height: 33rem;
  }
}

@media (max-height: 825px) and (min-width: 1000px) {
  .video-into__img.img2 {
    bottom: -13.75vw;
  }
}

@media (max-width: 768px) {
  .video-into__img.img2 {
    bottom: -5rem;
    left: -35.5rem;
    height: 20rem;
  }
}

.video-into__img.img3 {
  bottom: -75vw;
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;
  height: auto;
}

@media (max-width: 768px) {
  .video-into__img.img3 {
    bottom: -85vw;
  }
}

.video-into__img.img4 {
  bottom: -9rem;
  right: -55rem;
  height: 35rem;
  width: auto;
}

@media (max-height: 1050px) {
  .video-into__img.img4 {
    height: 33rem;
  }
}

@media (max-height: 890px) and (min-width: 1000px) {
  .video-into__img.img4 {
    bottom: -12.2222222222vw;
  }
}

@media (max-height: 825px) and (min-width: 1000px) {
  .video-into__img.img4 {
    bottom: -13.75vw;
  }
}

@media (max-width: 768px) {
  .video-into__img.img4 {
    bottom: -5rem;
    right: -30rem;
    height: 20rem;
  }
}

.video-into__img.img5 {
  top: -10rem;
  right: -64rem;
  height: 35rem;
  width: auto;
}

@media (max-height: 1050px) {
  .video-into__img.img5 {
    height: 33rem;
  }
}

@media (max-height: 890px) and (min-width: 1000px) {
  .video-into__img.img5 {
    top: -13.3333333333vw;
  }
}

@media (max-height: 825px) and (min-width: 1000px) {
  .video-into__img.img5 {
    top: -15vw;
  }
}

@media (max-width: 768px) {
  .video-into__img.img5 {
    top: -5rem;
    right: -35rem;
    height: 20rem;
  }
}

.video-into__img.img6 {
  top: -59vw;
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;
  height: auto;
}

@media (max-width: 768px) {
  .video-into__img.img6 {
    top: -65vw;
  }
}

.bpm-header {
  background-color: #E8E8D9;
  padding-top: 6rem;
  padding-bottom: 5rem;
  position: relative;
}

.bpm-header span {
  margin: 0 auto;
  display: block;
  width: fit-content;
  font-size: 0.875rem;
  text-transform: uppercase;
  margin-bottom: 7rem;
  z-index: 2;
  position: relative;
}

@media (max-width: 768px) {
  .bpm-header span {
    margin-bottom: 3rem;
  }
}

.bpm-header h2 {
  font-size: 3.625rem;
  max-width: 36rem;
  font-weight: bold;
  z-index: 3;
  position: relative;
}

@media (max-width: 768px) {
  .bpm-header h2 {
    font-size: 2rem;
    margin-bottom: 4rem;
  }
}

.bpm-header img {
  position: absolute;
  top: 0;
  left: 35%;
  transform: translateX(-50%);
  width: auto;
  height: 14rem;
  opacity: 0;
  z-index: 1;
}

@media (max-width: 768px) {
  .bpm-header img {
    height: 8rem;
  }
}

.bpm-header ul {
  margin-left: auto;
  padding: 0;
  list-style: none;
  display: block;
  width: fit-content;
  position: relative;
  z-index: 2;
}

@media (max-width: 768px) {
  .bpm-header ul {
    margin-left: 2rem;
  }
}

.bpm-header ul h3 {
  font-size: 1.5rem;
  font-weight: bold;
  padding-bottom: 0.5rem;
  position: relative;
  color: #444444;
}

@media (max-width: 768px) {
  .bpm-header ul h3 {
    font-size: 1.25rem;
  }
}

.bpm-header ul h3::before {
  content: counter(list-item, decimal-leading-zero);
  display: block;
  padding-bottom: 0.5rem;
  font-size: 0.875rem;
  font-weight: bold;
  color: #E20516;
  position: absolute;
  top: -0.0625rem;
  left: -1rem;
  transform: translateX(-50%);
}

.bpm-header ul li ul {
  display: flex;
  padding-bottom: 3rem;
  flex-direction: column;
  margin-left: 0;
  gap: 0.5rem;
}

.bpm-header ul li ul li {
  font-size: 1.125rem;
  color: #252525;
}

@media (max-width: 768px) {
  .bpm-header ul li ul li {
    font-size: 1rem;
  }
}

.visual {
  background-color: #F6F6F6;
  height: auto;
  max-height: 32rem;
  position: relative;
  color: #252525;
  padding-bottom: 2.5rem;
  padding-top: 0.625rem;
}

body.en .visual {
  max-height: 35rem;
}

@media (max-width: 768px) {
  .visual {
    height: unset;
    max-height: unset;
    position: static;
    display: block;
    padding-bottom: 0;
    padding-top: 0;
  }
}

@media (max-width: 768px) {
  .visual div.col-lg-6:has(.content) {
    background-color: #F6F6F6;
  }
}

.visual div:has(img) {
  display: flex;
  justify-content: end;
  height: 100%;
  position: static !important;
}

@media (max-width: 768px) {
  .visual div:has(img) {
    margin: 0;
    padding: 0;
    max-width: unset;
    display: block;
  }
}

.visual img {
  position: absolute;
  left: 0;
  bottom: 0;
  max-width: 48rem;
  height: auto;
  display: block;
  width: 100vw;
}

@media (min-width: 1750px) {
  .visual img {
    max-width: 53rem;
  }
}

@media (max-width: 1350px) {
  .visual img {
    max-width: 40rem;
  }
}

@media (max-width: 768px) {
  .visual img {
    bottom: 0;
    width: 100%;
    position: static;
    max-width: unset;
    display: block;
  }
}

@media (max-width: 768px) {
  .visual .image-wrapper {
    background-color: #FFFFFF;
    width: 100%;
    height: auto;
    display: block;
  }
}

.visual .content {
  padding-top: 4.5rem;
  margin-left: 8.5rem;
  padding-bottom: 2rem;
}

@media (max-width: 768px) {
  .visual .content {
    margin-left: 0;
    padding-top: 3rem;
    padding-bottom: 3rem;
    background-color: #F6F6F6;
  }
}

.visual .content span {
  font-size: 0.875rem;
  text-transform: uppercase;
  font-weight: 500;
}

.visual .content h2 {
  font-size: 3.625rem;
  font-weight: bold;
  margin: 0;
  display: block;
  padding-top: 0.5rem;
  padding-bottom: 2rem;
}

@media (max-width: 1100px) {
  .visual .content h2 {
    font-size: 3rem;
  }
}

@media (max-width: 768px) {
  .visual .content h2 {
    font-size: 2rem;
  }
}

.visual .content p {
  font-size: 1.375rem;
}

@media (max-width: 768px) {
  .visual .content p {
    font-size: 1rem;
  }
}

.logo {
  padding-top: 6rem;
  padding-bottom: 5rem;
  background: #FFFFFF;
}

@media (max-width: 768px) {
  .logo {
    padding-top: 2.5rem;
    padding-bottom: 3rem;
  }
}

.logo .logo__images .image-wrapper:nth-child(1) video {
  overflow: hidden;
}

.logo .logo__images .image-wrapper img {
  margin: 0 auto;
  display: block;
  width: 100%;
  height: auto;
}

.logo .logo__images .image-wrapper--video {
  position: relative;
}

.logo .logo__images .image-wrapper--video img {
  @media (min-width: 768px) {
    margin-left: -1.25rem;
  }
}

.image-wrapper--colour img {
  @media (min-width: 768px) {
    margin-right: -1.25rem;
  }
}

@media (max-width: 768px) {
  .logo .logo__images .image-wrapper--video {
    margin-top: 3rem;
    margin-bottom: 3rem;
  }
}

@media (max-width: 768px) {
  .logo .logo__images .image-wrapper--video:nth-child(1) {
    margin-top: -3rem;
    margin-bottom: -5rem;
  }
}

.logo .logo__images .image-wrapper--video video {
  width: 37rem;
  height: auto;
  display: block;
  margin: 0 auto;
  position: absolute;
  top: 50%;
  z-index: -1;
  left: 50%;
  transform: translate(-50%, -50%);
}

@media (max-width: 768px) {
  .logo .logo__images .image-wrapper--video video {
    width: 30rem;
  }
}

.logo .logo__images .image-wrapper--layout {
  width: 17.688rem;
}

.logo .logo__images .image-wrapper--colour img {
  width: 20rem;
}

@media (max-width: 768px) {
  .logo .logo__images {
    display: flex;
    flex-direction: column;
    gap: 6rem;
    justify-content: center;
  }
}

.logo .logo__description {
  max-width: 43.5rem;
  margin: 0 auto;
  padding-top: 5rem;
  font-size: 1.25rem;
}

.logo .logo__description p {
  margin-top: 1rem;
  color: #252525;
}

@media (max-width: 768px) {
  .logo .logo__description {
    padding-top: 0.5em;
    font-size: 1rem;
  }
}

.grid-gallery {
  overflow: hidden;
}

.grid-gallery .animate-on-scroll {
  opacity: 0;
  will-change: opacity, transform;
}

.grid-gallery .from-left {
  transform: translateX(-100px);
}

.grid-gallery .from-right {
  transform: translateX(100px);
}

.grid-gallery .from-top {
  transform: translateY(-100px);
}

.grid-gallery .from-bottom {
  transform: translateY(100px);
}


.grid-gallery .gallery-container {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 3rem;
  max-width: 1920px;
  max-height: 50.813rem;
  margin: 0 auto;
  background: #FFFFFF;
}

@media screen and (max-width: 768px) {
  .grid-gallery .gallery-container {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto;
    max-height: unset;
  }
}

.grid-gallery .gallery-container .gallery-item {
  overflow: hidden;
}

.grid-gallery .gallery-container .gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.grid-gallery .gallery-container .gallery-item:nth-child(1) {
  grid-row: 1/span 2;
  grid-column: 1;
}

.grid-gallery .gallery-container .gallery-item:nth-child(2) {
  grid-row: 1;
  grid-column: 2;
}

.grid-gallery .gallery-container .gallery-item:nth-child(3) {
  grid-row: 2;
  grid-column: 2;
}

.grid-gallery .gallery-container .gallery-item:nth-child(4) {
  grid-row: 1/span 2;
  grid-column: 3;
}

@media screen and (max-width: 768px) {
  .grid-gallery .gallery-container {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto;
  }

  .grid-gallery .gallery-container .gallery-item:nth-child(1),
  .grid-gallery .gallery-container .gallery-item:nth-child(4) {
    grid-column: span 2;
    grid-row: auto;
  }

  .grid-gallery .gallery-container .gallery-item:nth-child(2),
  .grid-gallery .gallery-container .gallery-item:nth-child(3) {
    grid-column: span 1;
    grid-row: auto;
  }
}

@media screen and (max-width: 480px) {
  .grid-gallery .gallery-container {
    grid-template-columns: 1fr;
  }

  .grid-gallery .gallery-container .gallery-item {
    grid-column: 1 !important;
    grid-row: auto !important;
  }
}

.web_configurator {
  position: relative;
  background: #FFFFFF;
}

@media (max-width: 768px) {
  .web_configurator {
    overflow: hidden;
  }
}

.web_configurator .web_configurator__header {
  padding-top: 6rem;
  padding-bottom: 8rem;
}

@media (max-width: 768px) {
  .web_configurator .web_configurator__header {
    padding-top: 4rem;
    padding-bottom: 6rem;
  }
}

.web_configurator .web_configurator__header span {
  margin-right: auto;
  display: block;
  width: fit-content;
  font-size: 0.875rem;
  font-weight: 500;
  text-transform: uppercase;
  margin-bottom: 0.5rem;
}

.web_configurator .web_configurator__header h2 {
  font-size: 3.625rem;
  font-weight: bold;
  max-width: 45rem;
}

@media (max-width: 768px) {
  .web_configurator .web_configurator__header h2 {
    font-size: 2rem;
  }
}

.web_configurator .web_configurator__header p {
  max-width: 34.5rem;
  font-size: 1.375rem;
  margin-top: 2rem;
}

@media (max-width: 768px) {
  .web_configurator .web_configurator__header p {
    font-size: 1rem;
    margin-bottom: 1.25rem;
  }
}

.web_configurator .web_configurator__video-container {
  position: relative;
  overflow: hidden;
  height: calc(var(--vh, 1vh) * 100) !important;
  max-height: 51.063rem;
  background: url("/media/cases/profiltechnik/images/web_configurator_background.webp") center/cover no-repeat;
}

.web_configurator .web_configurator__video-container::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.05);
}

@media (max-width: 768px) {
  .web_configurator .web_configurator__video-container {
    max-height: 40rem;
  }
}

.web_configurator .web_configurator__video-container .video-frame {
  overflow: hidden;
  position: absolute;
  z-index: 2;
  max-width: 43.938rem;
  height: 100%;
  width: 100%;
  left: 10vw;
  bottom: 20%;
  max-height: 32.924rem;
  display: flex;
  justify-content: center;
  align-items: end;
  border-radius: 3rem;
  border: 1px solid rgba(255, 255, 255, 0.65);
  backdrop-filter: blur(8px);
}

@media (max-width: 1275px) {
  .web_configurator .web_configurator__video-container .video-frame {
    max-width: 38.493rem;
  }
}

@media (min-width: 1920px) {
  .web_configurator .web_configurator__video-container .video-frame {
    left: 15vw;
  }
}

@media (max-width: 768px) {
  .web_configurator .web_configurator__video-container .video-frame {
    width: 100%;
    max-width: 22rem;
    left: 50%;
    transform: translateX(-50%);
    height: 100%;
    max-height: 17rem;
    border-radius: 2rem;
  }
}

.web_configurator .web_configurator__video-container .video-frame .dots {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  top: 1.25rem;
  left: 2.25rem;
}

@media (max-width: 768px) {
  .web_configurator .web_configurator__video-container .video-frame .dots {
    top: 1rem;
    left: 1.5rem;
  }
}

.web_configurator .web_configurator__video-container .video-frame .dots .dot {
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  background-color: #FFFFFF;
  margin-right: 0.5rem;
}

@media (max-width: 768px) {
  .web_configurator .web_configurator__video-container .video-frame .dots .dot {
    width: 0.35rem;
    height: 0.35rem;
  }
}

.web_configurator .web_configurator__video-container .video-frame video {
  max-width: 41rem;
  width: 100%;
  max-height: 29rem;
  height: 100%;
  object-fit: cover;
  border-radius: 0 0 2rem 2rem;
  margin-bottom: 1rem;
}

@media (max-width: 1275px) {
  .web_configurator .web_configurator__video-container .video-frame video {
    max-width: 36rem;
  }
}

@media (max-width: 768px) {
  .web_configurator .web_configurator__video-container .video-frame video {
    width: 100%;
    max-width: 20rem;
    left: 1.5rem;
    height: 100%;
    max-height: 14rem;
    border-radius: 0 0 1rem 1rem;
    margin-bottom: 0.75rem;
  }
}

.web_configurator .flowing_card-wrapper {
  position: absolute;
  top: 15%;
  right: 6rem;
  height: 100%;
  max-height: 57rem;
  width: 23.878rem;
}

@media (max-width: 1300px) {
  .web_configurator .flowing_card-wrapper {
    right: 5rem;
    width: 22.878rem;
  }
}

@media (max-width: 768px) {
  .web_configurator .flowing_card-wrapper {
    right: 1rem;
    height: 100%;
    width: 15rem;
  }
}

.web_configurator .flowing_card-wrapper .flowing_card {
  position: sticky;
  top: 15%;
  background-color: #E20516;
  width: 23.75rem;
  height: 24rem;
  color: #FFFFFF;
  padding: 2.5rem;
  transition: all 0.5s cubic-bezier(0.25, 0.1, 0.25, 1);
  clip-path: polygon(0 0, calc(100% - 4rem) 0, calc(100% - 4rem) 4rem, 100% 4rem, 100% 100%, 0 100%);
}

@media (max-width: 768px) {
  .web_configurator .flowing_card-wrapper .flowing_card {
    clip-path: polygon(0 0, calc(100% - 2rem) 0, calc(100% - 2rem) 2rem, 100% 2rem, 100% 100%, 0 100%);
    top: 31%;
    padding: 1.5rem;
    width: 15rem;
    height: fit-content;
  }
}

.web_configurator .flowing_card-wrapper .flowing_card p {
  margin: 0;
  color: #FFFFFF;
  font-size: 1.125rem;
  font-weight: 400;
  max-width: 17.745rem;
}

body.en .web_configurator .flowing_card-wrapper .flowing_card p {
  margin-top: 1.5625rem;
  max-width: 16.875rem;
}

@media (max-width: 768px) {
  .web_configurator .flowing_card-wrapper .flowing_card p {
    font-size: 0.8rem;
    max-width: 13rem;
  }
}

.why_pwa {
  background-color: #E8E8D9;
  padding-top: 6rem;
  padding-bottom: 8rem;
  position: relative;
}

.why_pwa img.leaf {
  position: absolute;
  top: 0;
  right: 6%;
  transform: translateX(-50%);
  width: auto;
  height: 14rem;
  opacity: 0;
  z-index: 2;
}

@media (max-width: 768px) {
  .why_pwa img.leaf {
    height: 8rem;
    right: 25%;
  }
}

@media (max-width: 768px) {
  .why_pwa {
    padding-bottom: 4rem;
  }
}

.why_pwa .why_pwa__header {
  max-width: 34.5rem;
  width: 100%;
  margin-right: auto;
  font-size: 1.5rem;
  position: relative;
  z-index: 3;
}

@media (max-width: 768px) {
  .why_pwa .why_pwa__header {
    font-size: 1.25rem;
  }
}

.why_pwa .why_pwa__content {
  margin-top: 6rem;
  position: relative;
  z-index: 3;
}

@media (max-width: 768px) {
  .why_pwa .why_pwa__content {
    margin-top: 3rem;
  }
}

.why_pwa .why_pwa__content .why_pwa__text {
  padding-top: 0rem;
  max-width: 27.813rem;
  margin-right: auto;
  margin-left: 3rem;
}

@media (max-width: 768px) {
  .why_pwa .why_pwa__content .why_pwa__text {
    margin-left: 0.3125rem;
  }
}

.why_pwa .why_pwa__content .why_pwa__text h2 {
  font-size: 1.5rem;
  font-weight: bold;
  margin-bottom: 1.5rem;
}

.why_pwa .why_pwa__content .why_pwa__text p {
  font-size: 1.125rem;
  margin-top: 3rem;
}

@media (max-width: 768px) {
  .why_pwa .why_pwa__content .why_pwa__text p {
    font-size: 1rem;
  }
}

.why_pwa .why_pwa__content .why_pwa__text ul {
  list-style: none;
  padding: 0;
  margin: 1rem 0 0;
}

.why_pwa .why_pwa__content .why_pwa__text ul li {
  font-size: 1.25rem;
  font-weight: 300;
  padding-bottom: 1.5rem;
  position: relative;
  color: #252525;
  line-height: 1.25;
}

@media (max-width: 768px) {
  .why_pwa .why_pwa__content .why_pwa__text ul li {
    font-size: 1rem;
  }
}

.why_pwa .why_pwa__content .why_pwa__text ul li::before {
  content: counter(list-item, decimal-leading-zero);
  left: 0;
  display: block;
  padding-bottom: 0.5rem;
  font-size: 1rem;
  font-weight: bold;
  color: #E20516;
}

.why_pwa .why_pwa__content .why_pwa__images {
  display: flex;
  justify-content: start;
  align-items: center;
  gap: 2rem;
  margin-left: -12vw;
}

@media (max-width: 990px) {
  .why_pwa .why_pwa__content .why_pwa__images {
    margin-left: 0;
    margin-bottom: 2rem;
  }

  .why_pwa .why_pwa__content .why_pwa__images .images__item:nth-child(3) {
    display: none;
  }
}

.why_pwa .why_pwa__content .why_pwa__images .images__item img {
  max-width: 14.375rem;
  height: auto;
  width: 100%;
  display: block;
  margin: 0 auto;
  border: 1px solid #FFFFFF;
  box-shadow: 0 0 1rem rgba(0, 0, 0, 0.25);
  border-radius: 1rem;
}

@media (min-width: 1800px) {
  .why_pwa .why_pwa__content .why_pwa__images .images__item img {
    max-width: 16.25rem;
  }
}

.ar {
  background-color: #111111;
}

.ar .background_image {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
  background: linear-gradient(180deg, rgba(17, 17, 17, 0) 0px, rgba(17, 17, 17, 0) 85px, rgb(17, 17, 17) 100%), url("/media/cases/profiltechnik/images/ar_background.webp");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top center;
  z-index: 1;
  max-height: 41.25rem;
}

@media (max-width: 768px) {
  .ar .background_image {
    max-height: 100%;
    background: linear-gradient(180deg, rgba(17, 17, 17, 0) 0px, rgba(17, 17, 17, 0) 85px, rgb(17, 17, 17) 60%), url("/media/cases/profiltechnik/images/ar_background.webp");
    background-repeat: no-repeat;
    background-size: cover;
    background-position: top center;
  }
}

.ar .background_image .building-roof {
  position: absolute;
  z-index: 2;
  top: -10%;
  left: 56.25%;
  transform: translateX(-50%);
  width: 48%;
  height: auto;
}

@media (min-width: 2070px) {
  .ar .background_image .building-roof {
    top: -13.5%;
    left: 57.25%;
    width: 50%;
  }
}

@media (max-width: 1440px) {
  .ar .background_image .building-roof {
    top: -9%;
    left: 56.25%;
    width: 48%;
  }
}

@media (max-width: 1370px) {
  .ar .background_image .building-roof {
    top: -8%;
    left: 56.25%;
    width: 50%;
  }
}

@media (max-width: 1270px) {
  .ar .background_image .building-roof {
    top: -9%;
    left: 57.25%;
    width: 55.25%;
  }
}

@media (max-width: 768px) {
  .ar .background_image .building-roof {
    top: -14vw;
    left: 71%;
    width: 166vw;
  }
}

.ar .background_image .container {
  padding-top: 8rem;
  margin-bottom: -4rem;
}

.ar .background_image .ar__content {
  margin-left: auto;
}

.ar .background_image .ar__header {
  position: relative;
  z-index: 3;
}

.ar .background_image .ar__header h2 {
  font-size: 3.625rem;
  font-weight: bold;
  color: #FFFFFF;
  margin: 0;
  max-width: 25.938rem;
}

@media (max-width: 768px) {
  .ar .background_image .ar__header h2 {
    font-size: 2rem;
    padding-top: 4rem;
  }
}

.ar .background_image .ar__header p {
  font-size: 1.5rem;
  color: #FFFFFF;
  max-width: 26rem;
  margin-top: 2rem;
}

@media (max-width: 768px) {
  .ar .background_image .ar__header p {
    font-size: 1rem;
    margin-bottom: 2rem;
  }
}

.ar .background_image .video-frame {
  margin-top: auto;
  position: relative;
  z-index: 5;
  width: 100vw;
  max-width: 43.493rem;
  height: calc(var(--vh, 1vh) * 100) !important;
  max-height: 27.098rem;
  overflow: hidden;
  display: flex;
  justify-content: center;
  align-items: end;
  border-radius: 2.5rem;
  border: 1px solid rgba(255, 255, 255, 0.75);
  backdrop-filter: blur(10px);
}

@media (max-width: 1275px) {
  .ar .background_image .video-frame {
    max-width: 40.493rem;
  }
}

@media (min-width: 1800px) {
  .ar .background_image .video-frame {
    justify-self: end;
  }
}

@media (max-width: 768px) {
  .ar .background_image .video-frame {
    width: 100vw;
    max-width: 22rem;
    left: 50%;
    transform: translateX(-50%);
    height: calc(var(--vh, 1vh) * 100) !important;
    max-height: 14rem;
    border-radius: 2rem;
  }
}

.ar .background_image .video-frame video {
  position: absolute;
  width: 100vw;
  height: 100%;
  z-index: 5;
  object-fit: cover;
  display: block;
  max-width: 38.389rem;
  max-height: 25.613rem;
  border-radius: 2rem 0 0 2rem;
  left: 0.8rem;
  bottom: 0.75rem;
}

@media (max-width: 1275px) {
  .ar .background_image .video-frame video {
    max-width: 35.389rem;
  }
}

@media (max-width: 768px) {
  .ar .background_image .video-frame video {
    width: 100vw;
    max-width: 19rem;
    left: 50%;
    transform: translateX(-55%);
    height: calc(var(--vh, 1vh) * 100) !important;
    border-radius: 1.5rem 0 0 1.5rem;
    max-height: 12.5rem;
  }
}

.ar .background_image .video-frame::after {
  content: "";
  position: absolute;
  right: 1rem;
  top: 50%;
  transform: translateY(-50%);
  width: 2.139rem;
  height: 2.139rem;
  border: 1px solid rgba(255, 255, 255, 0.9);
  border-radius: 50%;
  background: transparent;
  box-sizing: border-box;
  z-index: 4;
}

@media (max-width: 768px) {
  .ar .background_image .video-frame::after {
    width: 1rem;
    height: 1rem;
    transform: translateX(25%);
  }
}

@media (max-width: 768px) {
  .ar .container:has(.ar__description) {
    max-height: unset;
    height: 15rem;
    margin-top: 2rem;
  }
}

.ar .ar__description {
  background-color: #111111;
  height: calc(var(--vh, 1vh) * 100);
  max-height: calc(var(--vh, 1vh) * 26);
}

.ar .ar__description p {
  font-size: 1.125rem;
  color: #FFFFFF;
  max-width: 41rem;
  margin-left: auto;
  padding-top: 2rem;
}

@media (min-width: 1800px) {
  .ar .ar__description p {
    max-width: 44rem;
  }
}

@media (max-width: 768px) {
  .ar .ar__description p {
    font-size: 1rem;
    margin: 0;
    height: 15rem;
    padding-top: 3rem;
  }
}

.house {
  position: relative;
  height: calc(var(--vh, 1vh) * 100) !important;
  max-height: calc(var(--vh, 1vh) * 100) !important;
  overflow: hidden;
  background-color: #252525;
}

@media (max-width: 768px) {
  .house {
    max-height: calc(var(--vh, 1vh) * 94) !important;
  }
}

.house {
  position: relative;
  overflow: hidden;
  height: 100vh;
}

.house__image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 120%;
  object-fit: cover;
  object-position: center top;
  will-change: transform;
  pointer-events: none;
}

.house__day {
  opacity: 1;
}

.house__night {
  opacity: 0;
}


.socials {
  background-color: #FFF0F1;
  position: relative;
  padding-top: 10rem;
  padding-bottom: 49vw;
}

@media (max-width: 1600px) {
  .socials {
    padding-bottom: 44vw;
  }
}

@media (max-width: 768px) {
  .socials {
    padding-top: 4rem;
    padding-bottom: 60vw;
  }
}

.socials .section_background {
  position: absolute;
  z-index: 1;
  bottom: 0;
  left: 0;
  width: 100vw;
  height: auto;
}

.socials .swiper {
  width: 100%;
}

.socials .swiper-wrapper {
  display: flex;
}

.socials .swiper-slide {
  width: auto !important;
  flex-shrink: 0;
}

.socials .socials__header {
  height: 100%;
  max-height: 31rem;
  position: relative;
  z-index: 2;
  margin-bottom: 10rem;
}

@media (max-width: 768px) {
  .socials .socials__header {
    margin-bottom: 5rem;
  }
}

.socials .socials__header span {
  display: block;
  font-size: 0.875rem;
  text-transform: uppercase;
  font-weight: 500;
  margin-bottom: 0.5em;
  width: fit-content;
}

@media (max-width: 768px) {
  .socials .socials__header span {
    margin-bottom: 2rem;
  }
}

.socials .socials__header h2 {
  font-size: 3.625rem;
  font-weight: bold;
  margin: 0 0 1rem 0;
  width: fit-content;
}

body.en .socials .socials__header h2 {
  max-width: 41.25rem;
}

@media (max-width: 768px) {
  .socials .socials__header h2 {
    font-size: 2rem;
  }
}

.socials .socials__header p {
  max-width: 27.75rem;
  font-size: 1.5rem;
  margin-left: auto;
  line-height: 1.4;
  width: fit-content;
  margin-top: -4rem;
}

body.en .socials .socials__header p {
  margin-top: -10rem;
}

@media (max-width: 768px) {
  .socials .socials__header p {
    font-size: 1rem;
    margin-top: unset;
  }
}

.socials .socials__icons {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: start;
  gap: 4rem;
  margin-bottom: 4rem;
}

@media (max-width: 768px) {
  .socials .socials__icons {
    gap: 2rem;
    margin-bottom: 1rem;
    justify-content: center;
  }
}

.socials .socials__icons .nav__button {
  background: none;
  border: none;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-size: 1rem;
  font-weight: bold;
  color: #252525;
  cursor: pointer;
  padding: 0;
  transition: all 0.5s cubic-bezier(0.25, 0.1, 0.25, 1);
  border-bottom: 2px solid transparent;
  padding-bottom: 0.5rem;
}

@media (max-width: 768px) {
  .socials .socials__icons .nav__button {
    font-size: 0.75rem;
    gap: 0.5rem;
  }
}

@media (max-width: 385px) {
  .socials .socials__icons .nav__button {
    font-size: 0.7rem;
    gap: 0.35rem;
  }
}

.socials .socials__icons .nav__button img {
  width: 1.625rem;
  height: 1.625rem;
}

@media (max-width: 768px) {
  .socials .socials__icons .nav__button img {
    width: 1.25rem;
    height: 1.25rem;
  }
}

@media (max-width: 385px) {
  .socials .socials__icons .nav__button img {
    width: 1.15rem;
    height: 1.15rem;
  }
}

.socials .socials__icons .nav__button:hover {
  border-bottom: 1px solid #252525;
}

.socials .socials__icons .nav__button--active {
  border-bottom: 1px solid #252525;
}

.socials .socials-slider-wrap {
  width: 100%;
  overflow: hidden;
  position: relative;
  margin-bottom: 4rem;

  &::before,
  &::after {
    content: "";
    position: absolute;
    top: 0;
    width: 100px;
    opacity: 0.75;
    height: 100%;
    pointer-events: none;
    z-index: 2;
  }

  &::before {
    height: calc(100% - 1.5625rem);
    left: 0;
    top: 0.78125rem;
    background: linear-gradient(to right,
        #fff 0%,
        rgba(255, 255, 255, 0) 100%);
  }

  &::after {
    height: calc(100% - 1.5625rem);
    right: 0;
    top: 0.78125rem;
    background: linear-gradient(to left,
        #fff 0%,
        rgba(255, 255, 255, 0) 100%);
  }
}

@media (max-width: 768px) {
  .socials .socials-slider-wrap {
    overflow: visible;
    margin-bottom: 1rem;
  }
}

.socials .socials-slider-wrap .slider-arrows {
  position: absolute;
  top: 50%;
  width: 100%;
  z-index: 3;
  display: flex;
  justify-content: space-between;
  pointer-events: none;
  max-width: 1900px;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  transition: 0.3s cubic-bezier(0.25, 0.1, 0.25, 1);
}

@media (max-width: 768px) {
  .socials .socials-slider-wrap .slider-arrows {
    display: none;
  }
}

.socials .socials-slider-wrap .slider-arrows .slider-arrow {
  width: 3.5rem;
  height: 3.5rem;
  border: none;
  cursor: pointer;
  pointer-events: auto;
  border-radius: 50%;
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.1);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(8px);
  background-color: #E20516;
}

.socials .socials-slider-wrap .slider-arrows .slider-arrow::before,
.socials .socials-slider-wrap .slider-arrows .slider-arrow::after {
  content: "";
  position: absolute;
  width: 1rem;
  height: 3px;
  background-color: #FFFFFF;
  transition: 0.2s;
  z-index: 2;
}

.socials .socials-slider-wrap .slider-arrows .slider-arrow.left {
  margin-left: 4.125rem;
}

.socials .socials-slider-wrap .slider-arrows .slider-arrow.left::before {
  transform: rotate(-45deg);
  left: 1.15rem;
  top: 1.35rem;
}

.socials .socials-slider-wrap .slider-arrows .slider-arrow.left::after {
  transform: rotate(45deg);
  left: 1.15rem;
  top: 2rem;
}

.socials .socials-slider-wrap .slider-arrows .slider-arrow.right {
  margin-right: 4.125rem;
}

.socials .socials-slider-wrap .slider-arrows .slider-arrow.right::before {
  transform: rotate(45deg);
  right: 1.15rem;
  top: 1.35rem;
}

.socials .socials-slider-wrap .slider-arrows .slider-arrow.right::after {
  transform: rotate(-45deg);
  right: 1.15rem;
  top: 2rem;
}

.socials .socials-slider-wrap .slider-arrows .slider-arrow.disabled {
  opacity: 0;
  pointer-events: none;
}

.socials .socials-slider-wrap .socials-slider {
  display: flex;
  transition: all 0.7s cubic-bezier(0.4, 0, 0.2, 1);
}

.socials .socials-slider-wrap .socials-slider .socials-slide {
  position: relative;
  width: 100%;
  flex-shrink: 0;
  overflow: hidden;
  display: flex;
  justify-content: center;
}

@media (max-width: 768px) {
  .socials .socials-slider-wrap .socials-slider .socials-slide {
    scroll-snap-align: start;
  }
}

.socials .socials-slider-wrap .socials-slider .socials-slide .socials-slide__cards {
  display: flex;
  flex-wrap: nowrap;
  gap: 0rem;
  width: max-content;
  margin: 0 auto;
}

@media (max-width: 768px) {
  .socials .socials-slider-wrap .socials-slider .socials-slide .socials-slide__cards {
    justify-content: flex-start;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scroll-padding-left: 1.25rem;
  }
}

@media (min-width: 1850px) {
  .socials .socials-slider-wrap::before {
    display: none !important;
  }

  .socials .socials-slider-wrap::after {
    display: none !important;
  }
}

.socials ::-webkit-scrollbar {
  display: none;
}

.socials .social-card {
  background: #FFFFFF;
  border: 1px solid #ddd;
  border-radius: 6px;
  margin: 1rem;
  width: auto;
  flex: 0 0 auto;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}

@media (max-width: 768px) {
  .socials .social-card {
    margin: 0.46875rem !important;
    scroll-snap-align: start;
  }
}

.socials .social-card__header {
  display: flex;
  align-items: center;
  padding: 1rem;
  border-bottom: 1px solid #eee;
  color: #252525;
}

.socials .social-card__content img {
  width: 100%;
  display: block;
}

.socials .social-card__content p {
  padding: 1rem;
  font-size: 0.95rem;
  color: #333;
}

.socials .social-card__content p .see-more {
  color: #65676b;
  cursor: pointer;
}

.socials .social-card__footer {
  display: flex;
  justify-content: space-around;
  align-items: center;
  padding: 0.5rem;
  background: #f9f9f9;
  border-top: 1px solid #eee;
  color: #252525;
}

.socials .social-card__footer span {
  font-size: 0.9rem;
  color: #666;
  cursor: pointer;
}

.socials .social-card.social-card--facebook {
  font-family: "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  background-color: #FFFFFF;
  width: 21rem;
  min-width: 21rem;
  display: block;
  border: none;
  border-radius: 0.75rem;
  height: 34.875rem;
  transition: all 0.2s ease-out;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}

/* main { p, h2, … { font-family: "Montserrat" } } (specificity 0,0,2) was
   overriding the card's intended system UI font, widening the post text past
   its fixed-height box and causing overflow. Re-assert the FB system font. */
.socials .social-card.social-card--facebook,
.socials .social-card.social-card--facebook h4,
.socials .social-card.social-card--facebook p,
.socials .social-card.social-card--facebook span {
  font-family: "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

.socials .social-card.social-card--facebook:hover {
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  transform: scale(1.01) !important;
  cursor: pointer;
}

.socials .social-card.social-card--facebook .social-card__header {
  border-bottom: none;
  padding: 0.75rem;
  display: flex;
  padding-bottom: 0.35rem;
  align-items: center;
}

.socials .social-card.social-card--facebook .social-card__header img {
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 50%;
  margin-right: 0.25rem;
}

.socials .social-card.social-card--facebook .social-card__header .social-card__header-text {
  margin-left: 0.25rem;
  display: flex;
  flex-direction: column;
  gap: -0.25rem;
}

.socials .social-card.social-card--facebook .social-card__header .social-card__header-text h4 {
  font-weight: 600;
  font-size: 0.65rem;
  margin: 0;
  color: #252525;
}

.socials .social-card.social-card--facebook .social-card__header .social-card__header-text span {
  font-size: 0.6rem;
  color: #666;
  display: flex;
  align-items: center;
  font-weight: 500;
}

.socials .social-card.social-card--facebook .social-card__header .dots {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-left: auto;
  margin-right: 0.25rem;
}

.socials .social-card.social-card--facebook .social-card__header .dots .dot {
  width: 2px;
  height: 2px;
  border-radius: 100%;
  background-color: #666;
  margin-right: 2px;
}

.socials .social-card.social-card--facebook .social-card__content {
  padding: 0;
}

.socials .social-card.social-card--facebook .social-card__content .content__text {
  padding: 0.75rem;
  padding-top: 0;
  padding-bottom: 0.25rem;
  height: 6.35rem;
}

.socials .social-card.social-card--facebook .social-card__content .content__text p {
  padding-top: 0;
  font-size: 0.6875rem;
  color: #333;
  padding: 0;
  white-space: normal;
  word-break: break-word;
  font-weight: 400;
  margin-bottom: 0.25rem;
  line-height: 0.8rem;
}

.socials .social-card.social-card--facebook .social-card__content .content__text .see-more {
  color: #252525;
  font-weight: 500;
  margin-left: 0.25rem;
}

.socials .social-card.social-card--facebook .social-card__content .fb-images {
  max-height: 20.563rem;
  overflow: hidden;
}

.socials .social-card.social-card--facebook .social-card__content .fb-images .fb-image img {
  object-fit: cover;
  object-position: bottom;
  width: 100%;
  display: block;
  margin: 0 auto;
  height: auto;
}

.socials .social-card.social-card--facebook .social-card__content .fb-images .fb-images__top img {
  max-height: 13.5rem;
  object-fit: cover;
  object-position: bottom;
  width: 100%;
  display: block;
  margin: 0 auto;
  height: auto;
}

.socials .social-card.social-card--facebook .social-card__content .fb-images .fb-images__bottom {
  display: flex;
  justify-content: space-between;
  width: 100%;
  gap: 3px;
}

.socials .social-card.social-card--facebook .social-card__content .fb-images .fb-images__bottom img {
  border-top: 3px solid #FFFFFF;
  height: auto;
  max-width: calc(50% - 0.15rem);
  object-fit: cover;
  object-position: bottom;
  max-height: 7.5rem;
  width: 100%;
  display: block;
  margin: 0 auto;
}

.socials .social-card.social-card--facebook .fb-footer {
  font-family: "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  width: 100%;
  border-top: 1px solid #ddd;
  padding-bottom: 0;
}

.socials .social-card.social-card--facebook .fb-footer .fb-actions {
  display: flex;
  justify-content: space-around;
  padding: 0.2rem 0;
  font-size: 0.65rem;
  color: #666;
  border-bottom: 1px solid #ddd;
}

.socials .social-card.social-card--facebook .fb-footer .fb-actions .fb-action {
  display: flex;
  align-items: center;
  gap: 0.15rem;
  cursor: pointer;
  border-radius: 0.5rem;
  padding: 0rem;
}

.socials .social-card.social-card--facebook .fb-footer .fb-actions .fb-action .fb-icon {
  display: inline-block;
  flex: 0 0 auto;
  width: 0.9rem;
  height: 0.9rem;
  /* Was a hot-linked Facebook CDN sprite (static.xx.fbcdn.net/…olX2yf1iinG.png)
     that 404s once FB rotates the hashed filename — self-hosted inline SVGs now. */
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

.socials .social-card.social-card--facebook .fb-footer .fb-actions .fb-action .fb-icon.fb-icon--like {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2365676b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 10v11'/%3E%3Cpath d='M15 5.88 14 10h5.83a2 2 0 0 1 1.92 2.56l-2.33 8A2 2 0 0 1 17.5 22H4a2 2 0 0 1-2-2v-8a2 2 0 0 1 2-2h2.76a2 2 0 0 0 1.79-1.11L12 2a3.13 3.13 0 0 1 3 3.88Z'/%3E%3C/svg%3E");
}

.socials .social-card.social-card--facebook .fb-footer .fb-actions .fb-action .fb-icon.fb-icon--comment {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2365676b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7.9 20A9 9 0 1 0 4 16.1L2 22Z'/%3E%3C/svg%3E");
}

.socials .social-card.social-card--facebook .fb-footer .fb-actions .fb-action .fb-icon.fb-icon--share {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2365676b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='15 17 20 12 15 7'/%3E%3Cpath d='M4 18v-2a4 4 0 0 1 4-4h12'/%3E%3C/svg%3E");
}

.socials .social-card.social-card--facebook .fb-footer .fb-actions .fb-action span {
  font-weight: 500;
}

.socials .social-card.social-card--facebook .fb-footer .comment {
  display: flex;
  width: 100%;
  padding: 0.25rem 0.35rem 0;
  align-items: center;
  gap: 0.15rem;
}

.socials .social-card.social-card--facebook .fb-footer .comment .avatar {
  width: 1.25rem;
  height: 1.25rem;
  margin-bottom: -0.15rem;
  border-radius: 50%;
}

.socials .social-card.social-card--facebook .fb-footer .comment .fb-comment-bar {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.3rem;
  margin-top: 0.25rem;
  padding-right: 0.35rem;
  background-color: #f0f2f5;
  border-radius: 0.5rem;
}

.socials .social-card.social-card--facebook .fb-footer .comment .fb-comment-bar input {
  flex: 1;
  border: none;
  background: transparent;
  font-size: 0.6rem;
  padding-left: 0.35rem;
  cursor: pointer;
}

.socials .social-card.social-card--facebook .fb-footer .comment .fb-comment-bar .comment-icons {
  display: flex;
  gap: 0.4rem;
}

.socials .social-card.social-card--facebook .fb-footer .comment .fb-comment-bar .comment-icons .comment-icon {
  width: 16px;
  height: 16px;
  scale: 0.75;
  background-image: url("https://static.xx.fbcdn.net/rsrc.php/v4/yU/r/ETqWQ46BPZV.png");
  background-repeat: no-repeat;
  background-size: auto;
  display: inline-block;
  opacity: 0.7;
  cursor: pointer;
}

.socials .social-card.social-card--facebook .fb-footer .comment .fb-comment-bar .comment-icons .comment-icon:hover {
  opacity: 1;
}

.socials .social-card.social-card--facebook .fb-footer .comment .fb-comment-bar .comment-icons .comment-icon.comment-icon--star {
  background-position: 0 -371px;
}

.socials .social-card.social-card--facebook .fb-footer .comment .fb-comment-bar .comment-icons .comment-icon.comment-icon--person {
  background-position: 0px -201px;
}

.socials .social-card.social-card--facebook .fb-footer .comment .fb-comment-bar .comment-icons .comment-icon.comment-icon--emoji {
  background-position: 0 -269px;
}

.socials .social-card.social-card--facebook .fb-footer .comment .fb-comment-bar .comment-icons .comment-icon.comment-icon--camera {
  background-position: 0 -235px;
}

.socials .social-card.social-card--facebook .fb-footer .comment .fb-comment-bar .comment-icons .comment-icon.comment-icon--gif {
  background-position: 0 -286px;
}

.socials .social-card.social-card--facebook .fb-footer .comment .fb-comment-bar .comment-icons .comment-icon.comment-icon--sticker {
  background-position: 0 -388px;
}

.socials .social-card.social-card--instagram {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  background-color: #fff;
  width: 21rem;
  min-width: 21rem;
  border-radius: 0.75rem;
  display: block;
  border: none;
  margin: 0 auto;
  margin: 1rem;
  height: 34.15rem;
  transition: all 0.2s ease-out;
}

.socials .social-card.social-card--instagram:hover {
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
  cursor: pointer;
  transform: scale(1.01) !important;
}

.socials .social-card.social-card--instagram .insta-card__header {
  display: flex;
  align-items: center;
  padding: 0.65rem 0.75rem;
}

.socials .social-card.social-card--instagram .insta-card__header .profile-image {
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  object-fit: cover;
  margin-right: 0.75rem;
}

.socials .social-card.social-card--instagram .insta-card__header .insta-card__header-text {
  display: flex;
  flex-direction: column;
}

.socials .social-card.social-card--instagram .insta-card__header .insta-card__header-text h4 {
  font-size: 0.85rem;
  font-weight: 600;
  margin: 0;
  color: #252525;
}

.socials .social-card.social-card--instagram .insta-card__header .insta-card__header-text span {
  font-size: 0.75rem;
  color: #8e8e8e;
}

.socials .social-card.social-card--instagram .insta-card__header .dots {
  margin-left: auto;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.socials .social-card.social-card--instagram .insta-card__header .dots .dot {
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background-color: #262626;
  margin-left: 3px;
  margin-right: 0.25rem;
}

.socials .social-card.social-card--instagram .insta-card__content {
  position: relative;
}

.socials .social-card.social-card--instagram .insta-card__content .insta-card__image-container {
  position: relative;
  width: 100%;
}

.socials .social-card.social-card--instagram .insta-card__content .insta-card__image-container img {
  width: 100%;
  display: block;
  height: 22.75rem;
  object-fit: cover;
}

.socials .social-card.social-card--instagram .insta-card__content .insta-card__image-container .multi-post-overlay {
  position: absolute;
  top: 0;
  right: 0;
  display: flex;
  width: 100%;
  height: 100%;
  flex-direction: column;
  align-items: flex-end;
  margin: 0.5rem;
}

.socials .social-card.social-card--instagram .insta-card__content .insta-card__image-container .multi-post-overlay .image-count {
  background-color: rgba(0, 0, 0, 0.6);
  color: #fff;
  padding: 0.25rem 0.4rem;
  font-size: 0.65rem;
  border-radius: 0.75rem;
  margin-bottom: 0.35rem;
  margin-right: 0.35rem;
  margin-top: 0.35rem;
}

.socials .social-card.social-card--instagram .insta-card__content .insta-card__image-container .multi-post-overlay .slider-indicator {
  display: flex;
  gap: 0.15rem;
  position: absolute;
  bottom: -0.75rem;
  left: 50%;
  transform: translateX(-50%);
}

.socials .social-card.social-card--instagram .insta-card__content .insta-card__image-container .multi-post-overlay .slider-indicator .slider-indicator__dot {
  width: 0.4rem;
  height: 0.4rem;
  border-radius: 50%;
  background-color: #666;
  opacity: 0.2;
}

.socials .social-card.social-card--instagram .insta-card__content .insta-card__image-container .multi-post-overlay .slider-indicator .slider-indicator__dot--active {
  background-color: rgba(66, 150, 255, 0.9);
  opacity: 1;
}

.socials .social-card.social-card--instagram .insta-card__footer {
  padding: 0 0.75rem 0.75rem 0.75rem;
}

.socials .social-card.social-card--instagram .insta-card__footer .insta-card__actions {
  display: flex;
  align-items: center;
  padding-top: 0.5rem;
  padding-bottom: 0.3rem;
}

.socials .social-card.social-card--instagram .insta-card__footer .insta-card__actions .action {
  width: 24px;
  height: 24px;
  scale: 0.9;
  background-repeat: no-repeat;
  background-size: auto;
  background-position: center;
  margin-right: 0.75rem;
  opacity: 0.85;
  transition: all 0.2s ease-out;
  color: #4f4f4f;
}

.socials .social-card.social-card--instagram .insta-card__footer .insta-card__actions .action:hover {
  opacity: 1;
}

.socials .social-card.social-card--instagram .insta-card__footer .insta-card__actions .action.action--save {
  background-image: url("#");
  margin-right: 0;
}

.socials .social-card.social-card--instagram .insta-card__footer .insta-card__actions .action-space {
  flex: 1;
}

.socials .social-card.social-card--instagram .insta-card__footer .insta-card__likes {
  font-size: 0.85rem;
  font-weight: 600;
  margin-bottom: 0rem;
  margin-top: 0.2rem;
  /* Light card in both modes — keep text dark so it stays visible in dark mode. */
  color: #262626;
}

.socials .social-card.social-card--instagram .insta-card__footer .insta-card__caption {
  font-size: 0.8rem;
  margin-bottom: 0.25rem;
}

.socials .social-card.social-card--instagram .insta-card__footer .insta-card__caption .username {
  font-weight: 600;
  margin-right: 0.1rem;
  /* Light card in both modes — was inheriting white in dark mode (invisible). */
  color: #262626;
}

.socials .social-card.social-card--instagram .insta-card__footer .insta-card__caption .caption-text {
  color: #262626;
  font-weight: 400;
}

.socials .social-card.social-card--instagram .insta-card__footer .insta-card__caption .caption-text span {
  color: #8e8e8e;
  font-weight: 400;
  margin-left: 0.2rem;
}

.socials .social-card.social-card--instagram .insta-card__footer .insta-card__date {
  margin-top: -0.25rem;
}

.socials .social-card.social-card--instagram .insta-card__footer .insta-card__date span {
  color: #8e8e8e;
  font-weight: 400;
  font-size: 0.7rem;
  letter-spacing: 0.25px;
}

.socials .social-card.social-card--pinterest {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  position: relative;
  background-color: #fff;
  width: 18rem;
  min-width: 18rem;
  border-radius: 0.75rem;
  display: block;
  border: none;
  margin: 1rem;
  height: 34.15rem;
  overflow: hidden;
  transition: all 0.2s ease-out;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}

.socials .social-card.social-card--pinterest:hover {
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
  cursor: pointer;
  transform: scale(1.01) !important;
}

.socials .social-card.social-card--pinterest .pin-image {
  position: relative;
  width: 100%;
  overflow: hidden;
}

.socials .social-card.social-card--pinterest .pin-image img {
  width: 100%;
  display: block;
  height: 26rem;
  object-fit: cover;
  object-position: top;
  border-radius: 1.25rem;
  padding: 0.35rem;
}

.socials .social-card.social-card--pinterest .pin-image .pin-tools {
  position: absolute;
  right: 0.75rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  bottom: 1.5rem;
}

.socials .social-card.social-card--pinterest .pin-image .pin-tools .pin-icon {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background-color: #eaeeed;
  opacity: 1;
  display: inline-block;
  background-repeat: no-repeat;
  background-position: center;
}

.socials .social-card.social-card--pinterest .pin-image .pin-tools .pin-icon--search {
  background-image: url("/media/cases/profiltechnik/images/icons/pinterest-search-icon.png");
  background-size: 0.9rem;
}

.socials .social-card.social-card--pinterest .pin-image .pin-tools .pin-icon--crop {
  background-image: url("/media/cases/profiltechnik/images/icons/pinterest-cut-icon.png");
  background-size: 0.85rem;
}

.socials .social-card.social-card--pinterest .pin-info {
  padding: 0.15rem 0.75rem 0.75rem 0.75rem;
}

.socials .social-card.social-card--pinterest .pin-info .pin-actions {
  display: flex;
  align-items: center;
  margin-bottom: 0.5rem;
  gap: 0.35rem;
}

.socials .social-card.social-card--pinterest .pin-info .pin-actions .pin-action {
  width: 20px;
  height: 20px;
  margin-right: 1rem;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

.socials .social-card.social-card--pinterest .pin-info .pin-actions .pin-action--heart {
  background-image: url("https://s.pinimg.com/webapp/reactionHeartOutline-24ab75a6.svg");
  background-size: contain;
}

.socials .social-card.social-card--pinterest .pin-info .pin-actions .pin-action--comment {
  background-image: url("/media/cases/profiltechnik/images/icons/pinterest-comment-icon.png");
  background-size: contain;
  scale: 0.9;
}

.socials .social-card.social-card--pinterest .pin-info .pin-actions .pin-action--share {
  background-image: url("/media/cases/profiltechnik/images/icons/pinterest-share-icon.png");
  scale: 0.9;
}

.socials .social-card.social-card--pinterest .pin-info .pin-actions .pin-action--dots {
  display: flex;
  gap: 1px;
  align-items: center;
}

.socials .social-card.social-card--pinterest .pin-info .pin-actions .pin-action--dots .dot {
  width: 4px;
  height: 4px;
  border-radius: 10rem;
  background-color: #252525;
  margin-right: 2px;
}

.socials .social-card.social-card--pinterest .pin-info .pin-actions .pin-save {
  background-color: #e60023;
  color: #fff;
  border: none;
  border-radius: 1.5rem;
  padding: 0.4rem 0.9rem;
  font-size: 0.85rem;
  font-weight: 600;
  cursor: pointer;
  margin-left: auto;
  transition: all 0.2s ease-out;
}

.socials .social-card.social-card--pinterest .pin-info .user {
  display: flex;
  align-items: center;
  gap: 0;
  margin-bottom: 0.25rem;
}

.socials .social-card.social-card--pinterest .pin-info .user img {
  width: 1.15rem;
  height: 1.15rem;
  border-radius: 50%;
  margin-right: 0.5rem;
}

.socials .social-card.social-card--pinterest .pin-info .user h4 {
  font-size: 0.85rem;
  font-weight: 600;
  margin: 0;
  color: #252525;
  margin-top: -3.5px;
}

.socials .social-card.social-card--pinterest .pin-info .pin-title {
  font-size: 1rem;
  font-weight: 600;
  margin: 0 0 0.4rem 0;
  color: #252525;
  line-height: 1.2;
  margin-top: 0.35rem;
}

.socials .social-card.social-card--pinterest .pin-info .pin-desc {
  position: relative;
  color: #252525;
  line-height: 1.4;
  white-space: nowrap;
  font-weight: 400;
  overflow: hidden;
  height: 1.4rem;
  font-size: 0.85rem;
}

.socials .social-card.social-card--pinterest .pin-info .pin-desc::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  width: 7.25rem;
  pointer-events: none;
  background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.5) 5%, #FFFFFF 25%, #FFFFFF 100%);
}

.socials .social-card.social-card--pinterest .pin-info .pin-desc .see-more {
  position: absolute;
  top: 0;
  right: 0.25rem;
  color: #252525;
  font-weight: 500;
  line-height: 1.4;
  background: #FFFFFF;
  z-index: 2;
  padding-left: 0.2rem;
  cursor: pointer;
}

.socials .socials__statistics {
  margin-top: 3rem;
  overflow: hidden;
}

@media (max-width: 768px) {
  .socials .socials__statistics {
    margin-top: 2rem;
  }
}

.socials .socials__statistics p {
  max-width: 26rem;
  font-size: 1.25rem;
}

@media (max-width: 768px) {
  .socials .socials__statistics p {
    font-size: 1rem;
  }
}

.socials .socials__statistics h3 {
  font-size: 1.5rem;
  font-weight: bold;
  margin-bottom: 4rem;
  margin-left: auto;
}

@media (max-width: 768px) {
  .socials .socials__statistics h3 {
    font-size: 1.25rem;
    margin-top: 1.5rem;
    margin-bottom: 3rem;
  }
}

.socials .socials__statistics .stat-item {
  opacity: 1;
  transform: translateY(30px);
  margin-bottom: 7.5rem;
  position: relative;
}

@media (max-width: 768px) {
  .socials .socials__statistics .stat-item {
    margin-bottom: 6rem;
  }
}

.socials .socials__statistics .stat-item .stat-number-wrap {
  position: relative;
  display: inline-block;
  min-width: 80px;
}

.socials .socials__statistics .stat-item .stat-number {
  font-size: 3rem;
  font-weight: bold;
  color: #252525;
  width: fit-content;
}

@media (max-width: 768px) {
  .socials .socials__statistics .stat-item .stat-number {
    font-size: 2rem;
    height: 3rem;
  }
}

.socials .socials__statistics .stat-item .stat-text {
  position: absolute;
  top: 50%;
  color: #252525;
  left: 45%;
  transform: translateY(-50%);
  font-size: 1.125rem;
  max-width: 15rem;
  line-height: 1.4;
}

@media (max-width: 768px) {
  .socials .socials__statistics .stat-item .stat-text {
    font-size: 1rem;
  }
}

.socials .socials__statistics .stat-item .stat-arrow {
  position: absolute;
  top: 120%;
  left: 0;
  transform: translateY(-50%);
  height: 2px;
  background-color: red;
  width: 0;
  top: 4.625rem;
}

@media (max-width: 768px) {
  .socials .socials__statistics .stat-item .stat-arrow {
    top: 150%;
  }
}

.socials .socials__statistics .stat-item .stat-arrow::after {
  content: "";
  position: absolute;
  width: 16px;
  height: 16px;
  border-right: 2px solid red;
  border-bottom: 2px solid red;
  top: 50%;
  right: 0;
  transform: translate(0, -50%) rotate(-45deg);
}

.believe {
  min-height: 74rem;
  padding-top: 8rem;
  overflow: hidden;
  padding-bottom: 8rem;
  background-color: #FFFFFF;
}

.believe h2 {
  font-size: 3.625rem;
  font-weight: bold;
  position: relative;
  margin: 0;
}

@media (max-width: 768px) {
  .believe {
    padding-bottom: 3.125rem;
  }

  .believe h2 {
    font-size: 2rem;
  }
}

.believe h2 span {
  display: block;
  font-size: 8rem;
  margin-top: 0.625rem;
}

body.en .believe h2 span {
  margin-top: 0.84375rem;
}

@media (max-width: 768px) {
  .believe h2 span {
    font-size: 2.875rem;
    margin-top: 0rem;
  }
}

.believe h2::after {
  content: "";
  position: absolute;
  width: 3.125rem;
  top: 0.34375rem;
  left: 26.875rem;
  height: 3.125rem;
  transform: translateX(-50%);
  background-image: url("/media/cases/profiltechnik/images/believe-emoji.png");
}

body.en .believe h2::after {
  left: 15.625rem;
}

@media (max-width: 768px) {
  .believe h2::after {
    font-size: 2rem;
    left: 15.5rem;
    top: -0.15rem;
    width: 2rem;
    height: 2rem;
    background-size: cover;
  }
}

.believe .mark {
  margin-top: 9rem;
  margin-bottom: 9rem;
  background: none;
  margin-left: auto;
  display: block;
  width: fit-content;
  position: relative;
}

@media (max-width: 768px) {
  .believe .mark {
    margin-top: 3rem;
    margin-bottom: 3rem;
    margin-right: 1.5rem;
  }
}

.believe .mark p {
  font-size: 2.5rem;
  text-align: right;
  margin: 0;
  position: relative;
}

@media (max-width: 768px) {
  .believe .mark p {
    font-size: 1.5rem;
  }
}

.believe .mark span {
  display: block;
  position: relative;
}

.believe .mark span.svg-wrapper {
  bottom: 0.5rem;
  left: 0;
  width: 100%;
  height: 1em;
  pointer-events: none;
  position: relative;
  display: inline-block;
}

.believe .mark span.svg-wrapper .underline {
  position: absolute;
  bottom: -1rem;
  left: 4rem;
  width: 100%;
  height: 2rem;
  stroke: currentColor;
}

@media (max-width: 768px) {
  .believe .mark span.svg-wrapper .underline {
    height: 1.5rem;
    width: 65%;
    bottom: -0.5rem;
  }
}

.believe .mark img {
  position: absolute;
  bottom: 3.5rem;
  right: -1.5rem;
  width: 31.5px;
  height: 28.5px;
}

@media (max-width: 768px) {
  .believe .mark img {
    bottom: 2.5em;
    right: -1.5rem;
  }
}

.believe .info p {
  font-size: 1.5rem;
  max-width: 34.313rem;
}

@media (max-width: 768px) {
  .believe .info p {
    font-size: 1.1875rem;
  }
}

.believe .info div:nth-child(2) p {
  max-width: 34.313rem;
  font-size: 1.125rem;
}

@media (max-width: 768px) {
  .believe .info div:nth-child(2) p {
    font-size: 1rem;
    margin-top: 1rem;
  }
}

.believe .info div:nth-child(2) p span {
  font-weight: bold;
}

.believe .list {
  margin-top: 6rem;
}

@media (max-width: 768px) {
  .believe .list {
    margin-top: 3rem;
  }
}

.believe .list ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 1rem;
}

.believe .list ul li {
  font-weight: 300;
  padding-bottom: 1rem;
  position: relative;
  max-width: 20.5rem;
}

.believe .list ul li p {
  font-size: 1.25rem;
}

@media (max-width: 768px) {
  .believe .list ul li p {
    font-size: 1rem;
  }
}

.believe .list ul li::before {
  content: counter(list-item, decimal-leading-zero);
  left: 0;
  display: block;
  padding-bottom: 0.5rem;
  font-size: 1rem;
  font-weight: bold;
  color: #E20516;
}

.client_response {
  background: url("/media/cases/profiltechnik/images/client_response_background.webp");
  background-size: cover;
  background-position: center top;
  padding-top: 8rem;
  padding-bottom: 10rem;
  position: relative;
  height: calc(var(--vh, 1vh) * 100) !important;
  max-height: 44rem;
}

@media (min-width: 1800px) {
  .client_response {
    max-height: 55rem;
  }
}

@media (max-width: 768px) {
  .client_response {
    background-position: 223vw top;
    max-height: 55rem;
    padding-top: 70%;
    position: relative;
  }
}

@media (max-width: 385px) {
  .client_response {
    background-position: 225vw top;
  }
}

.client_response::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to right, rgba(17, 17, 17, 0.7) 0%, rgba(17, 17, 17, 0) 100%);
  z-index: 1;
}

.client_response>* {
  position: relative;
  z-index: 2;
}

@media (max-width: 768px) {
  .client_response>* {
    position: unset;
  }
}

.client_response img.leaf {
  position: absolute;
  top: 0;
  right: 2%;
  transform: translateX(-50%);
  width: auto;
  height: 14rem;
  opacity: 0;
  z-index: 3;
}

@media (max-width: 768px) {
  .client_response img.leaf {
    height: 8rem;
    right: 25%;
  }
}

.client_response span {
  font-size: 0.875rem;
  text-transform: uppercase;
  font-weight: 500;
  color: #FFFFFF !important;
}

@media (max-width: 768px) {
  .client_response span {
    position: absolute;
    bottom: 23rem;
    z-index: 4;
  }
}

.client_response .red_box {
  margin-top: 2rem;
  background-color: #E20516;
  color: #FFFFFF;
  padding: 2rem;
  max-width: 26rem;
  height: calc(var(--vh, 1vh) * 100) !important;
  max-height: 26rem;
  margin-right: auto;
  clip-path: polygon(0 0, calc(100% - 3.5rem) 0, calc(100% - 3.5rem) 3.5rem, 100% 3.5rem, 100% 100%, 0 100%);
}

@media (max-width: 768px) {
  .client_response .red_box {
    max-width: 18.5rem;
    max-height: 18rem;
    position: absolute;
    bottom: 3rem;
    z-index: 4;
    clip-path: polygon(0 0, calc(100% - 2.5rem) 0, calc(100% - 2.5rem) 2.5rem, 100% 2.5rem, 100% 100%, 0 100%);
  }
}

.client_response .red_box p {
  margin-top: 2.5rem;
  font-size: 1.25rem;
  font-weight: bold;
  max-width: 20.5rem;
  color: #FFFFFF;
}

body.en .client_response .red_box p {
  margin-top: 1.09375rem;
}

@media (max-width: 768px) {
  .client_response .red_box p {
    font-size: 0.875rem;
    margin-top: 1rem;
    max-width: 17rem;
  }
}

.client_response .red_box p:nth-child(2) {
  font-size: 1.125rem;
  font-weight: bold;
  margin-top: 1rem;
}

.client_response .red_box p:nth-child(2) span {
  display: block;
  font-size: 1.125rem;
  font-weight: 300;
}

@media (max-width: 768px) {
  .client_response .red_box p:nth-child(2) span {
    font-size: 0.875rem;
    margin-top: 0;
  }
}

@media (max-width: 768px) {
  .client_response .red_box p:nth-child(2) {
    font-size: 0.875rem;
    margin-top: 0.5rem;
  }
}

.request {
  background-color: #FFF0F1;
  max-height: 42rem;
  position: relative;
  z-index: 2;
  padding-top: 6.25rem;
  padding-bottom: 12.5rem;
}


.request .btn-arrow {
  font-size: 18px;
}

@media (max-width: 768px) {
  .request {
    padding-top: 8rem;
    padding-bottom: 8rem;
    height: unset;
    max-height: unset;
  }
}

.request div {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 3rem;
}

.request div h2 {
  text-align: center;
  font-size: 3.625rem;
  max-width: 56.5rem;
  font-weight: 400;
}

@media (max-width: 768px) {
  .request div h2 {
    font-size: 2rem;
  }
}

.request div button {
  background-color: #E20516;
  color: #FFFFFF;
  padding: 0.5rem 3rem;
  font-weight: 500;
  font-size: 1.5rem;
  border-radius: 2rem;
  cursor: pointer;
  transition: all 0.5s cubic-bezier(0.25, 0.1, 0.25, 1);
  border: none;
  height: 3.25rem;
}

.request div button:hover {
  background: #b00411;
}

@media (max-width: 768px) {
  .request div button {
    font-size: 1rem;
    padding: 0.5rem 2rem;
  }

  .request div button:hover {
    background-color: #E20516;
  }
}

@media (max-width: 576px) {

  main .container,
  main .container-fluid,
  main .container-xxl,
  main .container-xl,
  main .container-lg,
  main .container-md,
  main .container-sm {
    --bs-gutter-x: 2.5rem;
  }
}

.site-header,
.site-header.glass {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  background: transparent !important;
  box-shadow: none !important;
}

.site-header.glass::before,
.site-header.glass::after {
  display: none !important;
}

/* The profiltechnik ".container { max-width: 1172/1320px !important }" overrides
   (the @media 1400/1680px rules) also shrank the header bar. Re-assert full
   width on the header's container so the logo/menu sit at the edges, like the
   other case studies. Higher specificity than ".container" beats the !important. */
.site-header .container {
  max-width: none !important;
  width: 100%;
}

.case-section-tag .content>* {
  font-weight: bold;
}

/* ─────────────────────────────────────────────────────────────
   GLASS treatment for the floating controls (dark-mode toggle, floating
   case tag, horizontal-slider buttons, socials arrows).
   Implemented as a frosted backdrop-filter + the site's signature rim
   shadow rather than the .glass class, because each of these elements has
   its own ::before/::after (toggle knob, arrow chevrons) or background-state
   variants (case tag white/red) that the .glass class + glass.js would
   clobber. Pure CSS — no layout or JS impact; tweak the blur/alpha to taste.
   ───────────────────────────────────────────────────────────── */

/* 1) Dark-mode toggle pill */
.hero__toggle .toggle .slider {
  backdrop-filter: blur(8px) saturate(150%);
  -webkit-backdrop-filter: blur(8px) saturate(150%);
  box-shadow:
    inset 0 1px 1px rgba(255, 255, 255, 0.4),
    inset 0 -1px 1px rgba(0, 0, 0, 0.25),
    0 6px 16px -8px rgba(0, 0, 0, 0.45);
}

/* 2) Horizontal slider nav buttons (sit over the slide photos) */
.horizontal-scroll .slider-nav__button {
  backdrop-filter: blur(20px) saturate(150%);
  -webkit-backdrop-filter: blur(20px) saturate(150%);
  box-shadow:
    inset 0 1px 1px rgba(255, 255, 255, 0.3),
    inset 0 -1px 1px rgba(0, 0, 0, 0.3),
    0 4px 12px -4px rgba(0, 0, 0, 0.45);
}

/* 3) Socials slider arrows — kept translucent RED (not clear) so the white
      chevrons keep contrast; clear glass would make them vanish on the light bg. */
.socials .socials-slider-wrap .slider-arrows .slider-arrow {
  background-color: rgba(226, 5, 22, 0.6);
  backdrop-filter: blur(8px) saturate(160%);
  -webkit-backdrop-filter: blur(8px) saturate(160%);
  box-shadow:
    inset 0 1px 1px rgba(255, 255, 255, 0.35),
    inset 0 -1px 1px rgba(0, 0, 0, 0.2),
    0 4px 12px -4px rgba(0, 0, 0, 0.35);
}

body.light-mode .contact h2 {
  color: white;
}