:root {
  --light-blue: #006fcf;
  --deep-blue: #00175a;
  --white: #ffffff;
  --vd-grey-blue: #DDE1EA;
  --vd-grey-light: #f6f8fa;
  --vd-grey-dark: #3d3d3d;
}

html {
  /* Reserve scrollbar gutter to prevent ~10-15px viewport width jumps */
  scrollbar-gutter: stable;
}

body {
  overflow-x: hidden !important;
}

/***** FONTS *****/
/*---------------*/

div[role="main"].container-fluid .richtext h1 {
  font-size: 34px;
  line-height: 120%;
  font-weight: 700;
  font-family: BentonSans;
  color: #000;
}

div[role="main"].container-fluid .richtext h2 {
  font-size: 40px;
  line-height: 120%;
  font-weight: 700;
  font-family: BentonSans;
  color: #000;
}

div[role="main"].container-fluid .richtext h3 {
  font-size: 34px;
  line-height: 120%;
  font-weight: 400;
  font-family: BentonSans;
  color: #000;
}

div[role="main"].container-fluid .richtext h3.small {
  font-size: 24px !important;
  line-height: 120%;
  font-weight: 500 !important;
  font-family: BentonSans !important;
  color: #000 !important;
}

/* Body Text */
div[role="main"].container-fluid .richtext p {
  font-size: 18px;
  line-height: 150%;
  color: #000;
}

@media screen and (max-width: 767.98px) {
  div[role="main"].container-fluid .richtext h1 {
    font-size: 24px;
  }

  div[role="main"].container-fluid .richtext h2 {
    font-size: 28px;
  }

  div[role="main"].container-fluid .richtext h3 {
    font-size: 24px;
  }

  div[role="main"].container-fluid .richtext h3.small {
    font-size: 16px;
  }

  /* Body Text */
  div[role="main"].container-fluid .richtext p {
    font-size: 14px;
  }
}

/***** COLORS *****/
.vd--bg-gradient-tb {
  background-color: var(--vd-grey-light);
  background-image:
    linear-gradient(180deg,
      color-mix(in srgb, var(--deep-blue) 10%, transparent) 8.6538%,
      color-mix(in srgb, var(--vd-grey-light) 10%, transparent) 91.827%),
    linear-gradient(90deg, var(--vd-grey-light) 0%, var(--vd-grey-light) 100%);
}

.vd--bg-gradient-bt {
  background-color: var(--vd-deep-blue) 10%;
  background-image:
    linear-gradient(0deg,
      color-mix(in srgb, var(--deep-blue) 10%, transparent) 8.6538%,
      color-mix(in srgb, var(--vd-grey-light) 10%, transparent) 91.827%),
    linear-gradient(90deg, var(--vd-grey-light) 0%, var(--vd-grey-light) 100%);
}

.vd--bg-grey-blue {
  background-color: var(--vd-deep-blue) 10%;
  background-image:
    linear-gradient(0deg,
      color-mix(in srgb, var(--deep-blue) 10%, transparent) 8.6538%,
      color-mix(in srgb, var(--deep-blue) 10%, transparent) 91.827%),
    linear-gradient(90deg, var(--vd-grey-light) 0%, var(--vd-grey-light) 100%);
}

.vd--bg-grey-light {
  background-color: var(--vd-grey-light);
}

/***** SPACING *****/
/*-----------------*/

div[role="main"] {
  padding-bottom: 40px !important;
}

div[role="main"] .container {
  max-width: 1376px;
}

@media screen and (min-width: 1376px) {
  div[role="main"] .container {
    padding: 0;
  }
}

div[role="main"] .container .container {
  max-width: unset;
}

@media screen and (max-width: 767.98px) {
  div[role="main"] .container .container {
    padding: 0;
  }

  .vd--hero-content-left {
    margin-left: 12px;
    margin-right: 12px;
  }

  .vd--hero-content-left:not(.vd--grid-no-padding) > .container{
    padding: 0 40px;
  }

  .vd--hero-benefit .container {
    padding-right: 0;
  }
}

.vd--section {
  padding: 4rem 0;
}

@media screen and (max-width: 767.98px) {
  .vd--section {
    padding: 2rem 4px;
  }
}

.vd--section>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  flex-direction: column;
  gap: 42px;
}

.vd---grid-headlines>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.vd--grid-legal {
  padding: 2rem 1rem;
}

@media screen and (max-width: 767.98px) {
  .vd--grid-legal {
    padding: 20px 4px;
  }
}



/***** BUTTONS *****/
/*-----------------*/

.vd--hero-button a {
  margin-bottom: 0 !important;
  font-weight: 500 !important;
  padding: 16px 24px !important;
  font-family: BentonSans !important;
  min-width: 230px !important;
}

.vd--hero-button .btn {
  max-width: 230px !important;
}

.vd--sticky-button a,
.vd--sticky-banner .vd--hero-button a,
.vd---details-sticky-banner .vd--hero-button a {
  margin-bottom: 0 !important;
  font-weight: 500 !important;
  padding: 13px 17px !important;
  font-family: BentonSans !important;
  min-height: 42px !important;
  line-height: 16px !important;
  font-size: 16px !important;
  border-radius: 4px !important;
}

@media screen and (max-width: 767.98px) {
  .vd--sticky-button a,
  .vd--sticky-banner .vd--hero-button a,
  .vd---details-sticky-banner .vd--hero-button a {
    font-size: 14px;
    padding: 8px 12px !important;
    font-family: BentonSans !important;
  }

  .vd--grid-horizontal .col-md-12> div {
    display: flex;
    gap: 0;
    padding-top: 0;
    justify-content: space-between;
  }
}

/***** STICKY BAR *****/
/*-------------------*/

.vd--grid-horizontal .col-md-12>div {
  display: flex;
  gap: 2rem;
}

.vd--sticky-content-left > .container > .row > .col-md-12.margin-0-tb > div > .richtext {
display: flex;
align-items: center;
}

.vd--sticky-banner {
  border-bottom: 1px solid #c8c9c7;
  padding: 24px 12px;
  position: fixed !important;
  z-index: 9;
  width: 100%;
  background-color: #fff;
  box-shadow: 0 0 12px rgba(0, 0, 0, 0.08);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-100%);
  transition:
    opacity 0.3s ease,
    visibility 0.3s ease,
    transform 0.3s ease;
}

.vd--sticky-banner .container {
  padding: 0 10px;
}

@media screen and (max-width: 767.98px) {

  .vd--sticky-banner .container {
    padding: 0 16px;
  }

  .vd--sticky-banner .vd--hero-button a,
  .vd---details-sticky-banner .vd--hero-button a,
  .vd---details-sticky-banner-right .vd--hero-button a,
  .vd--sticky-button-details a,
  .vd--details-sticky-button-close a {
    font-size: 16px !important;
    line-height: 16px !important;
    min-height: 42px !important;
  }

  .vd--sticky-banner .vd--hero-button a,
  .vd---details-sticky-banner .vd--hero-button a,
  .vd---details-sticky-banner-right .vd--hero-button a {
    width: auto !important;
    min-width: 0 !important;
    max-width: 280px !important;
    padding: 13px 17px !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
  }

  .vd--sticky-banner > .container > .row > .col-md-12.margin-0-tb > div >.grid:has(.vd--sticky-card-image) {
    display: none !important;
  }

  .vd--sticky-banner > .container > .row > .col-md-12.margin-0-tb > div,
  .vd---details-sticky-banner > .container > .row > .col-md-12.margin-0-tb > div {
    width: 100%;
  }

  .vd--sticky-banner > .container > .row > .col-md-12.margin-0-tb > div >.grid:has(.vd--sticky-content-right) {
    width: 100%;
  }

  .vd--grid-horizontal .col-md-12>div {
    padding-top: 0;
  }
}

.vd--sticky-banner.is-visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.vd--sticky-banner>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 42px;
}

.vd--sticky-content-left img {
  width: 75px;
}

.vd--sticky-button-details a {
  font-weight: 500 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin-bottom: 0 !important;
  color: #8e9092 !important;
  min-height: 42px !important;
  display: inline-flex !important;
  align-items: center;
  line-height: 16px !important;
  font-size: 16px !important;
}

.vd--sticky-button-details a:hover,
.vd--sticky-button-details a:focus {
  color: var(--deep-blue) !important;
  background: transparent !important;
}

/***** BANNER *****/
/*---------------*/

.vd--banner-offer p {
  line-height: 2rem !important;
  font-size: 16px !important;
}

.vd--banner-offer>.container>.row>.col-md-12 {
  padding: 8px 0px;
}

.vd--banner-offer>.card-img-bg {
  background-color: var(--light-blue) !important;
}

/***** HERO *****/
/*-------------*/

.vd--hero-grid {
  background-color: var(--deep-blue);
  overflow: hidden;
}

.vd--hero-grid>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  flex-direction: row;
  gap: 80px;
}

@media screen and (max-width: 767.98px) {
  .vd--hero-grid>.container>.row>.col-md-12.margin-0-tb>div {
    flex-direction: column;
  }
}

@media screen and (max-width: 1000px) {
  .vd--hero-grid>.container>.row>.col-md-12.margin-0-tb>div {
    gap: 20px;
  }
}

.vd--hero-grid>.container>.row>.col-md-12.margin-0-tb>div>.grid {
  flex: 1 1 0;
  min-width: 0;
}

@media screen and (max-width: 767.98px) {
  .vd--hero-grid>.container>.row>.col-md-12.margin-0-tb>div>.grid {
    margin: 0 -18px;
    width: calc(100% + 36px);
  }

  .vd--hero-grid>.container>.row>.col-md-12.margin-0-tb>div>.grid:last-child {
    order: -1;
    padding: 24px 0 0;
  }

  .vd--hero-content-right .container,
  .vd--hero-content-right .row,
  .vd--hero-content-right,
  .vd--hero-content-right .col-md-12.margin-0-tb {
    padding: 0;
    margin: 0;
  }
}

.vd--hero-content-right {
  max-height: 768px;
  height: 100%;
  position: relative;
}

.vd--hero-content-right {
  visibility: hidden;
  opacity: 0;
  transform: translateY(16px);
  transition:
    opacity 700ms ease 100ms,
    transform 700ms ease 100ms,
    visibility 0s linear 800ms;
}

.vd--hero-grid.is-hero-carousel-ready .vd--hero-content-right {
  visibility: visible;
  opacity: 1;
  transform: translateY(0);
  transition:
    opacity 700ms ease 100ms,
    transform 700ms ease 100ms,
    visibility 0s linear 0s;
}

.vd--hero-content-right .vd--hero-badge>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 40px;
  min-height: 560px;
  height: 100%;
  overflow: hidden;
}

@media screen and (max-width: 767.98px) {
  .vd--hero-content-right {
    max-height: none;
    height: auto;
  }

  .vd--hero-content-right .vd--hero-badge>.container>.row>.col-md-12.margin-0-tb>div {
    align-items: stretch;
    display: flex;
    flex-direction: row;
    gap: 16px;
    height: auto;
    justify-content: flex-start;
    min-height: 0;
    overflow: hidden;
  }

  .vd--hero-content-right .vd--hero-badge>.container>.row>.col-md-12.margin-0-tb>div>.image.parbase {
    flex: 0 0 52%;
    max-width: 52%;
    width: auto;
  }

  .vd--hero-content-right .vd--hero-badge .image.parbase {
    justify-content: center;
  }

  .vd--hero-image {
    max-width: 100%;
  }

  .vd--hero-image img {
    height: auto !important;
  }
}

.vd--hero-content-right .container,
.vd--hero-content-right .row,
.vd--hero-content-right .col-md-12.margin-0-tb {
  height: 100%;
}

.vd--hero-content-right .vd--hero-badge .image.parbase {
  width: 100%;
  display: flex;
  justify-content: flex-end;
}

.vd--hero-image {
  max-width: 540px;
}

.vd--hero-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  opacity: 0;
  transition: opacity 700ms ease;
}

.vd--hero-image img.is-loaded {
  opacity: 1;
}

.vd--hero-badges>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  margin-bottom: 2.5rem;
  gap: 1rem;
}

.vd--hero-badges .vd--hero-card-image {
  width: 120px;
  height: auto;
}

@media screen and (max-width: 767.98px) {

  .vd--hero-badges>.container>.row>.col-md-12.margin-0-tb>div,
  .vd--hero-badges .vd--hero-card-image {
    display: none;
  }
}

/* Callout */
.vd--hero-callout {
  border: 1px solid #fff;
  border-radius: 24px;
  padding: 8px 12px;
  margin-bottom: 1.25rem;
  display: inline-flex;
}

@media screen and (max-width: 767.98px) {
  .vd--hero-callout {
    display: table;
    margin: 0 auto 24px;
    white-space: nowrap;
  }
}

.vd--hero-callout p {
  line-height: 1.2 !important;
}

.vd--hero-callout span {
  line-height: 1.2 !important;
}

.vd--hero-grid {
  min-height: 770px;
}

.vd--hero-grid>.container>.row>.col-md-12.margin-0-tb>div>.grid>section {
  height: 100%;
}

.vd--hero-grid>.container>.row>.col-md-12.margin-0-tb>div>.grid>section>.vd--hero-content-left {
  padding: 80px 0 125px;
}

@media screen and (max-width: 767.98px) {
  .vd--hero-grid>.container>.row>.col-md-12.margin-0-tb>div>.grid>section>.vd--hero-content-left {
    padding: 4px 0 125px 0;
  }
}

.vd--hero-grid .vd--hero-content-left h1 {
  margin-bottom: 1.25rem;
}

.vd-hero--benefits>.container {
  padding-left: 10px !important;
}

.vd-hero--benefits>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
}

.vd--hero-benefit li {
  cursor: pointer;
  pointer-events: all;
  font-size: 18px !important;
  line-height: 150% !important;
  transition:
    opacity 0.25s ease-out,
    font-weight ease-in;
}
@media screen and (max-width: 767.98px) {
  .vd--hero-benefit li {

  font-size: 14px !important;

}
}
.vd--hero-benefit li:hover {
  opacity: 0.7;
}

.vd-hero--benefits [class*="vd--hero-benefit-"].is-active .richtext.parbase li,
.vd-hero--benefits [class*="vd--hero-benefit-"].is-active .richtext.parbase li b,
.vd-hero--benefits [class*="vd--hero-benefit-"].is-active .richtext.parbase li span,
.vd--hero-benefit li.is-active,
.vd--hero-benefit li.is-active b,
.vd--hero-benefit li.is-active span {
  font-weight: 900;
}

.vd--hero-grid .vd--hero-button a {
  margin-top: 2rem;
}

.vd--hero-subheadline .container {
  padding: 0;
}

/***** HIGHLIGHTS *****/
/*-------------------*/
section:has(.vd--hero-benefits-slider-section) {
  position: relative;
}

.vd--hero-benefits-slider-section {
  position: relative;
  transform: none;
  margin-top: clamp(-168px, -16vw, -160px);
  z-index: 8;
}

@media screen and (max-width: 767.98px) {
  .vd--hero-benefits-slider-section .container {
    padding: 0;
  }

  .vd--hero-benefits-slider-section .container .margin-0-tb {
    margin-left: 0;
    margin-right: 0;
  }
}

.vd--hero-benefits-slider-section>.container>.row>.col-md-12.margin-0-tb>div {
  margin: 0 auto;
  margin-top: 0;
  max-width: 1122px;
  padding-bottom: 2.25rem;
}

/* Content inside consisting of buttons and image + text */
.vd--hero-benefits-slider-wrapper>.container>.row>.col-md-12.margin-0-tb>div {
  background-color: #fff;
  border-radius: 16px;
  box-shadow: 0px 0px 24px 0px rgba(0, 0, 0, 0.08);
  position: relative;
}

/* Arrow buttons */
.vd--hero-benefits-slider-wrapper .grid:has(.vd--slider-arrow-left) {
  position: absolute;
  left: 1rem;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  cursor: pointer;
}

.vd--hero-benefits-slider-wrapper .grid:has(.vd--slider-arrow-left):hover {
  opacity: 0.7;
}

.vd--hero-benefits-slider-wrapper .vd--slider-arrow-left {
  width: 2rem;
  height: 2rem;
  background-color: #ecedee;
  z-index: 5;
  position: relative;
  pointer-events: auto;
}

.vd--hero-benefits-slider-wrapper .grid:has(.vd--slider-arrow-right) {
  position: absolute;
  right: 1rem;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  cursor: pointer;
}

.vd--hero-benefits-slider-wrapper .grid:has(.vd--slider-arrow-right):hover {
  opacity: 0.7;
}

.vd--hero-benefits-slider-wrapper .vd--slider-arrow-right {
  width: 2rem;
  height: 2rem;
  background-color: #ecedee;
  pointer-events: auto;
}

/*Viewport */
.vd--hero-benefits-slider {
  min-height: 176px;
  overflow: hidden;
  cursor: grab;
  transition: height 0.35s ease;
}

/* Arrange slides horizontally like a carousel */
.vd--hero-benefits-slider>.container>.row>.col-md-12.margin-0-tb>div {
  position: relative !important;
  display: flex;
  width: 100%;
  will-change: transform;
}

.vd--hero-benefits-slider .grid:has(.vd--hero-benefits-slide) {
  position: relative !important;
  flex: 0 0 100%;
  min-width: 100%;
  width: 100%;
  padding: 0 45px;
  box-sizing: border-box;
  height: auto;
  transition: none;
}

.vd--hero-benefits-slider section {
  display: flex;
  align-items: center;
  height: 100%;
}

.vd--hero-benefits-slide.is-active {
  z-index: 2;
}

.vd--hero-benefits-slider>.container {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.vd--hero-benefits-slider>.container>.row>.col-md-12.margin-0-tb>div {
  min-height: 100%;
}

.vd--hero-benefits-slider>.container>.row>.col-md-12.margin-0-tb>div>.grid {
  display: flex;
  align-items: stretch;
  min-height: 100%;
}

@media screen and (max-width: 767.98px) {
  .vd--hero-benefits-slider>.container>.row>.col-md-12.margin-0-tb>div>.grid {
    flex-direction: column;
  }
}

.vd--hero-benefits-slide {
  padding: 16px 35px;
}

.vd--hero-benefits-slide div {
  display: flex;
  align-items: center;
}

.vd--hero-benefits-slide>.container {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Inner content consisting of image and text */
.vd--hero-benefits-slide>.container>.row>.col-md-12.margin-0-tb>div {
  flex: 1;
  justify-content: space-between;
  gap: 24px;
  min-height: 100%;
}

@media screen and (max-width: 767.98px) {
  .vd--hero-benefits-slide>.container>.row>.col-md-12.margin-0-tb>div {
    flex-direction: column;
  }
}

/* Image */
.vd--hero-benefits-slide>.container>.row>.col-md-12.margin-0-tb>div>.image.parbase {
  flex: 1 0 auto;
  position: relative;
  width: 237px;
}

.vd--hero-benefits-slide>.container>.row>.col-md-12.margin-0-tb>div>.image.parbase>.text-align-left>img {
  border-radius: 8px;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  overflow: hidden;
}

/* Text */
.vd--hero-benefits-slide>.container>.row>.col-md-12.margin-0-tb>div>.richtext.parbase {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 24px 0;
}

/* Button */
.vd--benefits-slider-button {
  padding-top: 2rem;
}

/* Dots */
.vd--slider-page-dots>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  width: 100%;
  gap: 8px;
  justify-content: center;
  align-items: center;
  position: absolute;
  bottom: -36px;
  left: 0;
}

.vd--slider-dot {
  height: 12px;
  width: 12px;
  border-radius: 50%;
  cursor: pointer;
  background-color: var(--white);
}

.vd--slider-dot:hover {
  opacity: 0.7;
}

.vd--slider-dot.is-active {
  background-color: var(--light-blue);
}

@media screen and (max-width: 767.98px) {
  .vd--hero-benefits-slider-section>.container>.row>.col-md-12.margin-0-tb>div {
    padding-top: 3rem;
    padding-bottom: 3rem;
  }

  .vd--hero-benefits-slider-wrapper>.container>.row>.col-md-12.margin-0-tb>div {
    border-radius: 12px;
  }

  .vd--hero-benefits-slider .grid:has(.vd--hero-benefits-slide) {
    padding: 0 12px;
  }

  .vd--hero-benefits-slide {
    padding: 12px 12px 16px;
  }

  .vd--hero-benefits-slide p {
    text-align: center !important;
  }

  .vd--hero-benefits-slide>.container>.row>.col-md-12.margin-0-tb>div {
    gap: 12px;
  }

  .vd--hero-benefits-slide>.container>.row>.col-md-12.margin-0-tb>div>.image.parbase {
    display: none;
  }

  .vd--hero-benefits-slide>.container>.row>.col-md-12.margin-0-tb>div>.richtext.parbase {
    padding: 0;
  }

  .vd--hero-benefits-slider-wrapper .grid:has(.vd--slider-arrow-left) {
    left: 8px;
  }

  .vd--hero-benefits-slider-wrapper .grid:has(.vd--slider-arrow-right) {
    right: 8px;
  }

  .vd--hero-benefits-slider-wrapper .vd--slider-arrow-left,
  .vd--hero-benefits-slider-wrapper .vd--slider-arrow-right {
    display: none;
  }

  .vd--slider-page-dots>.container>.row>.col-md-12.margin-0-tb>div {
    bottom: -30px;
  }
}

.vd--intro-text h2 {
  padding-top: 80px;
}

/***** LIQUIDITY *****/
/*------------------*/

.vd--grid-liquidity .container {
  max-width: 1100px !important;
  margin: 0 auto;
}

.vd--grid-liquidity-button {
  padding-top: 2rem;
  padding-bottom: 8rem;
}

/* Image */
.vd--liquidity-plus {
  max-width: 1100px !important;
  align-items: center;
}

/* Enforce exclusive liquidity variants at the 767/768 breakpoint.
   Use wrapper-level control so utility class overrides can't show both blocks. */
@media screen and (max-width: 767.98px) {
  .vd--grid-liquidity .vd--liquidity-image-wrapper {
    display: none !important;
  }

  .vd--grid-liquidity .vd--grid-liquidity-mobile {
    display: block !important;
  }
}

@media screen and (min-width: 768px) {
  .vd--grid-liquidity .vd--liquidity-image-wrapper {
    display: block !important;
  }

  .vd--grid-liquidity .vd--grid-liquidity-mobile {
    display: none !important;
  }
}

@media screen and (min-width: 860px) {
  .vd--liquidity-plus {
    min-width: 800px;
  }
}

/* SPIELRAUM TEXT */

.vd--spielraum-text .col-md-12.margin-0-tb>div {
  display: flex;
  justify-content: flex-end;
}

@media (max-width: 767.98px) {
  .vd--spielraum-text .col-md-12.margin-0-tb>div {
    width: 200px;
    margin: 0 auto;
  }
}

.vd--spielraum-text .richtext.parbase p {
  margin-top: 12px;
  max-width: 180px;
  font-size: 12px !important;
  line-height: 1.5;
  text-align: right;
}

@media (max-width: 767.98px) {
  .vd--spielraum-text .richtext.parbase p {
    max-width: 100%;
  }
}

/***** INVOICES PHONE *****/
/*------------------------*/

.vd--payment-section {
  background-color: #fff;
}

@media (max-width: 767.98px) {
  .vd--payment-section {
    background-color: #f6f8fa;
    padding: 4rem 0;
  }
}

@media screen and (min-width: 1080px) {
  .vd--payment-section {
    margin-top: 4rem;
  }
}

@media screen and (min-width: 768px) {
  .vd--payment-section:before {
    content: "";
    height: 80px;
    width: 100%;
    position: absolute;
    top: 0;
    background-color: #f7f8f9;
  }

  /* roter “Margin-Layer” außerhalb des Elements */

  .vd--payment-section::after {
    content: "";
    position: absolute;
    top: -4rem;
    left: 0;
    right: 0;
    height: 4rem;
    background: #f7f8f9;
    z-index: -1;
    pointer-events: none;
  }
}

.vd--payment-section>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  flex-direction: row;
  padding-top: 140px;
  gap: 0;
}

@media screen and (min-width: 1080px) {
  .vd--payment-section>.container>.row>.col-md-12.margin-0-tb>div {
    margin-top: -80px;
    padding-top: 0;
  }
}

@media screen and (max-width: 767.98px) {
  .vd--payment-section>.container>.row>.col-md-12.margin-0-tb>div {
    flex-direction: column;
  }
}

.vd--payment-section .grid:has(.vd--payment-left),
.vd--payment-section .grid:has(.vd--payment-right) {
  width: 50%;
}

@media screen and (max-width: 767.98px) {
  .vd--payment-section .grid:has(.vd--payment-left) {
    margin-bottom: 70px;
  }

  .vd--payment-section .grid:has(.vd--payment-left),
  .vd--payment-section .grid:has(.vd--payment-right) {
    width: 100%;
    transform: none;
  }
}

@media screen and (max-width: 767.98px) {
  .vd--payment-section.vd--payment-slider-active>.container>.row>.col-md-12.margin-0-tb>div {
    position: relative;
    overflow: hidden;
    display: block;
    padding: 0;
  }

  .vd--payment-section.vd--payment-slider-active .grid:has(.vd--payment-left),
  .vd--payment-section.vd--payment-slider-active .grid:has(.vd--payment-right) {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    margin-bottom: 0;
    transition: transform 0.35s ease;
    transform: translateX(0);
  }

  .vd--payment-section.vd--payment-slider-active>.container>.row>.col-md-12.margin-0-tb>div>.grid:last-child {
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    transition: none !important;
    animation: none !important;
    translate: 0 !important;
    opacity: 1 !important;
  }
  .vd--payment-dots .grid {
    transition: none !important;
    animation: none !important;
    translate: 0 !important;
    opacity: 1 !important;
  }
  .vd--payment-section.vd--payment-slider-active .vd--payment-dots {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    margin-top: 24px;
  }

  .vd--payment-section.vd--payment-slider-active .vd--payment-dots>.container>.row>.col-md-12.margin-0-tb>div {
    display: flex;
    justify-content: center;
    gap: 7px;
  }

  .vd--payment-section.vd--payment-slider-active .vd--payment-dots .vd--slider-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #c8d2e5;
    cursor: pointer;
  }

  .vd--payment-section.vd--payment-slider-active .vd--payment-dots .vd--slider-dot.is-active {
    background: var(--light-blue);
  }
}

.vd--payment-section .grid:has(.vd--payment-left) section,
.vd--payment-section .grid:has(.vd--payment-right) section {
  height: 100%;
  display: flex;
}

.vd--payment-section .grid:has(.vd--payment-left) .container,
.vd--payment-section .grid:has(.vd--payment-right) .container {
  height: 100%;
  display: flex;
}

@media screen and (min-width: 768px) {

  .vd--payment-left>.container>.row>.col-md-12.margin-0-tb>div,
  .vd--payment-right>.container>.row>.col-md-12.margin-0-tb>div {
    height: 100%;
    display: flex;
  }
}

.vd--payment-left {
  z-index: 1;
}

.vd--payment-left>.container {
  padding-right: 0 !important;
  padding-left: 0 !important;
}

.vd--payment-content>.container {
  padding-right: 0 !important;
  padding-left: 0 !important;
}

@media screen and (min-width: 768px) {

  /* LEFT CONTAINER consisting of text and phone image */
  .vd--payment-left>.container>.row>.col-md-12.margin-0-tb>div {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    position: relative;
    z-index: 1;
  }

  /* Text container width */
  .vd--payment-left .grid:has(.vd--payment-content) {
    width: 64%;
    padding-right: 20px;
  }

  /* Phone image container width */
  .vd--payment-left .image.parbase:has(.vd--payments-phone-left) {
    width: 36%;
  }
}

/* Text container */
.vd--payment-left .vd--payment-content>.container>.row>.col-md-12.margin-0-tb>div,
.vd--payment-right .vd--payment-content>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  flex-direction: column;
  gap: 24px;
  height: 100%;
}

.vd--payment-left .vd--payment-content>.container>.row>.col-md-12.margin-0-tb>div>.grid,
.vd--payment-right .vd--payment-content>.container>.row>.col-md-12.margin-0-tb>div>.grid {
  display: flex;
  flex-direction: column;
  min-height: 0;
  margin-top: auto;
}

.vd--payment-right .vd--payment-content>.container>.row>.col-md-12.margin-0-tb>div>.grid {
  margin-left: auto;
}

.vd--payment-left .vd--payment-content>.container>.row>.col-md-12.margin-0-tb>div>.grid>section,
.vd--payment-right .vd--payment-content>.container>.row>.col-md-12.margin-0-tb>div>.grid>section {
  margin-top: auto;
}

@media screen and (min-width: 1080px) {

  .vd--payment-left .vd--payment-content>.container>.row>.col-md-12.margin-0-tb>div,
  .vd--payment-right .vd--payment-content>.container>.row>.col-md-12.margin-0-tb>div {
    padding-bottom: 20px;
    padding-top: 155px;
  }
}

.vd--payment-content h3 {
  font-size: 28px !important;
  font-weight: 900 !important;
  color: black;
}

/* Phone image container */
.vd--payment-left .vd--payment-content>.container>.row>.col-md-12.margin-0-tb>div>.image.parbase {
  padding-top: 8px;
}

@media screen and (min-width: 768px) {
  .vd--payment-left .image.parbase:has(.vd--payments-phone-left) {
    transform: translate(50%);
  }

  .vd--payments-phone-left {
    position: relative;
    width: 100%;
    padding-top: 199%;
    transform: translate(0px, 0px);
  }

  .vd--payments-phone-left img {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    object-fit: contain;
  }
}

/* RIGHT CONTAINER consisting of text and phone image */
.vd--payment-right {
  text-align: right;
}

.vd--payment-right>.container {
  padding-right: 0 !important;
  padding-left: 0 !important;
}

@media screen and (min-width: 768px) {
  .vd--payment-right>.container>.row>.col-md-12.margin-0-tb>div {
    display: flex;
    justify-content: space-between;
    position: relative;
  }

  /* Text container width */
  .vd--payment-right .grid:has(.vd--payment-content) {
    width: 64%;
    padding-left: 20px;
  }

  /* Phone image container width */
  .vd--payment-right .image.parbase:has(.vd--payments-phone-right) {
    width: 36%;
  }
}

.vd--payment-right .vd--payment-content p {
  padding-bottom: 24px;
}

/* Logos container */
.vd--payments-logos>.container {
  padding-right: 0 !important;
  padding-left: 0 !important;
}

.vd--payments-logos>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  justify-content: flex-end;
  gap: 24px;
  margin-top: auto;
  width: 100%;
}

.vd--payments-logos>.container>.row>.col-md-12.margin-0-tb>div img {
  height: 40px;
}

@media screen and (min-width: 768px) {

  /* Phone image container */
  .vd--payment-right .image.parbase:has(.vd--payments-phone-right) {
    transform: translate(-50%);
  }

  .vd--payments-phone-right {
    position: relative;
    width: 100%;
    padding-top: 199%;
    transform: translate(0px, 0px);
  }

  .vd--payments-phone-right img {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    object-fit: contain;
  }

  .vd--payment-dots {
    display: none;
  }
}

@media screen and (max-width: 767.98px) {
  .vd--payment-section .image.parbase img {
    height: 200px;
  }

  .vd--payments-phone-left,
  .vd--payments-phone-right {
    transform: none !important;
    display: flex;
    justify-content: center;
  }

  .vd--payment-left>.container>.row>.col-md-12.margin-0-tb>div {
    display: flex;
    flex-direction: column-reverse;
    gap: 32px;
    text-align: center;
  }

  .vd--payment-right>.container>.row>.col-md-12.margin-0-tb>div {
    display: flex;
    flex-direction: column;
    gap: 32px;
    text-align: center;
  }

  .vd--payment-left .vd--payment-content>.container>.row>.col-md-12.margin-0-tb>div,
  .vd--payment-right .vd--payment-content>.container>.row>.col-md-12.margin-0-tb>div {
    align-items: center;
    padding-bottom: 40px;
  }

  .vd--payments-logos>.container>.row>.col-md-12.margin-0-tb>div {
    justify-content: center;
  }

  .vd--payment-right .vd--payment-content>.container>.row>.col-md-12.margin-0-tb>div>.grid {
    margin: 0 auto;
  }

  .vd--payment-right .vd--payment-content p {
    padding-bottom: 0;
  }
}

/***** BENEFITS TAB MODULE *****/
/*-----------------------------*/

.vd--benefits-buttons-wrapper>.container {
  padding: 0 !important;
}

.vd--benefits-buttons-wrapper>.container>.row {
  margin: 0 !important;
}

.vd--benefits-buttons-wrapper>.container>.row>.col-md-12.margin-0-tb {
  padding: 0 !important;
}

.vd--benefits-buttons-wrapper>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  padding: 2rem 0 2rem 0;
}

@media screen and (max-width: 767.98px) {
  .vd--benefits-buttons-wrapper>.container>.row>.col-md-12.margin-0-tb>div {
    flex-wrap: nowrap;
    justify-content: flex-start;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding: 1rem 16px 1rem 16px;
    gap: 12px;
  }

  .vd--benefits-buttons-wrapper>.container>.row>.col-md-12.margin-0-tb>div::-webkit-scrollbar {
    display: none;
  }

  .vd--section:has(.vd--benefits-buttons-wrapper) {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .vd--section > .container:has(.vd--benefits-buttons-wrapper) {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .vd--benefit-overview-details-wrapper {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
}



/* Tab Buttons */
.vd--benefit-overview-button {
  background-color: white;
  border-radius: 50px;
  box-shadow: 0px 0px 24px 0px rgba(0, 0, 0, 0.08);
  cursor: pointer;
  display: flex;
  align-items: center;
}

.vd--benefit-overview-button .heading-4 {
  font-size: 16px;
  font-weight: 500;
  line-height: 22px;
  color: #000;
  white-space: nowrap;
}

.vd--benefit-overview-button:hover .heading-4 {
  color: var(--light-blue) !important;
}

/* Force outline variant only (disable filled-icon hover swap) */
.vd--benefit-overview-button .icon.dls-bright-blue>svg:first-of-type {
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
}

.vd--benefit-overview-button .icon.dls-bright-blue>svg:last-of-type {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
}

.vd--benefit-overview-button>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  flex: 0 1 auto;
  gap: 8px;
  padding: 10px 24px;
  width: auto;
  align-items: center;
  min-height: 40px;
  border-radius: 50px;
}

@media screen and (max-width: 767.98px) {
  .vd--benefit-overview-button>.container>.row>.col-md-12.margin-0-tb>div {
    padding: 10px 16px;
  }
}

.vd--benefit-overview-button div>i>svg {
  width: 20px !important;
  height: 20px !important;
  display: inline-block !important;
}

/* Active state tab buttons*/
.vd--benefit-overview-button.active {
  background-color: var(--light-blue) !important;
  color: #fff !important;
  border-radius: 50px;
  transition:
    background-color 0.25s ease-out,
    color 0.25s ease-out;
}

.vd--benefit-overview-button.active>.container>.row>.col-md-12.margin-0-tb>div,
.vd--benefit-overview-button.active * {
  color: #fff !important;
  fill: #fff !important;
}

.vd--benefit-overview-button.active .image.parbase,
.vd--benefit-overview-button.active .icons.parbase,
.vd--benefit-overview-button.active .image.parbase>.text-align-left,
.vd--benefit-overview-button.active .vd--benefit-overview-button-image,
.vd--benefit-overview-button.active .icon.dls-bright-blue>svg {
  background: transparent !important;
  color: #fff !important;
  fill: #fff !important;
}

/* Wrapper for detail cards */
.vd--benefit-overview-details-wrapper>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  position: relative;
  width: 100%;
  box-sizing: border-box;
  transform: translate(0px, 0px);
  overflow: hidden;
  transition: height 320ms cubic-bezier(0.22, 1, 0.36, 1);
}

/* Detail card */
.vd--benefit-overview-details>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  align-items: stretch;
  background-color: #fff;
  border-radius: 16px;
  box-shadow: 0px 0px 4px 0px rgba(0, 0, 0, 0.08);
  padding: 24px;
  gap: 40px;
  height: auto;
}

@media screen and (max-width: 568px) {
  .vd--benefit-overview-details>.container>.row>.col-md-12.margin-0-tb>div {
    flex-direction: column;
  }

  .vd--benefit-overview-details>.container>.row>.col-md-12.margin-0-tb>div>.image.parbase {
    width: 100% !important;
  }
}

/* Base state detail card: hidden/collapsed */
.vd--benefit-overview-details {
  overflow: visible;
  transform: translateY(30px);
  transform-origin: 50% 50%;
  opacity: 0;
  z-index: 0;
  pointer-events: none;
  will-change: transform, opacity;
  backface-visibility: hidden;
  transition:
    transform 480ms cubic-bezier(0.16, 1, 0.3, 1),
    opacity 520ms cubic-bezier(0.22, 1, 0.36, 1);
  top: 0;
  left: 0;
  width: 100%;
  min-width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

/* Visible state */
.vd--benefit-overview-details.is-active {
  transform: translateY(0);
  opacity: 1;
  z-index: 1;
  pointer-events: auto;
  transition:
    transform 1000ms cubic-bezier(0.16, 1, 0.3, 1),
    opacity 1000ms cubic-bezier(0.22, 1, 0.36, 1);
  margin-bottom: 24px;
}

/* Animate wrapper height for details */
.vd--benefit-overview-details-wrapper {
  position: relative;
  transition: height 420ms cubic-bezier(0.22, 1, 0.36, 1);
}

/* Leaving state for detail card — position: absolute set by JS */
.vd--benefit-overview-details.is-leaving {
  transform: translateY(10px);
  opacity: 0;
  pointer-events: none;
  z-index: 0;
  transition:
    transform 360ms ease-out,
    opacity 360ms ease-out;
}

/* Image in benefit details */
.vd--benefit-overview-details>.container>.row>.col-md-12.margin-0-tb>div>.image.parbase {
  flex: 1 0 auto;
  position: relative;
  height: auto;
  width: 43.3%;
  max-width: 430px;
}

.vd--benefit-overview-details-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  overflow: hidden;
  border-radius: 8px;
  max-height: 230px;
}

/* Max width of content blocks */
.vd--benefits-buttons-wrapper>.container {
  max-width: 1100px !important;
}

.vd--benefit-overview-details-wrapper>.container {
  max-width: 1100px !important;
  padding: 0 !important;
}

.vd--benefit-overview-details>.container {
  padding: 0 !important;
}

/* Text in benefit details */
.vd--benefit-overview-details-text-wrapper {
  flex: 1 1 auto;
}

.vd--benefit-overview-details-text-wrapper>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  justify-content: center;
  flex-direction: column;
  gap: 24px;
  padding-top: 12px;
  padding-bottom: 12px;
  height: 100%;
}

.vd--benefit-overview-details .vd--benefit-overview-details-image {
  height: 100%;
}

.vd--benefit-overview-details-text-wrapper h3 {
  font-size: 28px !important;
  font-weight: 400 !important;
}

.vd--benefit-overview-details>.container>.row>.col-md-12.margin-0-tb>div>.grid {
  display: flex;
  align-items: center;
}

.vd--benefit-overview-details p {
  font-size: 16px !important;
}

/* Button below */
.vd--button-benefit-overview {
  display: flex;
}

.vd--button-benefit-overview a {
  padding-top: 2rem !important;
}

@media screen and (max-width: 568px) {
  .vd--button-benefit-overview a {
    display: flex !important;
    align-items: center;
    text-align: left;
  }

  .vd--button-benefit-overview i {
    min-width: 1.5rem !important;
  }
}

.vd--button-benefit-overview span {
  font-weight: 500 !important;
}

.vd--button-benefit-overview i {
  background: var(--light-blue);
  border-radius: 50%;
  height: 1.5rem !important;
  width: 1.5rem !important;
}

.vd--button-benefit-overview svg {
  height: 1rem !important;
  width: 1rem !important;
  color: white;
}

.vd--button-benefit-overview .btn {
  max-width: none;
}

.vd--button-benefit-overview .btn:hover {
  color: var(--deep-blue);
  background: none;

  i {
    background: var(--deep-blue);
  }
}

/***** TESTIMONIALS *****/
/*----------------------*/

/* Viewport */
.vd--testemonials-slider {
  position: relative;
  height: 372px;
  overflow: hidden;
  max-width: 1100px !important;
}

.vd--testemonials-slider-wrapper {
  flex: 1 1 auto;
  width: 100%;
  display: flex;
  justify-content: center;
}

.vd--testemonials-slider>.container>.row>.col-md-12.margin-0-tb>div {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.vd--testemonial-headline h2 {
  max-width: 600px;
  margin: 0 auto;
}

/* Stack slides and fade */
.vd--testemonials-slider .vd--testemonials-slide,
.vd--testemonials-slider [class^="vd--testemonials-slide-"] {
  position: absolute !important;
  inset: 0;
  opacity: 0;
  transition: opacity 1s ease !important;
  pointer-events: none;
}

.vd--testemonials-slider .vd--testemonials-slide.is-active,
.vd--testemonials-slider [class^="vd--testemonials-slide-"].is-active {
  opacity: 1;
  pointer-events: auto;
}

.vd--testemonials-slide>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  align-items: stretch;
  justify-content: center;
  flex: 1;
  gap: 0;
  padding: 24px;
  background-color: var(--white);
  border-radius: 16px;
  overflow: hidden;
  min-height: 372px;
  max-width: 1100px !important;
}

@media screen and (max-width: 767.98px) {
  .vd--testemonials-slide>.container>.row>.col-md-12.margin-0-tb>div {
    flex-wrap: wrap;
  }
}

.vd--testemonial-image {
  height: 100%;
  width: 100%;
}

.vd--testemonial-image img {
  border-radius: 8px;
  width: 100%;
  height: 100%;
  object-fit: cover;
  overflow: hidden;
}

.vd--testemonials-text>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  gap: 0;
  width: 100%;

  padding: 20px 0 0;
}

@media screen and (min-width: 768px) {
  .vd--testemonials-text>.container>.row>.col-md-12.margin-0-tb>div {
    padding: 20px 8px 0 20px;
    min-height: 324px;
  }
}

.vd--testemonials-text p {
  font-size: 16px !important;
  line-height: 24px !important;
  color: #000;
  margin: 0;
}

.vd--testemonials-text .heading-4 {
  margin-right: 12px;
  font-size: 20px !important;
  line-height: 24px !important;
  
}
@media screen and (max-width: 767.98px) {
  .vd--testemonials-text .heading-4 {
    display: block;
    margin-right: 0; 
  }
  .vd--testemonials-text .legal-1 {
    margin-left: -4px;
  }
}
.vd--testemonials-text .legal-1 {
  font-size: 13px !important;
  line-height: 24px !important;
}

.vd--testemonials-text .richtext.parbase:last-of-type {
  padding-top: 40px;
}

@media screen and (min-width: 768px) {
  .vd--testemonials-text .richtext.parbase:last-of-type {
    margin-top: auto;
  }
}

@media screen and (min-width: 768px) {
  .vd--testemonials-slide .image.parbase {
    aspect-ratio: auto;
    width: 43.3%;
    max-width: 43.3%;
    flex: 0 0 43.3%;
  }
}

.vd--testemonial-slider-buttons {
  bottom: 2rem;
  left: 4rem;
}

.vd--testemonial-slider-buttons>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
}

.vd--arrow-bg .container {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.vd--slider-arrow-left {
  border-radius: 50%;
  background-color: #fff;
  width: 2rem;
  height: 2rem;
  text-align: center !important;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  margin-left: 7px;
}

.vd--slider-arrow-left:hover {
  opacity: 0.7;
}

.vd--slider-arrow-left img {
  width: 1rem;
  height: 1rem;
}

.vd--slider-arrow-right {
  border-radius: 50%;
  background-color: #fff;
  width: 2rem;
  height: 2rem;
  text-align: center !important;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  margin-right: 7px;
}

.vd--slider-arrow-right:hover {
  opacity: 0.7;
}

.vd--slider-arrow-right img {
  width: 1rem;
  height: 1rem;
}

/* TAB MENU */
.container-fluid.pad-0-lr .tab-menu {
  background-color: #ecedee;
  display: flex;
  width: 100%;
}

.container-fluid.pad-0-lr .tab-menu .tab-link {
  flex: 1;
  text-align: center;
  white-space: initial;
  /*Add white-space to tab-link*/
}

.container-fluid.pad-0-lr .tab-menu .tab-link span {
  font-weight: bold;
  display: inline-block;
  /*Remove white space*/
}

.container-fluid.pad-0-lr .tab-menu .tab-link[aria-selected="true"] {
  background-color: var(--deep-blue);
  color: white;
  position: relative;
  border: none;
}

/* STEPS */
.vd--steps-top img{
  max-width: 362px;
}

section:has(>.vd--steps-top) {
  display: flex;
  justify-content: center;
  align-items: center;
}

.vd--steps-top {
  max-width: 800px;
}

.vd--steps-wrapper>.container {
  max-width: 1200px !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.vd--steps-wrapper>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  gap: 24px;
  align-items: stretch;
  justify-content: center;
}

@media screen and (max-width: 767.98px) {
  .vd--steps-wrapper>.container>.row>.col-md-12.margin-0-tb>div {
    flex-direction: column;
  }
}

.vd--steps-wrapper>.container>.row>.col-md-12.margin-0-tb>div>.grid {
  flex: 1 1 0;
  min-width: 0;
}

.vd--steps-wrapper>.container>.row>.col-md-12.margin-0-tb>div>.grid>section {
  height: 100%;
}

.vd--steps-wrapper [class*="vd--step-"] {
  height: 100%;
}

.vd--steps-wrapper [class*="vd--step-"]>.card-img-bg {
  background-color: var(--white) !important;
  border: 1px solid #f4f4f4;
  border-radius: 12px !important;
}

.vd--steps-wrapper [class*="vd--step-"]>.container {
  height: 100%;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.vd--steps-wrapper [class*="vd--step-"]>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  flex-direction: column;
  gap: 24px;
  padding: 20px;
  min-height: 100%;
}

.vd--steps-wrapper [class*="vd--step-"] .icons.parbase {
  width: 40px;
  height: 40px;
}

.vd--steps-wrapper [class*="vd--step-"] .icons.parbase .icon.dls-bright-blue>svg {
  width: 40px !important;
  height: 40px !important;
}

.vd--steps-wrapper [class*="vd--step-"] h3.small {
  font-size: 32px !important;
  font-weight: 500 !important;
  line-height: 1.2 !important;
  margin: 0;
}

.vd--steps-wrapper [class*="vd--step-"] p {
  font-size: 16px !important;
  line-height: 1.5 !important;
  color: #595959;
  margin: 0;
}

.vd--steps .row {
  gap: 2rem;
  justify-content: space-between;
}

.vd--steps .row.pad-3-t.pad-3-b {
  padding-top: 3.5rem !important;
  padding-bottom: 2.5rem !important;
}

.vd--steps .pad-3-t {
  padding-top: 0 !important;
}

.vd--steps .col-md-4 {
  flex: 1;

  display: flex;
  flex-direction: column;
  align-items: center;
}

.vd--steps .pad-3-t.pad-3-b.pad-2-l.pad-2-r {
  width: 100%;
  margin: 0 auto;
}

.vd--steps-icon-list .container {
  width: 100%;
}

.vd--stroke {
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
}

/* CROSS SELL CARD */

.vd--cross-sell-wrapper>.container {
  max-width: 1100px !important;
}

.vd--cross-sell-wrapper>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  align-items: stretch;
  border-radius: 16px;
  overflow: hidden;
}

@media screen and (max-width: 767.98px) {
  .vd--cross-sell-wrapper>.container>.row>.col-md-12.margin-0-tb>div {
    flex-direction: column;
  }
}

@media screen and (min-width: 768px) {
  .vd--cross-sell-wrapper .image.parbase {
    flex: 0 0 43.3%;
    max-width: 43.3%;
    border-radius: 16px 0 0 16px;
    overflow: hidden;
  }
}

.vd--cross-sell-wrapper .vd--cross-sell-image {
  height: 100%;
}

.vd--cross-sell-wrapper .vd--cross-sell-image img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  background-color: var(--deep-blue);
}

.grid:has(> section > .vd--cross-sell-text) {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.vd--cross-sell-wrapper .grid:has(.vd--cross-sell-text) {
  flex: 1 1 auto;
  background-color: var(--white);
}

.vd--cross-sell-wrapper .vd--cross-sell-text>.container {
  height: 100%;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.vd--cross-sell-wrapper .vd--cross-sell-text>.container>.row>.col-md-12.margin-0-tb>div {
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 24px;
  padding: 40px 24px 40px 40px;
}

@media screen and (max-width: 568px) {
  .vd--cross-sell-wrapper .vd--cross-sell-text>.container>.row>.col-md-12.margin-0-tb>div {
    padding: 24px;
  }
}

.vd--cross-sell-wrapper .vd--cross-sell-text .richtext.parbase p {
  margin: 0;
  font-size: 16px;
  line-height: 1.5;
  color: #3d3d3d;
}

.vd--cross-sell-wrapper .vd--cross-sell-text .button.parbase {
  margin: 0;
}

.vd--cross-sell-wrapper .vd--cross-sell-text .vd--button-secondary a {
  min-width: 230px;
  border: 1px solid var(--light-blue);
  border-radius: 4px;
  color: var(--light-blue) !important;
  background: var(--white) !important;
  padding: 17px 25px !important;
}

@media screen and (max-width: 568px) {
  .vd--cross-sell-wrapper .vd--cross-sell-text .vd--button-secondary a {
    min-width: unset;
    white-space: normal;
  }
}

section .vd--cross-sell-card>.container>.row>.col-md-12>div {
  display: flex;
  align-items: center;
  gap: 2rem;
}

.vd--cross-sell-card-image-wrapper .container {
  padding: 0;
  margin: 0;
  width: 390px;
}

.vd--cross-sell-card-image-wrapper img {
  padding: 0;
  margin: 0;
}

/***** POPUP CONTENT *****/
/*----------------------*/

/* Prevent body scroll when panel is open */
body.vd--no-scroll {
  overflow: hidden !important;
}

.vd--popup-host {
  display: none;
}

.vd--popup-host.is-open {
  position: fixed;
  inset: 0;
  z-index: 9999;
  overflow-y: auto;
  width: 100%;
  display: grid;
  place-items: center;
  padding: 24px;
}

.vd--popup-host.is-open .vd--pop-up {
  background: #ececec;
  max-width: 635px;
  width: min(635px, calc(100vw - 48px));
  margin: 0 auto;
  border-radius: 24px;
  overflow: hidden;
}

.vd--popup-host.is-open .vd--pop-up > .container > .row {
  padding: 40px !important;
}

.vd--popup-host.is-open .vd--pop-up-grid > .container > .row > .col-md-12.margin-0-tb > div {
  gap: 40px;
  padding-top: 0;
  padding-bottom: 0;
}

.vd--popup-host.is-open .vd--pop-up-column {
  padding: 10px;
}

.vd--popup-host.is-open .vd--pop-up-column .btn-sm {
  width: 230px;
  min-height: 40px;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
}

.vd--popup-host.is-open .overlay-close-button .btn.btn-secondary {
  width: 200px;
  min-height: 40px;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
}

.vd--popup-host.is-open .overlay-close-button,
.vd--popup-host.is-open .overlay-close-button .close-modal {
  display: flex;
  justify-content: center;
}

@media (max-width: 767.98px) {
  .vd--popup-host.is-open {
    padding: 12px;
  }

  .vd--popup-host.is-open .vd--pop-up {
    width: calc(100vw - 24px);
    border-radius: 16px;
  }

  .vd--popup-host.is-open .vd--pop-up > .container > .row {
    padding: 24px 16px !important;
  }

  .vd--popup-host.is-open .vd--pop-up-grid > .container > .row > .col-md-12.margin-0-tb > div {
    flex-direction: column;
    align-items: center;
    gap: 20px;
  }
}

/* Reveal-on-scroll left inline opacity/translate styles on popup markup */
.vd--popup-host.is-open .vd--pop-up [data-vd-reveal-prepared] {
  opacity: 1 !important;
  translate: 0 0 !important;
  transform: none !important;
}

.vd--pop-up-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  z-index: 9998;
  display: none;
}

.vd--pop-up-backdrop.is-open {
  display: block;
}

/* Backdrop overlay */
.vd--details-overlay {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.4);
  opacity: 0;
  visibility: hidden;
  transition:
    opacity 0.3s ease,
    visibility 0.3s ease;
  z-index: 9998;
}

.vd--details-overlay.is-visible {
  opacity: 1;
  visibility: visible;
}

/* Slide-in panel */
.vd--details-popup {
  position: fixed !important;
  /* override inline */
  top: 0;
  right: -100vw;
  /* keep fully offscreen initially */
  height: 100vh;
  width: 80vw;
  /* ~80% width */
  /* max-width: 1280px; */
  background: #ffffff;
  box-shadow: -12px 0 32px rgba(0, 0, 0, 0.12);
  transition: right 0.35s ease;
  will-change: right;
  z-index: 9999;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overflow-x: hidden;
}

@media screen and (max-width: 767.98px) {
  .vd--details-popup {
    width: 100vw;
  }
}

.vd--details-popup.is-open {
  right: 0;
}


.vd---details-sticky-banner {
  position: sticky !important;
  top: 0;
  right: 0;
  z-index: 100;
  background-color: #fff;
  box-shadow: 0 0 12px rgba(0, 0, 0, 0.08);
  padding: 24px 12px;
}

.vd---details-sticky-banner>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 42px;
}

.vd---details-popup-wrapper>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
}

.vd--details-sticky-button-close .btn {
  color: #8e9092;
}

.vd--details-sticky-button-close a {
  font-weight: 500 !important;
  margin-bottom: 0 !important;
  color: #8e9092 !important;
  min-height: 42px !important;
  display: inline-flex !important;
  align-items: center;
  padding: 13px 0 !important;
  line-height: 16px !important;
  font-size: 16px !important;
}

.vd--details-sticky-button-close:hover {
  .btn {
    opacity: 0.7;
    background: none;
  }
}

.vd---details-sticky-banner-right>.container {
  padding-right: 0 !important;
  padding-left: 0 !important;
}

.vd--details-sticky-button-apply a,
.vd---details-sticky-banner-right .vd--hero-button a {
  font-weight: 500 !important;
  margin-bottom: 0 !important;
  min-height: 42px !important;
  border-radius: 4px !important;
  padding: 13px 17px !important;
  line-height: 16px !important;
  font-size: 16px !important;
  min-width: 160px !important;
}

/* Content */
.vd--details-popup-wrapper>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  flex-direction: column;
  gap: 64px;
  padding: 40px 0px 20px 0px;
}

.vd--details-popup-text>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.vd--details-popup-text h3 {
  font-size: 28px !important;
  font-weight: 900 !important;
  line-height: 1.3 !important;
  color: #000;
}

.vd--details-popup-text h4 {
  font-size: 21px !important;
  font-weight: 500 !important;
  line-height: 1.3 !important;
}

.vd--details-benefit-card p {
  font-size: 12px !important;
  line-height: 1.5 !important;
}

.vd--details-popup-list>.container {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.vd--details-popup-list ul {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-left: 1.5rem;
}

.vd--details-benefit-card-wrapper {
  margin-top: 16px;
}

.vd--details-benefit-card-wrapper>.container {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.vd--details-benefit-card-wrapper>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 24px;
}

.vd--details-benefit-card .card-img-bg {
  border-radius: 12px;
}

.vd--details-benefit-card>.container {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

@media screen and (min-width: 800px) {

  /* Desktop: Always 3 cards per row - target the .grid wrapper that contains each card */
  .vd--details-benefit-card-wrapper>.container>.row>.col-md-12.margin-0-tb>div>.grid {
    flex: 0 0 calc((100% - 48px) / 3);
    min-width: 0;
    max-width: calc((100% - 48px) / 3);
  }
}

.vd--details-benefit-card-wrapper>.container>.row>.col-md-12.margin-0-tb>div>.grid section {
  height: 100%;
}

.vd--details-benefit-card-wrapper>.container>.row>.col-md-12.margin-0-tb>div>.grid section .vd--details-benefit-card {
  height: 100%;
}

.vd--details-benefit-card>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 24px;
  width: 100%;
}

.vd--details-benefit-card .image.parbase {
  height: 43.5px;
}

.vd--details-benefit-card:has(h4) ul {
  margin-bottom: 0;
}

/* Box with card at the bottom */

.vd--details-cta-content .pad {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.vd--details-cta-content .vd--hero-button {
  margin-top: 2.5rem;
}

.vd--details-cta-content>.container {
  background-color: #f7f8f9;
  border-radius: 16px;
  padding: 100px 32px 40px 32px !important;
  margin-top: 3rem;
}

.vd--details-cta-content>.container>.row>.col-md-12.margin-0-tb>div {
  position: relative;
}

.vd--details-cta-text {
  max-width: 750px;
  margin: 0 auto;
}

.vd--details-popup-text>.container>.row>.col-md-12.margin-0-tb>div>.richtext.parbase:nth-child(2)>div>ul {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-left: 1.5rem;
}

.vd--details-cta-card {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: 362px;
  margin: -180px auto 4px;
}

.vd--details-cta-ribbon {
  max-width: 233px;
  position: absolute;
  top: -60px;
  right: -70px;
  width: 20vw;
}

.vd--details-popup .container {
  max-width: unset !important;
}

.vd--details-popup>.container,
.vd--details-popup__scroll>.container>.row>.col-md-12.margin-0-tb,
.vd--details-popup-wrapper>.container,
.vd--details-popup-wrapper>.container>.row>.col-md-12.margin-0-tb,
.vd--details-popup-text>.container,
.vd--details-popup-text>.container>.row>.col-md-12.margin-0-tb,
.vd---details-sticky-banner>.container>.row>.col-md-12.margin-0-tb,
.vd---details-sticky-banner-left>.container {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.vd--details-popup__scroll>.container>.row,
.vd--details-popup-wrapper>.container>.row,
.vd--details-popup-text>.container>.row,
.vd---details-sticky-banner>.container>.row {
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.vd---details-sticky-banner>.container,
.vd--details-popup__scroll>.container {
  padding-left: 32px !important;
  padding-right: 32px !important;
}

@media screen and (max-width: 767.98px) {

  .vd---details-sticky-banner>.container,
  .vd--details-popup__scroll>.container {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
}

/***** HELP BUBBLE *****/
/*---------------------*/

.vd--questions-wrapper {
  position: fixed !important;
  z-index: 29;
  bottom: 2.5rem;
  width: 100%;
  padding: 0 2.5rem !important;
  pointer-events: none;
}

@media screen and (max-width: 767.98px) {
  .vd--questions-wrapper {
    bottom: 0.5rem;
    padding: 0 16px !important;
  }
}

.vd--questions-wrapper>.container {
  padding-right: 0 !important;
  padding-left: 0 !important;
  margin-right: 0 !important;
}

.vd--questions-wrapper>.container>.row>.col-md-12.margin-0-tb>div {
  position: relative;
  display: flex;
  justify-content: flex-end;
}

.vd--questions-wrapper>.container>.row>.col-md-12.margin-0-tb>div>.grid {
  position: absolute;
  bottom: 56px;
  right: 1rem;
  z-index: -1;
}

.vd--questions-button {
  width: 112px;
  pointer-events: auto;
  cursor: pointer;
}

.vd--questions-button-phone {
  visibility: hidden;
  width: 0;
}

.vd--questions-button:hover {
  scale: 1.45;
  transition: scale 0.25s ease-in-out;
}

/* Questions overlay and popup visibility */
.vd--questions-overlay {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.4);
  opacity: 0;
  visibility: hidden;
  transition:
    opacity 0.3s ease,
    visibility 0.3s ease;
  z-index: 28;
  /* below wrapper (29), above page content */
}

.vd--questions-overlay.is-visible {
  opacity: 1;
  visibility: visible;
}

.vd--questions-button {
  transition: scale 0.25s ease-in-out;
}

.vd--questions-button.is-active {
  scale: 1.45;
}

/* swap button visuals when questions are open */
.vd--questions-wrapper.questions-open .vd--questions-button {
  visibility: hidden;
  width: 0;
}

.vd--questions-wrapper.questions-open .vd--questions-button-phone {
  visibility: visible;
  width: 112px;
  scale: 1.45;
}

/* fade-in grid content when active */
.vd--questions-wrapper>.container>.row>.col-md-12.margin-0-tb>div>.grid {
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s ease-in-out;
}

.vd--questions-wrapper>.container>.row>.col-md-12.margin-0-tb>div>.grid.is-open {
  opacity: 1;
  pointer-events: auto;
}

.vd--questions-popup .container {
  width: 310px;
  padding: 18px 16px !important;
  background-color: #fff;
  border-radius: 8px;
}

.vd--questions-popup .container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.vd--questions-popup .container>.row>.col-md-12.margin-0-tb>div>.richtext.parbase:nth-child(2) p {
  padding-right: 6px;
}

.vd--questions-popup p {
  line-height: 1.25 !important;
}

/***** POPUP *****/
/*---------------*/

.dls-white-bg.modal-width-2.text-align-center.dls-gray-05.pad-3 {
  border-radius: 16px;
}

.vd--pop-up>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  flex-direction: column;
  /* gap: 1rem; */
}

.vd--pop-up>.container>.row {
  padding: 1.5rem 1rem !important;
}

.vd--pop-up-grid>.container>.row>.col-md-12.margin-0-tb>div {
  display: flex;
  flex-direction: row;
  justify-content: center;
  gap: 2.5rem;
  padding-top: 1rem;
  padding-bottom: 0.5rem;
}

.vd--pop-up-grid .grid:has(.vd--pop-up-column-left) {
  flex: 1;
}

.vd--pop-up-grid .grid:has(.vd--pop-up-column-right) {
  flex: 1;
}

.vd--pop-up-column-left>.container {
  padding-right: 0 !important;
  padding-left: 0 !important;
}

.vd--pop-up-column-right>.container {
  padding-right: 0 !important;
  padding-left: 0 !important;
}

.vd--pop-up h1 {
  font-size: 36px !important;
}

.vd--pop-up-column-right .richtext.parbase .pad-1-t.pad-1-b {
  padding-top: 6px !important;
  padding-bottom: 16px !important;
}

.vd--pop-up-column-right .richtext.parbase .pad-1-t.pad-1-b p b {
  white-space: nowrap;
  font-size: 15px;
}

.vd--pop-up-column-left .richtext.parbase .pad-1-t.pad-1-b {
  padding-top: 6px !important;
  padding-bottom: 16px !important;
}

.vd--pop-up-column-left .richtext.parbase .pad-1-t.pad-1-b p b {
  white-space: nowrap;
  font-size: 15px;
}

/* Accessibility-friendly focus handling: hide mouse click outline, keep keyboard focus */
.btn:focus:not(:focus-visible),
button:focus:not(:focus-visible),
a:focus:not(:focus-visible) {
  outline: none !important;
  box-shadow: none !important;
}

#mobileMenuFooter+hr {
  width: auto;
  padding: 0 !important;
}

/* Specific image spacing */
img[src*="ddbwi.webp"],
img[data-src*="ddbwi.webp"] {
  margin: 40px 0 20px 0;
}

img[src*="zahlungsziel-timeline-mobile.webp"] {
  width: 200px;
}

/* Hero image loader */
.vd--hero-loader {
  position: absolute;
  inset: 0;
  background: rgba(0, 20, 60, 0.55);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  transition: opacity 500ms ease;
  opacity: 1;
  top: 0;
  bottom: 0;
}

.vd--hero-loader.is-hidden {
  opacity: 0;
}

.vd--hero-loader::after {
  content: "";
  width: 52px;
  height: 52px;
  border: 3px solid rgba(255, 255, 255, 0.18);
  border-top-color: #ffffff;
  border-radius: 50%;
  animation: vd-hero-spin 0.75s linear infinite;
  flex-shrink: 0;
}

@keyframes vd-hero-spin {
  to {
    transform: rotate(360deg);
  }
}

.modal-screen {
  height: 100vh;
}