.wertstrom-page {
  --ws-navy: #000936;
  --ws-navy-soft: #071345;
  --ws-blue: #b0deed;
  --ws-blue-pale: #edf8fb;
  --ws-pink: #c01466;
  --ws-pink-pale: #efbfd8;
  --ws-pink-mid: #d76ca7;
  --ws-white: #ffffff;
  --ws-ink: #000936;
  overflow: hidden;
  background: rgba(176, 222, 237, 0.1);
  color: var(--ws-ink);
  font-family: "Ubuntu", Arial, sans-serif;
  line-height: 1.22;
  max-width: 100%;
  overflow-wrap: break-word;
}

/* Digitaler Produktpass page */
.dpp-page {
  --dpp-navy: #000936;
  --dpp-cyan: #2fc7cf;
  --dpp-blue: #1168ff;
  --dpp-purple: #9f4be8;
  --dpp-text: #ffffff;
  --dpp-muted: rgba(255, 255, 255, 0.78);
  background: var(--dpp-navy);
  color: var(--dpp-text);
  min-height: 100vh;
}

.dpp-page .ws-section {
  background: var(--dpp-navy);
  overflow: hidden;
  padding: 0;
}

.dpp-page .ws-container {
  max-width: 1030px;
  padding: 0;
  width: min(1030px, calc(100vw - 56px));
}

.dpp-page h1,
.dpp-page h2,
.dpp-page h3,
.dpp-page p,
.dpp-page li {
  color: var(--dpp-text);
}

.dpp-page h1,
.dpp-page h2 {
  letter-spacing: 0;
}

.dpp-page p {
  color: var(--dpp-muted);
  line-height: 1.08;
}

.dpp-orb {
  opacity: 0.95;
  z-index: 0;
}

.dpp-diagram {
  margin: 0;
  position: relative;
  z-index: 2;
}

.dpp-diagram img {
  height: auto;
  max-width: none;
  width: 100%;
}

.dpp-hero {
  min-height: 720px;
  padding-top: 50px !important;
}

.dpp-hero-container {
  min-height: 500px;
}

.dpp-orb-hero {
  right: -90px;
  top: -20px;
  width: min(760px, 60vw);
  z-index: 1 !important;
}

.dpp-hero-copy {
  margin-left: 165px;
  position: relative;
  z-index: 2;
}

.dpp-hero-copy h1 {
  font-size: clamp(4.4rem, 6.6vw, 7.2rem) !important;
  line-height: 0.94;
  max-width: 620px;
}

.dpp-hero-copy h1 span {
  color: var(--dpp-blue);
}

.dpp-hero-lead {
  font-size: clamp(2.1rem, 3.2vw, 3.4rem) !important;
  line-height: 1.03 !important;
  margin-top: 22px !important;
  max-width: 600px;
}

.dpp-context {
  min-height: 1120px;
  padding-top: 10px !important;
}

.dpp-intro {
  margin-left: 25px;
  max-width: 450px;
  position: relative;
  z-index: 3;
}

.dpp-step {
  align-items: center;
  background: var(--dpp-cyan);
  border-radius: 50%;
  color: var(--dpp-navy) !important;
  display: inline-flex;
  height: 30px;
  justify-content: center;
  line-height: 1;
  margin-bottom: 18px !important;
  width: 30px;
}

.dpp-kicker {
  color: var(--dpp-cyan) !important;
  letter-spacing: 0;
}

.dpp-kicker-2 {
  color: var(--dpp-blue) !important;
  letter-spacing: 0;
}

.dpp-kicker-2 span {
  color: #fff !important;
}

.dpp-intro h2,
.dpp-cost-copy h2,
.dpp-center-copy h2 {
  line-height: 1.03;
}

.dpp-intro h2 {
  font-size: clamp(2.1rem, 3.4vw, 3.5rem) !important;
}

.dpp-intro h2 span,
.dpp-cost-copy h2 span,
.dpp-flumen-copy h2 span {
  color: var(--dpp-blue);
}

.dpp-copy {
  margin-top: 14px !important;
  max-width: 340px;
}

.dpp-proof-list {
  display: grid;
  gap: 14px;
  list-style: none;
  margin: 34px 0 0;
  max-width: 420px;
  padding: 0 !important;
}

.dpp-proof-list li {
  align-items: center;
  border: 1px solid rgba(47, 199, 207, 0.9);
  border-radius: 999px;
  color: var(--dpp-cyan);
  display: flex;
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: 0.95rem;
  line-height: 1.1;
  min-height: 48px;
  padding: 9px 18px 9px 56px;
  position: relative;
}

.dpp-proof-list li::before {
  align-items: center;
  border: 1px solid var(--dpp-cyan);
  border-radius: 50%;
  color: var(--dpp-cyan);
  content: "✓";
  display: inline-flex;
  font-size: 0.75rem;
  height: 24px;
  justify-content: center;
  left: 18px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 24px;
}

.dpp-note {
  color: var(--dpp-cyan) !important;
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-style: italic;
  line-height: 1.05 !important;
}

.dpp-note-blue {
  color: #0964ff !important;
  margin-top: 48px !important;
  transform: rotate(-7deg);
}

.dpp-lifecycle {
  margin: 20px 0 0 0;
  width: min(1025px, 112vw);
}

.dpp-cost {
  min-height: 1000px;
  padding-top: 20px !important;
}

.dpp-cost-copy {
  margin-left: 130px;
  max-width: 610px;
  position: relative;
  z-index: 3;
}

.dpp-cost-copy h2 {
  font-size: clamp(3.3rem, 4.8vw, 5.2rem) !important;
}

.dpp-cost-copy .dpp-copy {
  font-size: clamp(1.15rem, 1.7vw, 1.8rem) !important;
  max-width: 620px;
}

.dpp-expensive {
  margin: 55px auto 0;
  width: min(874px, 92vw);
}

.dpp-describes {
  min-height: 880px;
  padding-top: 72px !important;
}

.dpp-orb-left {
  left: 0;
  width: min(400px, 20vw);
  z-index: 1 !important;
}

.dpp-center-copy {
  margin: 0 auto;
  position: relative;
  text-align: center;
  z-index: 3;
}

.dpp-center-copy-2 {
  margin: 0 auto;
  position: relative;
  text-align: center;
  z-index: 3;
}

.dpp-center-copy h2 {
  font-size: clamp(3.2rem, 5vw, 5.6rem) !important;
}

.dpp-center-copy h2 span {
  color: var(--dpp-cyan);
}

.dpp-product-cards {
  margin: 48px auto 0;
  width: min(696px, 82vw);
}

.dpp-open-pass {
  min-height: 1130px;
  padding-top: 55px !important;
}

.dpp-orb-open {
  right: 0;
  width: min(560px, 30vw);
  z-index: 1 !important;
}

.dpp-pass-flow {
  margin-left: -55px;
  width: min(1089px, 112vw);
}

.dpp-flumen {
  min-height: auto;
  padding-top: 90px !important;
  padding-bottom: 140px !important;
}

.dpp-orb-bottom {
  left: 0;
  width: min(500px, 20vw);
  z-index: 1 !important;
  margin-top: min(800px, 80vmin);
}

.dpp-flumen-copy {
  margin-left: 120px;
  max-width: 560px;
  position: relative;
  z-index: 3;
}

.dpp-flumen-copy .dpp-note {
  margin: 0 0 18px !important;
}

.dpp-flumen-copy h2 {
  font-size: clamp(3.6rem, 5.4vw, 6rem) !important;
  line-height: 0.96;
}

.dpp-flumen-sub {
  color: var(--dpp-cyan) !important;
  margin-top: 20px !important;
}

.dpp-flumen-art {
  margin: 0 auto;
  width: min(953px, 100vw);
}

@media (max-width: 1180px) {
  .dpp-page .ws-container {
    width: min(920px, calc(100vw - 44px));
  }

  .dpp-hero-copy {
    margin-left: 105px;
  }

  .dpp-lifecycle {
    width: min(1025px, 108vw);
  }

  .dpp-cost-copy {
    margin-left: 70px;
  }

  .dpp-pass-flow {
    margin-left: -70px;
    width: min(1089px, 115vw);
  }
}

@media (max-width: 991.98px) {
  .dpp-page .ws-container {
    width: min(720px, calc(100vw - 42px));
  }

  .dpp-hero {
    min-height: 610px;
    padding-top: 80px !important;
  }

  .dpp-orb-hero {
    right: -210px;
    width: 620px;
  }

  .dpp-hero-copy,
  .dpp-intro,
  .dpp-cost-copy,
  .dpp-flumen-copy {
    margin-left: 0;
  }

  .dpp-lifecycle,
  .dpp-pass-flow,
  .dpp-flumen-art {
    margin-left: 0;
    width: 100%;
  }

  .dpp-lifecycle {
    /* margin-top: 55px; */
  }

  .dpp-context,
  .dpp-cost,
  .dpp-describes,
  .dpp-open-pass,
  .dpp-flumen {
    min-height: auto;
    padding-bottom: 90px !important;
  }

  .dpp-expensive {
    width: 100%;
  }

  .dpp-pass-flow {
    margin-top: 20px;
  }
}

@media (max-width: 680px) {
  .dpp-page .ws-container {
    width: min(340px, calc(100vw - 32px));
  }

  .dpp-page h1,
  .dpp-page h2,
  .dpp-page h3 {
    overflow-wrap: normal;
    word-break: normal;
  }

  .dpp-hero {
    min-height: 520px;
    padding-top: 80px !important;
  }

  .dpp-orb-hero {
    right: -255px;
    top: 12px;
    width: 520px;
  }

  .dpp-hero-copy h1 {
    font-size: 3rem !important;
    max-width: 250px;
  }

  .dpp-hero-lead {
    font-size: 1.65rem !important;
    max-width: 400px;
  }

  .dpp-intro h2,
  .dpp-cost-copy h2 {
    font-size: 2.3rem !important;
  }

  .dpp-context {
    padding-top: 25px !important;
    padding-bottom: 235px !important;
  }

  .dpp-proof-list li {
    border-radius: 20px;
    min-height: 54px;
  }

  .dpp-note-blue {
    font-size: 1.55rem !important;
    margin-left: 16px !important;
  }

  .dpp-lifecycle {
    /* margin-top: 40px; */
    transform: none;
    transform-origin: top center;
  }

  .dpp-cost-copy {
    max-width: 315px;
  }

  .dpp-cost-copy .dpp-copy {
    font-size: 1.05rem !important;
  }

  .dpp-describes {
    padding-top: 45px !important;
  }

  .dpp-orb-left {
    left: 0;
    opacity: 0.82;
    width: 300px;
  }

  .dpp-center-copy h2,
  .dpp-flumen-copy h2 {
    font-size: 2.45rem !important;
  }

  .dpp-product-cards {
    width: 100%;
  }

  .dpp-open-pass {
    padding-top: 20px !important;
    padding-bottom: 170px !important;
  }

  .dpp-orb-open {
    width: 320px;
  }

  .dpp-pass-flow {
    transform: none;
    transform-origin: top center;
  }

  .dpp-flumen {
    padding-top: 44px !important;
    padding-bottom: 95px !important;
  }

  .dpp-flumen-art {
    margin-top: 24px;
    transform: none;
    transform-origin: top center;
  }

  .dpp-orb-bottom {
    width: 460px;
  }
}

.wertstrom-page *,
.wertstrom-page *::before,
.wertstrom-page *::after {
  box-sizing: border-box;
}

.wertstrom-page img {
  display: block;
  max-width: 100%;
}

.wertstrom-page p,
.wertstrom-page h1,
.wertstrom-page h2,
.wertstrom-page h3,
.wertstrom-page h4,
.wertstrom-page ul,
.wertstrom-page blockquote {
  margin: 0;
}

.wertstrom-page ul {
  padding-left: 1.15rem;
}

.wertstrom-page li+li {
  margin-top: 0.18rem;
}

.wertstrom-page strong {
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
}

.wertstrom-page h1,
.wertstrom-page h2,
.wertstrom-page h3,
.wertstrom-page h4 {
  color: var(--ws-navy);
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-weight: 900;
  letter-spacing: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.wertstrom-page h1 {
  font-size: 6.1rem;
  line-height: 0.92;
}

.wertstrom-page h2 {
  font-size: 4.5rem;
  line-height: 1.02;
}

.wertstrom-page h3 {
  font-size: 2.35rem;
  line-height: 1.08;
}

.wertstrom-page h4 {
  font-size: 1.08rem;
  line-height: 1.13;
}

.wertstrom-page span,
.wertstrom-page .ws-blue {
  color: var(--ws-blue);
}

.wertstrom-page .ws-pink-line,
.wertstrom-page .ws-practice span,
.wertstrom-page .ws-today-main span,
.wertstrom-page .ws-model span,
.wertstrom-page .ws-visible h2 span {
  color: var(--ws-pink);
}

.ws-section {
  position: relative;
  overflow: hidden;
  padding: 1rem 0 7.5rem 0;
}

.ws-container {
  position: relative;
  z-index: 2;
  width: min(1400px, calc(100% - 44px));
  margin: 0 auto;
  padding: 0 10vmin;
}

.ws-container>*,
.ws-two-col>*,
.ws-today-grid>*,
.ws-model-grid>*,
.ws-visible-grid>* {
  min-width: 0;
}

.ws-center {
  text-align: center;
}

.ws-bg,
.ws-grid-bg {
  position: absolute;
  z-index: 0;
  pointer-events: none;
  user-select: none;
}

.ws-bg-hero {
  top: 18.5rem;
  left: 0;
  width: 100%;
  min-width: 1280px;
  opacity: 0.92;
}

.ws-bg-understand {
  /* top: -8rem;
  right: -12rem;
  width: 1320px;
  opacity: 0.5;
  transform: rotate(7deg); */
  width: 100%;
}

.ws-bg-fah-top {
  width: 35%;
  right: 0;
  top: 0;
}

.ws-bg-invisible {
  top: -2rem;
  left: 50%;
  width: 1380px;
  opacity: 0.58;
  transform: translateX(-50%);
}

.ws-bg-system {
  top: 0;
  left: 50%;
  width: 1280px;
  opacity: 0.95;
  transform: translateX(-50%);
}

.ws-blue-mark {
  /* position: absolute;
  z-index: 1;
  top: 17.4rem; */
  left: 0;
  width: fit-content;
  height: fit-content;
  display: flex;
  align-items: center;
  background: var(--ws-blue);
  color: var(--ws-navy);
  padding: 1.2rem;
  margin-top: 1rem;
}

.ws-red-mark {
  /* position: absolute;
  z-index: 1;
  top: 17.4rem; */
  left: 0;
  width: fit-content;
  height: fit-content;
  display: flex;
  align-items: center;
  background: var(--ws-pink);
  color: var(--ws-white);
  padding: 1.2rem;
  margin-top: 1.5rem;
}

.ws-white-mark {
  /* position: absolute;
  z-index: 1;
  top: 17.4rem; */
  left: 0;
  width: fit-content;
  height: fit-content;
  display: flex;
  align-items: center;
  background: var(--ws-white);
  color: var(--ws-navy);
  padding: 1.2rem;
  margin-top: 1.5rem;
  position: sticky;
  z-index: 999;
}

.ws-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0.75rem 1.5rem;
  border-radius: 999px;
  background: var(--ws-navy);
  color: var(--ws-blue);
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: 0.95rem;
  text-decoration: none;
  transition: transform 180ms ease, background-color 180ms ease, color 180ms ease;
  text-align: center;
}

.ws-button:hover,
.ws-button:focus-visible {
  color: var(--ws-white);
  background: var(--ws-pink);
  text-decoration: none;
  transform: translateY(-2px);
}

.ws-button-dark {
  background: #3f3f3f;
  color: var(--ws-blue);
}

.ws-hero {
  min-height: 1120px;
  /* padding-top: 9.4rem; */
}

.ws-hero-grid {
  position: relative;
}

.ws-case-label {
  color: var(--ws-navy);
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: 1.05rem;
  line-height: 1.55;
}

.ws-case-label span {
  display: block;
  color: var(--ws-navy);
}

.ws-hero-copy {
  max-width: 1250px;
  padding-left: 2.6rem;
}

.ws-kicker {
  color: var(--ws-navy);
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: 2.85rem;
  line-height: 1.08;
  margin-bottom: 1.2rem;
}

.ws-hero-copy h2 {
  max-width: 960px;
  margin-top: 1.4rem;
  font-size: 3rem;
  line-height: 1.03;
}

.ws-lead-block {
  max-width: 650px;
  margin-top: 1.25rem;
  font-size: 1.15rem;
  color: var(--ws-navy);
}

.ws-lead-block p+p {
  margin-top: 1.05rem;
}

.ws-lead {
  font-size: 1.75rem;
}

.ws-traits {
  margin-top: 4.6rem;
  color: var(--ws-navy);
  font-size: 1.13rem;
}

.ws-hero .ws-button {
  margin-top: 1rem;
}

.ws-hero-note {
  position: absolute;
  right: 0;
  top: 36.5rem;
  text-align: center;
  color: var(--ws-navy);
}

.ws-hero-note h3 {
  font-size: 1.25rem;
}

.ws-hero-note p {
  max-width: 300px;
  margin-top: 1.2rem;
  font-size: 1.12rem;
}

.ws-two-col {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
  gap: 5.5rem;
}

.ws-align-start {
  align-items: start;
}

.ws-understand {
  padding-top: 4rem;
}

.ws-understand-main h2 {
  max-width: 760px;
}

.ws-understand-main h3 {
  max-width: 660px;
  margin-top: 1rem;
}

.ws-excellence-grid {
  display: grid;
  grid-template-columns: 0.78fr 1.22fr;
  gap: 2.2rem;
  margin-top: 2rem;
  color: var(--ws-navy);
}

.ws-bold-lines {
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
}

.ws-bold-lines p+p,
.ws-excellence-grid p+p,
.ws-argument p+p,
.ws-chain-copy p+p,
.ws-system-copy p+p,
.ws-model-grid p+p {
  margin-top: 1rem;
}

.ws-argument {
  max-width: 470px;
  margin-top: 3.4rem;
}

.ws-argument h3 {
  margin-bottom: 1rem;
  font-size: 1.8rem;
}

.ws-visible {
  padding-top: 25rem;
}

.ws-visible h2 {
  max-width: 520px;
  margin-bottom: 1.4rem;
  font-size: 3.8rem;
}

.ws-visible-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.5rem 2.2rem;
}

.ws-visible-grid article,
.ws-phase-grid article,
.ws-model-grid article,
.ws-system-copy article {
  color: var(--ws-navy);
  font-size: 0.98rem;
}

.ws-visible-grid h4,
.ws-phase-grid h4,
.ws-model-grid h3,
.ws-system-copy h4 {
  margin-bottom: 0.45rem;
}

.ws-visible-grid p+p,
.ws-visible-grid ul+p,
.ws-visible-grid p+ul,
.ws-phase-grid p+ul,
.ws-phase-grid ul+p,
.ws-phase-grid h4+p {
  margin-top: 0.75rem;
}

.ws-today {
  padding-top: 3rem;
}

.ws-today-grid {
  display: grid;
  grid-template-columns: minmax(280px, 0.78fr) minmax(0, 1.22fr);
  gap: 4rem;
  align-items: self-start;
}

.ws-practice {
  align-self: end;
  padding-top: 15vmin;
}

.ws-practice h2 {
  margin-bottom: 1.4rem;
  font-size: 1.8rem;
  line-height: 1.1;
}

.ws-phase-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.1rem 1.4rem;
}

.ws-phase-grid article {
  font-size: 0.93rem;
}

.ws-today-main {
  position: relative;
  text-align: right;
}

.ws-map-img {
  width: min(540px, 80%);
  margin: 0 0 1.6rem auto;
}

.ws-today-main h2 {
  margin-bottom: 1.2rem;
  font-size: 4.8rem;
  line-height: 1.05;
}

.ws-today-main>p {
  /* max-width: 570px; */
  margin: 0 auto;
  font-size: 1.12rem;
}

.ws-today-main blockquote {
  /* max-width: 620px; */
  margin: 1.55rem 0 1.55rem auto;
  padding-left: 1.2rem;
  border-left: 6px solid var(--ws-pink);
  color: var(--ws-navy);
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  text-align: right;
  width: fit-content;
}

.ws-today-main h3 {
  /* max-width: 560px; */
  margin: 1.2rem auto 0;
  font-size: 2rem;
}

.ws-invisible {
  padding-top: 6rem;
  background: rgba(176, 222, 237, 0.1);
}

.ws-invisible h2 {
  margin-bottom: 2rem;
  font-size: 3.8rem;
}

.ws-reason-stack {
  display: grid;
  max-width: 530px;
}

.ws-reason-stack article {
  min-height: 130px;
  padding: 1.55rem 1.7rem;
  background: rgba(176, 222, 237, 0.28);
  color: var(--ws-navy);
}

.ws-reason-stack article:nth-child(even) {
  background: rgba(176, 222, 237, 0.16);
}

.ws-reason-stack article:last-child {
  background: rgba(255, 255, 255, 0.72);
}

.ws-reason-stack h4 {
  margin-bottom: 0.35rem;
  font-size: 1.05rem;
}

.ws-reason-stack p+ul,
.ws-reason-stack ul+p {
  margin-top: 0.75rem;
}

.ws-chain-copy {
  padding-top: 3.1rem;
}

.ws-chain-copy h3 {
  max-width: 420px;
  margin-bottom: 1.2rem;
  font-size: 1.75rem;
}

.ws-chain-copy h2 {
  max-width: 520px;
  margin-top: 2rem;
  font-size: 3.1rem;
}

.ws-system {
  padding-top: 8rem;
  padding-bottom: 8rem;
}

.ws-system-grid {
  display: grid;
  gap: 2.4rem;
}

.ws-system-intro {
  max-width: 990px;
  margin: 0 auto;
}

.ws-system-intro p {
  margin-bottom: 0.8rem;
}

.ws-system-intro h2 {
  font-size: 5.4rem;
}

.ws-system-intro h3 {
  margin-top: 1rem;
  font-size: 1.9rem;
}

.ws-system-copy {
  max-width: 990px;
  margin: 0 auto;
}

.ws-system-copy h3 {
  margin-top: 1.1rem;
  font-size: 1.85rem;
}

.ws-flumen-intro {
  padding-top: 6rem;
  padding-bottom: 8rem;
}

.ws-feature-list {
  display: inline-block;
  margin-bottom: 0.8rem;
  color: var(--ws-navy);
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  text-align: left;
}

.ws-flumen-intro h2 {
  font-size: 8.3rem;
  line-height: 0.86;
}

.ws-flumen-intro h3 {
  margin-top: 0.9rem;
  font-size: 4rem;
}

.ws-large {
  color: var(--ws-navy);
  font-size: 2.95rem;
  line-height: 1.12;
}

.ws-flumen-intro .ws-large {
  max-width: 760px;
  margin: 1.4rem auto 1rem;
}

.ws-flumen-intro p:last-child {
  max-width: 320px;
  margin: 0 auto;
  font-size: 1.55rem;
}

.ws-model {
  padding-top: 5.5rem;
}

.ws-model h2 {
  max-width: 760px;
  margin-bottom: 3rem;
  font-size: 4rem;
}

.ws-model-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 2.2rem;
}

.ws-model-grid h3 {
  color: var(--ws-pink);
  font-size: 1.8rem;
}

.ws-model-grid h3 span {
  color: var(--ws-navy) !important;
  font-size: 1.8rem;
}

.ws-model-grid article:nth-child(2) {
  padding-top: 4.8rem;
}

.ws-comparison {
  padding-top: 7rem;
  padding-bottom: 8rem;
}

.ws-pink-line {
  color: var(--ws-pink);
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: 1.85rem;
  line-height: 1.08;
  margin-bottom: 0.7rem;
}

.ws-comparison h2 {
  max-width: 850px;
  font-size: 4rem;
}

.ws-comparison h3 {
  margin-top: 1rem;
  font-size: 2rem;
}

.ws-compare-card {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 1.7rem;
  background: var(--ws-pink-pale);
}

.ws-compare-card article {
  min-height: 305px;
  padding: 2.2rem 2.4rem;
  color: var(--ws-navy);
}

.ws-compare-card article:first-child {
  background: var(--ws-pink-mid);
}

.ws-compare-card h4 {
  font-size: 1.8rem;
}

.ws-compare-card strong {
  display: block;
  margin: 0.2rem 0 1.45rem;
  color: var(--ws-pink);
}

.ws-compare-card article:first-child strong {
  color: var(--ws-white);
}

.ws-compare-card ul {
  list-style: none;
  padding-left: 0;
}

.ws-closing-line {
  margin-top: 2.1rem;
  color: var(--ws-navy);
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: 2.55rem;
  text-align: center;
}

.ws-valuestore {
  min-height: 1220px;
  padding-top: 12rem;
  padding-bottom: 9rem;
}

.ws-grid-bg {
  top: 7rem;
  left: 50%;
  width: min(900px, 105vw);
  opacity: 0.82;
  transform: translateX(-57%);
}

.ws-valuestore h2 {
  font-size: 4.8rem;
  line-height: 1;
}

.ws-valuestore .ws-large {
  max-width: 680px;
  margin: 1rem auto;
}

.ws-boxed {
  max-width: 520px;
  margin: 1rem auto;
  padding: 0.8rem 1rem;
  border-radius: 8px;
  /* background: rgba(244, 215, 231, 0.72); */
  color: var(--ws-navy);
  font-size: 1.45rem;
  line-height: 1.05;
}

.ws-caption {
  /* max-width: 600px; */
  width: 100%;
  text-align: center;
  margin: 3rem auto 1.3rem;
  color: var(--ws-navy);
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: 1.1rem;
}

.ws-app-grid {
  width: min(740px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}

.ws-app-grid div {
  min-height: 185px;
  border-radius: 8px;
  background: var(--ws-navy);
}

@media (max-width: 1180px) {
  .wertstrom-page h1 {
    font-size: 5.6rem;
  }

  .wertstrom-page h2,
  .ws-model h2,
  .ws-comparison h2 {
    font-size: 3.4rem;
  }

  .ws-kicker,
  .ws-hero-copy h2,
  .ws-visible h2,
  .ws-invisible h2 {
    font-size: 3rem;
  }

  .ws-hero-copy {
    /* padding-left: 2.5rem; */
  }

  .ws-two-col,
  .ws-today-grid {
    gap: 3rem;
  }
}

@media (max-width: 980px) {
  .ws-section {
    padding: 5.5rem 0;
  }

  .ws-hero {
    min-height: auto;
    padding-top: 6rem;
  }

  .ws-hero-grid,
  .ws-two-col,
  .ws-today-grid,
  .ws-compare-card {
    grid-template-columns: 1fr;
  }

  .ws-hero-copy {
    max-width: 100%;
    padding-left: 0;
  }

  .ws-hero-note {
    position: static;
    margin-top: 2rem;
    text-align: left;
  }

  .ws-visible {
    padding-top: 1rem;
  }

  .ws-excellence-grid,
  .ws-model-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ws-model-grid article:nth-child(2) {
    padding-top: 0;
  }

  .ws-today-main {
    order: -1;
  }

  .ws-map-img {
    margin-right: auto;
  }

  .ws-chain-copy {
    padding-top: 0;
  }
}

@media (max-width: 680px) {
  .ws-container {
    width: min(calc(100vw - 28px), 362px);
    max-width: min(calc(100vw - 28px), 362px);
    margin-left: 14px;
    margin-right: auto;
  }

  .wertstrom-page {
    width: 100vw;
    max-width: 100vw;
  }

  .wertstrom-page {
    line-height: 1.3;
  }

  .wertstrom-page h1 {
    font-size: 2.45rem;
    line-height: 1.02;
  }

  .wertstrom-page h2,
  .ws-visible h2,
  .ws-invisible h2,
  .ws-model h2,
  .ws-comparison h2,
  .ws-system-intro h2,
  .ws-today-main h2 {
    font-size: 2.1rem;
    line-height: 1.08;
  }

  .ws-kicker,
  .ws-hero-copy h2 {
    font-size: 2rem;
    line-height: 1.12;
  }

  .wertstrom-page h3,
  .ws-understand-main h3,
  .ws-today-main h3,
  .ws-flumen-intro h3 {
    font-size: 1.65rem;
  }

  .ws-section {
    padding: 4.2rem 0;
  }

  .ws-hero {
    padding-top: 5rem;
  }

  .ws-blue-mark,
  .ws-red-mark,
  .ws-white-mark {
    top: 15rem;
    width: 126px;
    height: 34px;
  }

  .ws-bg-hero {
    top: 20rem;
    left: -310px;
    min-width: 900px;
  }

  .ws-lead {
    font-size: 1.35rem;
  }

  .ws-traits {
    margin-top: 2.6rem;
  }

  .ws-excellence-grid,
  .ws-visible-grid,
  .ws-phase-grid,
  .ws-model-grid {
    grid-template-columns: 1fr;
  }

  .ws-reason-stack article {
    padding: 1.2rem 1.15rem;
  }

  .ws-system-intro h2 {
    font-size: 3rem;
  }

  .ws-flumen-intro h2 {
    font-size: 4.7rem;
  }

  .ws-large {
    font-size: 2rem;
  }

  .ws-comparison h3 {
    font-size: 1.55rem;
  }

  .ws-compare-card article {
    min-height: auto;
    padding: 1.5rem;
  }

  .ws-closing-line {
    font-size: 1.8rem;
  }

  .ws-valuestore {
    min-height: auto;
    padding-top: 7rem;
  }

  .ws-valuestore h2 {
    font-size: 3.2rem;
  }

  .ws-grid-bg {
    top: 4rem;
    width: 690px;
    transform: translateX(-62%);
  }

  .ws-boxed {
    font-size: 1.05rem;
  }

  .ws-app-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }

  .ws-app-grid div {
    min-height: 125px;
  }
}

.fehlteile-page {
  --ft-navy: #010a2d;
  --ft-blue: #b0deed;
  --ft-pink: #c01466;
  --ft-white: #ffffff;
  background: var(--ft-navy);
  color: var(--ft-white);
}

.fehlteile-page h1,
.fehlteile-page h2,
.fehlteile-page h3,
.fehlteile-page h4 {
  color: var(--ft-white);
}

.fehlteile-page span,
.fehlteile-page .ft-pink {
  color: var(--ft-pink);
}

.fehlteile-page .ft-blue {
  color: var(--ft-blue);
}

.fehlteile-page p,
.fehlteile-page li {
  color: inherit;
}

.fehlteile-page .ws-section {
  background: var(--ft-navy);
}

.ft-bg {
  width: min(1180px, 106vw);
  opacity: 0.95;
}

.ft-bg-hero {
  top: 0;
  right: -5.5rem;
}

.ft-bg-left {
  top: -8rem;
  left: -24rem;
  transform: rotate(3deg);
}

.ft-bg-mid {
  top: -7rem;
  left: -14rem;
  width: min(1000px, 96vw);
  opacity: 0.54;
  transform: rotate(180deg);
}

.ft-bg-waves {
  top: 0;
  /* left: 50%; */
  width: 100%;
  /* min-width: 1280px;
  opacity: 1;
  transform: translateX(-50%); */
}

.ws-flow-arrow {
  margin-bottom: 1rem;
}

.ws-flow-arrow-2 {
  margin: 3rem 0;
}

.ws-flow-arrow-3 {
  margin: 3rem auto;
  width: 80%;
  display: flex;
  justify-content: center;
}

.ws-flow-arrow-4 {
  margin: 0 auto;
  width: 80%;
  display: flex;
  justify-content: center;
}


.ft-hero {
  min-height: 1130px;
  /* padding-top: 9rem; */
}

.ft-hero-grid {
  min-height: 880px;
}

.ft-hero-copy {
  width: min(1400px, 100%);
  padding-left: clamp(0rem, 5.6vw, 7rem);
}

.ft-case-label {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  margin: 3.1rem 0 1.2rem -7rem;
  padding: 0.35rem 1rem;
  background: var(--ft-blue);
  color: var(--ft-navy);
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: 0.95rem;
}

.ft-hero h1 {
  max-width: 1400px;
  font-size: clamp(4rem, 7vw, 7.2rem);
  line-height: 0.95;
}

.ft-lead {
  width: min(560px, 100%);
  margin-top: 1.3rem;
  font-size: 1.13rem;
  line-height: 1.28;
}

.ft-hero-strong {
  width: min(440px, 100%);
  margin-top: 1.1rem;
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: 1.32rem;
}

.ft-traits {
  margin-top: 1.4rem;
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: 0.9rem;
}

.ft-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
  margin-top: 0.9rem;
}

.ft-button-blue {
  min-height: 36px;
  padding: 0.56rem 1.2rem;
  background: var(--ft-blue);
  color: var(--ft-navy);
  font-size: 0.82rem;
}

.ft-button-pink {
  min-height: 38px;
  padding: 0.58rem 1.25rem;
  background: var(--ft-pink);
  color: var(--ft-white);
  font-size: 0.84rem;
}

.ft-button-blue:hover,
.ft-button-blue:focus-visible,
.ft-button-pink:hover,
.ft-button-pink:focus-visible {
  background: var(--ft-white);
  color: var(--ft-navy);
}

.ft-flow {
  position: relative;
  display: flex;
  align-items: flex-start;
  width: min(590px, 100%);
  color: var(--ft-white);
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: 0.78rem;
  line-height: 1.1;
}

.ft-flow::before {
  content: "";
  position: absolute;
  top: 9px;
  left: 8%;
  right: 8%;
  height: 2px;
  background: var(--ft-white);
  opacity: 0.75;
}

.ft-step {
  position: relative;
  flex: 1 1 0;
  padding-top: 24px;
  text-align: center;
}

.ft-dot {
  position: absolute;
  top: 2px;
  left: 50%;
  width: 15px;
  height: 15px;
  border-radius: 50%;
  background: var(--ft-white);
  transform: translateX(-50%);
}

.ft-step.is-active .ft-dot {
  background: var(--ft-pink);
}

.ft-step.is-active>span:not(.ft-dot),
.ft-step.is-active strong {
  color: var(--ft-pink);
}

.ft-step strong {
  display: block;
  margin-top: 0.25rem;
  font-size: 0.86rem;
}

.ft-late {
  min-height: 1180px;
  padding-top: 7rem;
  padding-bottom: 5.5rem;
}

.ft-late-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.78fr);
  gap: clamp(2rem, 8vw, 9rem);
  align-items: end;
  margin-bottom: 5.6rem;
}

.ft-late h2 {
  font-size: clamp(3.6rem, 6.4vw, 6.45rem);
  line-height: 0.97;
}

.ft-late-grid p {
  width: min(520px, 100%);
  margin-top: 1.3rem;
  font-size: 1.18rem;
  line-height: 1.26;
}

.ft-context-callout {
  padding-bottom: 1rem;
}

.ft-context-callout h3 {
  font-size: clamp(2.7rem, 4.4vw, 4.5rem);
  line-height: 0.98;
}

.ft-context-callout p {
  width: min(380px, 100%);
  font-size: 0.95rem;
}

.ft-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
  background: transparent;
}

.ft-card-grid article {
  min-width: 0;
  padding: clamp(2rem, 3.2vw, 3.25rem);
  border-radius: clamp(24px, 2.4vw, 36px);
}

.ft-card-grid h4 {
  margin-bottom: clamp(1.5rem, 2.8vw, 3.2rem);
  font-size: clamp(1.25rem, 1.75vw, 1.7rem);
  line-height: 1.12;
}

.ft-card-grid p {
  font-size: clamp(1.15rem, 1.55vw, 1.55rem);
  line-height: 1.16;
}

.ft-pink-cards article {
  min-height: clamp(230px, 17vw, 285px);
  background: var(--ft-pink);
  color: var(--ft-white);
}

.ft-pink-cards h4 {
  color: var(--ft-navy);
}

.ft-pink-cards article:not(:first-child) h4 {
  color: var(--ft-white);
}

.ft-intelligence {
  min-height: 1670px;
  padding-top: 6.5rem;
  padding-bottom: 6.5rem;
}

.ft-value-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(230px, 0.55fr) minmax(230px, 0.55fr);
  gap: 3rem;
  align-items: end;
}

.ft-eyebrow,
.ft-mini-title {
  color: var(--ft-pink);
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: 0.95rem;
  line-height: 1.16;
}

.ft-value-grid h2 {
  width: min(760px, 100%);
  margin-top: 0.35rem;
  font-size: clamp(3.25rem, 5.2vw, 5.4rem);
  line-height: 0.99;
}

.ft-small-copy {
  font-size: 0.92rem;
  line-height: 1.22;
}

.ft-small-copy h4 {
  margin-bottom: 0.55rem;
  font-size: 1rem;
}

.ft-small-copy p {
  margin-top: 0.75rem;
}

.ft-flow-wide {
  margin: 4.2rem auto 3.8rem;
}

.ft-intel-grid {
  display: grid;
  grid-template-columns: minmax(230px, 0.7fr) minmax(0, 1.3fr);
  gap: clamp(2rem, 7vw, 7.5rem);
  align-items: start;
  width: min(960px, 100%);
  margin: 0 auto;
}

.ft-intel-grid blockquote {
  margin-top: 7.4rem;
  color: var(--ft-white);
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: clamp(2.15rem, 3.2vw, 3.2rem);
  line-height: 1.05;
  text-align: center;
}

.ft-intel-grid h2 {
  font-size: clamp(2.8rem, 4.4vw, 4.7rem);
  line-height: 0.98;
}

.ft-intel-grid h3 {
  margin: 0.45rem 0 1rem;
  color: var(--ft-pink);
  font-size: 1.35rem;
}

.ft-intel-grid p {
  font-size: 0.98rem;
  line-height: 1.28;
}

.ft-intel-grid p+p,
.ft-intel-grid .ft-bar-list+p {
  margin-top: 1rem;
}

.ft-bar-list {
  display: grid;
  gap: 0.38rem;
  margin-top: 0.6rem;
}

.ft-bar-list span {
  color: var(--ft-white);
}

.ft-bar-list div {
  min-height: 34px;
  padding: 0.45rem 0.75rem;
  background: var(--ft-pink);
  color: var(--ft-navy);
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: 1rem;
}

.ft-operative {
  padding-top: 4.2rem;
  padding-bottom: 7.2rem;
}

.ft-operative h2 {
  margin-top: 0.4rem;
  margin-bottom: 1.6rem;
  font-size: clamp(3.2rem, 5.2vw, 5.3rem);
  line-height: 0.98;
}

.ft-blue-cards article {
  min-height: clamp(230px, 17vw, 285px);
  background: var(--ft-blue);
  color: var(--ft-navy);
}

.ft-blue-cards h4 {
  color: var(--ft-navy);
}

.ft-action {
  min-height: 1750px;
  padding-top: 7.8rem;
  padding-bottom: 6rem;
}

.ft-action-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: clamp(1rem, 2vw, 4rem);
}

.ft-action-copy {
  padding-left: clamp(0rem, 3vw, 3.5rem);
}

.ft-action-copy h2,
.ft-stream-copy h2 {
  font-size: clamp(3.4rem, 5.4vw, 5.8rem);
  line-height: 0.98;
}

.ft-action-copy p {
  width: min(430px, 100%);
  margin: 1rem 0 1.2rem;
  font-size: 1.02rem;
  line-height: 1.28;
}

.ft-stream-copy {
  margin-top: 495px;
}

.ft-stream-copy>p {
  width: min(520px, 100%);
  margin-top: 0.9rem;
  font-size: 1.08rem;
  line-height: 1.25;
}

.ft-flow-action {
  width: min(680px, 100%);
  margin-top: 3rem;
}

.ft-impact-list {
  width: min(600px, 100%);
  margin-top: 4rem;
  padding-left: 1rem;
  /* border-left: 7px solid var(--ft-pink); */
}

.ft-impact-list p {
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: 1.1rem;
}

.ft-impact-list ul {
  margin-top: 0.65rem;
  padding-left: 0;
  list-style: none;
  font-size: 0.95rem;
  line-height: 1.32;
}

.ft-bold-statement {
  width: min(650px, 100%);
  margin-top: 3rem;
  padding-left: 1.2rem;
  border-left: 8px solid var(--ft-pink);
  color: var(--ft-white);
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: clamp(2.25rem, 3.9vw, 4.1rem);
  line-height: 1.02;
}

.ft-stream-copy .ft-button-pink {
  margin-top: 1.15rem;
}

.ft-valuestore {
  min-height: auto;
  padding-top: 7rem;
  padding-bottom: 10rem;
}

.ft-valuestore .ws-grid-bg {
  top: 1.2rem;
  left: 36%;
  width: min(780px, 92vw);
  opacity: 1;
}

.ft-valuestore h2 {
  color: var(--ft-white);
}

.ft-valuestore .ws-large {
  max-width: 620px;
  color: var(--ft-white);
}

.ft-valuestore .ws-boxed {
  width: min(520px, 100%);
  margin-left: auto;
  margin-right: auto;
  /* background: rgba(192, 20, 102, 0.58); */
  color: var(--ft-white);
  text-align: center;
}

.ft-valuestore .ws-caption {
  color: var(--ft-white);
}

.ft-valuestore .ws-app-grid div {
  border: 2px solid rgba(176, 222, 237, 0.75);
  background: rgba(1, 10, 45, 0.74);
}

@media (max-width: 1180px) {
  .ft-hero-copy {
    padding-left: 2rem;
  }

  .ft-case-label {
    margin-left: -2rem;
  }

  .ft-late-grid,
  .ft-value-grid,
  .ft-action-grid {
    gap: 3rem;
  }
}

@media (max-width: 980px) {

  .ft-hero,
  .ft-late,
  .ft-intelligence,
  .ft-action {
    min-height: auto;
  }

  .ft-hero-copy {
    padding-left: 0;
  }

  .ft-case-label {
    margin-left: 0;
  }

  .ft-late-grid,
  .ft-value-grid,
  .ft-intel-grid,
  .ft-action-grid {
    grid-template-columns: 1fr;
  }

  .ft-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ft-context-callout,
  .ft-intel-grid blockquote,
  .ft-stream-copy {
    margin-top: 0;
  }

  .ft-intel-grid blockquote {
    text-align: left;
  }

  .ft-action-copy {
    padding-left: 0;
  }

  .ft-bg-hero {
    right: -22rem;
  }
}

@media (max-width: 680px) {
  .ft-bg {
    width: 900px;
    opacity: 0.55;
  }

  .ft-bg-hero {
    top: 3rem;
    right: -28rem;
  }

  .ft-bg-left {
    left: -30rem;
  }

  .ft-bg-waves {
    min-width: 900px;
  }

  .ft-hero {
    padding-top: 5rem;
  }

  .ft-hero-grid {
    min-height: auto;
  }

  .ft-hero h1,
  .ft-late h2,
  .ft-value-grid h2,
  .ft-operative h2,
  .ft-action-copy h2,
  .ft-stream-copy h2 {
    font-size: 2.65rem;
    line-height: 1.04;
  }

  .ft-context-callout h3,
  .ft-intel-grid h2 {
    font-size: 2.2rem;
  }

  .ft-intel-grid blockquote,
  .ft-bold-statement {
    font-size: 2rem;
  }

  .ft-lead,
  .ft-late-grid p,
  .ft-action-copy p,
  .ft-stream-copy>p {
    font-size: 1rem;
  }

  .ft-card-grid {
    grid-template-columns: 1fr;
  }

  .ft-pink-cards article,
  .ft-blue-cards article {
    min-height: auto;
  }

  .ft-flow {
    width: 100%;
    font-size: 0.62rem;
  }

  .ft-flow::before {
    left: 9%;
    right: 9%;
  }

  .ft-dot {
    width: 11px;
    height: 11px;
    top: 4px;
  }

  .ft-step {
    padding-top: 22px;
  }

  .ft-step strong {
    font-size: 0.65rem;
  }

  .ft-flow-wide {
    margin: 2.6rem auto 2.2rem;
  }

  .ft-flow-action {
    margin-top: 2rem;
  }

  .ft-impact-list,
  .ft-bold-statement {
    margin-top: 2.2rem;
  }

  .ft-valuestore {
    padding-top: 6rem;
  }

  .ft-valuestore .ws-grid-bg {
    left: 47%;
    width: 660px;
  }
}

.durchlaufzeit-page {
  --dl-blue: #b0deed;
  --dl-blue-soft: #d9f0f6;
  --dl-navy: #010a2d;
  --dl-pink: #c01466;
  background: var(--dl-blue);
  color: var(--dl-navy);
}

.durchlaufzeit-page h1,
.durchlaufzeit-page h2,
.durchlaufzeit-page h3,
.durchlaufzeit-page h4 {
  color: var(--dl-navy);
}

.durchlaufzeit-page .ws-section {
  background: transparent;
}

.durchlaufzeit-page .ws-container {
  width: min(1280px, calc(100% - 44px));
}

.durchlaufzeit-page .dl-standstill-grid {
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}

.dl-bg {
  max-width: none;
  left: 0;
  width: 100%;
}

.dl-bg-hero {
  top: -1rem;
}

.dl-bg-standstill {
  top: -54rem;
}

.dl-bg-warten {
  top: -70rem;
}

.dl-tiles-bg {
  max-width: none;
  opacity: 1;
}

.dl-hero {
  min-height: 1110px;
  padding-top: 0.5rem;
  padding-bottom: 4rem;
}

.dl-hero-inner {
  position: relative;
}

.dl-process-line {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 0.5rem;
  color: var(--dl-navy);
  font-family: "Ubuntu", Arial, sans-serif;
  font-size: clamp(1.1rem, 1.75vw, 1.8rem);
  line-height: 1;
  white-space: nowrap;
}

.dl-process-line span {
  color: var(--dl-navy);
}

.dl-process-line strong {
  color: var(--dl-pink);
  font-size: 1.42em;
  line-height: 0.9;
}

.dl-case-label {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  margin-top: 4.6rem;
  margin-left: max(-22px, calc((100vw - 1280px) / -2 - 22px));
  padding: 0.35rem 1.05rem;
  background: var(--dl-pink);
  color: var(--ws-white);
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: 0.96rem;
}

.dl-hero-copy {
  width: min(860px, 100%);
  margin: 0 auto;
  padding-top: 1.1rem;
  text-align: center;
}

.dl-hero-copy h1 {
  font-size: clamp(4rem, 6.45vw, 6.55rem);
  line-height: 0.95;
}

.dl-hero-copy h1 span {
  color: var(--dl-pink);
}

.dl-hero-copy h2 {
  width: min(530px, 100%);
  margin: 2rem auto 1.35rem;
  font-size: clamp(1.6rem, 2.5vw, 2.45rem);
  line-height: 0.98;
}

.dl-hero-copy p {
  width: min(410px, 100%);
  margin: 0 auto;
  font-size: clamp(1rem, 1.5vw, 1.38rem);
  line-height: 1.1;
}

.dl-button,
.dl-button-pink {
  min-height: 44px;
  margin-top: 3.2rem;
  padding: 0.65rem 1.55rem;
  border-radius: 999px;
  background: var(--ws-white);
  color: var(--dl-navy);
  font-size: 0.95rem;
}

.dl-button:hover,
.dl-button:focus-visible {
  background: var(--dl-pink);
  color: var(--ws-white);
}

.dl-standstill {
  min-height: 1060px;
  padding-top: 0;
  padding-bottom: 6rem;
}

.dl-process-wide {
  z-index: 2;
  width: max-content;
  min-width: 1280px;
  margin-left: 50%;
  transform: translateX(-50%);
}

.dl-standstill-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.04fr) minmax(0, 0.96fr);
  align-items: start;
  gap: 4rem;
  margin-top: 2rem;
}

.dl-dark-panel {
  min-height: 445px;
  margin-left: max(-22px, calc((100vw - 1280px) / -2 - 22px));
  padding: 8rem 3rem 4.5rem;
  background: var(--dl-navy);
  color: var(--ws-white);
  text-align: center;
}

.dl-dark-panel h2 {
  color: var(--ws-white);
  font-size: clamp(3.6rem, 5.1vw, 5.25rem);
  line-height: 0.94;
}

.dl-dark-panel h2 span {
  color: var(--dl-pink);
}

.dl-dark-panel p {
  width: min(420px, 100%);
  margin: 1.15rem auto 0;
  color: var(--ws-white);
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: clamp(1.45rem, 2.2vw, 2.15rem);
  line-height: 1.02;
}

.dl-standstill-copy {
  padding-top: 4rem;
  text-align: center;
}

.dl-standstill-copy h2 {
  font-size: clamp(3rem, 4.3vw, 4.35rem);
  line-height: 1.02;
}

.dl-standstill-copy h2 span {
  color: var(--dl-pink);
}

.dl-standstill-copy p {
  width: min(520px, 100%);
  margin: 1.2rem auto 2.1rem;
  font-size: clamp(1.25rem, 2vw, 1.9rem);
  line-height: 1.1;
}

.dl-standstill-copy h3 {
  font-size: clamp(3rem, 4.3vw, 4.3rem);
  line-height: 1.02;
}

.dl-warten {
  min-height: 1070px;
  padding-top: 6rem;
  padding-bottom: 8rem;
}

.dl-tiles-left {
  top: 0;
  left: -22rem;
  width: 900px;
}

.dl-warten h2 {
  width: min(820px, 100%);
  margin: 0 auto;
  font-size: clamp(4rem, 6vw, 6.15rem);
  line-height: 1.02;
}

.dl-warten p {
  margin-top: 1rem;
  font-size: clamp(2.4rem, 4vw, 4.05rem);
  line-height: 1.05;
}

.dl-wait-bar {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.2rem;
  width: min(1000px, 100%);
  margin: -0.2rem auto 0;
}

.dl-wait-bar strong {
  color: var(--dl-pink);
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: clamp(1.35rem, 2vw, 2rem);
}

.dl-wait-bar .dl-line {
  display: block;
  width: min(120px, 10vw);
  height: 8px;
  border-radius: 999px;
  background: var(--dl-pink);
}

.dl-wait-bar b {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: min(430px, 42vw);
  min-height: 52px;
  padding: 0.1rem 2rem 0.35rem;
  border-radius: 999px;
  background: var(--dl-pink);
  color: var(--ws-white);
  font-family: "Ubuntu", Arial, sans-serif;
  font-size: clamp(2.3rem, 4.1vw, 4.05rem);
  font-weight: 400;
  line-height: 0.95;
}

.dl-valuestore {
  min-height: 1350px;
  padding-top: 7.5rem;
  padding-bottom: 9rem;
}

.dl-valuestore-tiles {
  top: -5.4rem;
  left: 50%;
  width: min(900px, 112vw);
  transform: translateX(-64%);
}

.dl-valuestore h2 {
  color: var(--dl-navy);
}

.dl-valuestore .ws-large {
  width: min(670px, 100%);
  color: var(--dl-navy);
  font-family: "Ubuntu", Arial, sans-serif;
  font-size: clamp(3rem, 4.7vw, 4.75rem);
  line-height: 1.03;
}

.dl-valuestore .ws-boxed {
  width: min(520px, 100%);
  margin-left: auto;
  margin-right: auto;
  /* background: rgba(192, 20, 102, 0.16); */
  color: var(--dl-navy);
  text-align: center;
}

.dl-button-pink {
  margin-top: 0.5rem;
  background: var(--dl-pink);
  color: var(--ws-white);
}

.dl-button-pink:hover,
.dl-button-pink:focus-visible {
  background: var(--dl-navy);
  color: var(--ws-white);
}

.dl-valuestore .ws-caption {
  color: var(--dl-navy);
}

.dl-valuestore .ws-app-grid div {
  min-height: 270px;
  border: 3px solid rgba(176, 222, 237, 0.78);
  border-radius: 16px;
  background: var(--dl-navy);
}

@media (max-width: 1180px) {
  .dl-dark-panel {
    margin-left: 0;
  }

  .dl-standstill-grid {
    gap: 2rem;
  }
}

@media (max-width: 980px) {

  .dl-hero,
  .dl-standstill,
  .dl-warten,
  .dl-valuestore {
    min-height: auto;
  }

  .dl-standstill-grid {
    grid-template-columns: 1fr;
  }

  .dl-dark-panel {
    padding: 5rem 2rem;
  }

  .dl-standstill-copy {
    padding-top: 1rem;
  }

  .dl-wait-bar {
    flex-wrap: wrap;
    gap: 0.7rem;
  }

  .dl-wait-bar b {
    order: 2;
    min-width: min(430px, 100%);
  }
}

@media (max-width: 680px) {
  .durchlaufzeit-page .ws-container {
    width: min(calc(100vw - 28px), 362px);
    max-width: min(calc(100vw - 28px), 362px);
  }

  .dl-bg {
    width: 900px;
  }

  .dl-hero {
    padding-top: 5rem;
  }

  .dl-process-line {
    justify-content: flex-start;
    width: max-content;
    min-width: 680px;
    margin-left: 50%;
    font-size: 0.82rem;
    transform: translateX(-50%);
  }

  .dl-process-line strong {
    font-size: 1.35em;
  }

  .dl-case-label {
    margin-top: 2.5rem;
    margin-left: -14px;
    min-height: 36px;
    font-size: 0.78rem;
  }

  .dl-hero-copy h1,
  .dl-warten h2 {
    font-size: 2.75rem;
  }

  .dl-hero-copy h2 {
    margin-top: 1.4rem;
    font-size: 1.45rem;
  }

  .dl-hero-copy p {
    font-size: 1rem;
  }

  .dl-button,
  .dl-button-pink {
    min-height: 38px;
    font-size: 0.8rem;
  }

  .dl-dark-panel {
    padding: 3.6rem 1.4rem;
  }

  .dl-dark-panel h2,
  .dl-standstill-copy h2,
  .dl-standstill-copy h3 {
    font-size: 2.5rem;
  }

  .dl-dark-panel p,
  .dl-standstill-copy p {
    font-size: 1.2rem;
  }

  .dl-warten {
    padding-top: 4rem;
  }

  .dl-warten p {
    font-size: 2rem;
  }

  .dl-wait-bar {
    margin-top: 1rem;
  }

  .dl-wait-bar strong {
    font-size: 1rem;
  }

  .dl-wait-bar .dl-line {
    width: 54px;
    height: 5px;
  }

  .dl-wait-bar b {
    min-height: 44px;
    font-size: 2.2rem;
  }

  .dl-tiles-left {
    left: -22rem;
    width: 720px;
  }

  .dl-valuestore {
    padding-top: 5rem;
  }

  .dl-valuestore-tiles {
    width: 720px;
    transform: translateX(-64%);
  }

  .dl-valuestore .ws-large {
    font-size: 2.2rem;
  }

  .dl-valuestore .ws-app-grid div {
    min-height: 126px;
    border-radius: 8px;
  }
}

.engpass-page {
  --eg-blue: #b0deed;
  --eg-blue-soft: #d9f0f6;
  --eg-navy: #010a2d;
  --eg-pink: #c01466;
  background: var(--eg-blue);
  color: var(--eg-navy);
}

.engpass-page h1,
.engpass-page h2,
.engpass-page h3,
.engpass-page h4 {
  color: var(--eg-navy);
}

.engpass-page .ws-section {
  background: transparent;
}

.engpass-page .ws-container {
  width: min(1280px, calc(100% - 44px));
  padding-left: 0;
  padding-right: 0;
}

.eg-geometry,
.eg-tiles {
  max-width: none;
  opacity: 1;
}

.eg-hero {
  min-height: 975px;
  padding-top: 1rem;
  padding-bottom: 3rem;
}

.eg-geometry-hero {
  top: 0;
  left: 0;
  width: min(610px, 54vw);
}

.eg-hero-grid {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 760px) minmax(360px, 1fr);
  align-items: start;
  gap: 0.5rem;
}

.eg-hero-copy {
  position: relative;
  z-index: 2;
  padding-left: 5rem;
}

.eg-eyebrow {
  margin: 0 0 0.7rem;
  color: var(--eg-pink);
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: clamp(1rem, 1.35vw, 1.35rem);
  line-height: 1.1;
}

.eg-case-label {
  position: absolute;
  top: 2.55rem;
  left: max(-22px, calc((100vw - 1280px) / -2 - 22px));
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding: 0.35rem 1.05rem;
  background: var(--eg-pink);
  color: var(--ws-white);
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: 0.96rem;
}

.eg-hero-copy h1 {
  max-width: 720px;
  margin: 0;
  font-size: clamp(4.7rem, 5.35vw, 5.55rem);
  line-height: 0.97;
}

.eg-hero-copy h1 span,
.eg-visible h2 span {
  color: var(--eg-pink);
}

.eg-lead {
  margin-top: 2.1rem;
  font-size: clamp(1.55rem, 2.2vw, 2.15rem);
  line-height: 1.05;
}

.eg-button,
.eg-button-pink {
  min-height: 44px;
  margin-top: 2.2rem;
  padding: 0.65rem 1.55rem;
  border-radius: 999px;
  background: var(--ws-white);
  color: var(--eg-navy);
  font-size: 0.95rem;
}

.eg-button:hover,
.eg-button:focus-visible {
  background: var(--eg-pink);
  color: var(--ws-white);
}

.eg-flow-wrap {
  padding-top: 12.8rem;
  margin-left: -6rem;
}

.eg-flow-img {
  display: block;
  width: min(502px, 100%);
  margin-left: auto;
}

.eg-system {
  min-height: 1760px;
  padding-top: 0;
  padding-bottom: 2rem;
}

.eg-system::before,
.eg-system::after {
  content: "";
  position: absolute;
  pointer-events: none;
  background: var(--eg-pink);
}

.eg-system::before {
  z-index: 3;
  top: 390px;
  left: calc(50% + 126px);
  width: 8px;
  height: 890px;
  border-radius: 999px;
}

.eg-system::after {
  z-index: 4;
  top: 1260px;
  left: calc(50% + 130px);
  width: 42px;
  height: 42px;
  border-radius: 50%;
  transform: translateX(-50%);
}

.eg-tiles-system {
  top: 48rem;
  left: -22.5rem;
  width: 1054px;
}

.eg-hex-layout {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 870px) minmax(330px, 1fr);
  align-items: center;
  gap: 1.45rem;
}

.eg-hex-row {
  display: flex;
  align-items: center;
  margin-left: max(-22px, calc((100vw - 1280px) / -2 - 22px));
}

.eg-hex-card {
  position: relative;
  display: grid;
  place-items: center;
  flex: 0 0 min(306px, 26vw);
  min-height: min(350px, 30vw);
  padding: 2.3rem 2rem;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  text-align: center;
}

.eg-hex-card+.eg-hex-card {
  margin-left: -6px;
}

.eg-hex-light {
  background-image: url("../img/engpass-hex-light.svg");
}

.eg-hex-pink {
  background-image: url("../img/engpass-hex-pink.svg");
}

.eg-hex-card h2 {
  margin-top: 1.8rem;
  font-size: clamp(1.85rem, 2.45vw, 2.55rem);
  line-height: 1;
}

.eg-hex-card p {
  margin-top: 1.25rem;
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: clamp(0.95rem, 1.3vw, 1.25rem);
  line-height: 1.05;
}

.eg-determines h2 {
  font-size: clamp(3rem, 4.1vw, 4.15rem);
  line-height: 1;
}

.eg-determines p {
  max-width: 330px;
  font-size: 1.08rem;
  line-height: 1.1;
}

.eg-determines p+p {
  margin-top: 0.9rem;
}

.eg-path-line {
  display: none;
}

.eg-path-line::after {
  content: none;
}

.eg-constraint {
  position: relative;
  min-height: 1270px;
  margin-top: -0.8rem;
}

.eg-speed {
  z-index: 2;
  position: absolute;
  top: 255px;
  left: 22.8%;
  width: min(450px, 36vw);
  text-align: right;
}

.eg-speed h2 {
  font-size: clamp(3rem, 4.45vw, 4.25rem);
  line-height: 1;
}

.eg-speed p {
  /* width: min(280px, 100%); */
  margin: 1rem auto 0;
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: 1rem;
  line-height: 1.05;
}

.eg-line {
  display: none;
  position: absolute;
  z-index: 1;
  top: 78px;
  left: 58.1%;
  width: 8px;
  height: 1245px;
  border-radius: 999px;
  background: var(--eg-pink);
}

.eg-line::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -20px;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: var(--eg-pink);
  transform: translateX(-50%);
}

.eg-line-note {
  position: absolute;
  z-index: 2;
  top: 66px;
  left: calc(58.1% + 65px);
  width: 285px;
}

.eg-line-note p,
.eg-isolated p {
  margin: 0;
  font-size: 0.98rem;
  line-height: 1.1;
}

.eg-line-note p+p {
  margin-top: 0.95rem;
}

.eg-isolated {
  position: absolute;
  z-index: 2;
  top: 430px;
  left: calc(58.1% + 65px);
  width: 395px;
}

.eg-isolated h2 {
  font-size: clamp(3rem, 4.4vw, 4.2rem);
  line-height: 1;
}

.eg-isolated p {
  margin-top: 1.1rem;
}

.eg-visible {
  position: absolute;
  z-index: 2;
  top: 1335px;
  left: 50%;
  width: min(620px, 100%);
  text-align: center;
  transform: translateX(-50%);
}

.eg-visible h2 {
  font-size: clamp(3.6rem, 5.2vw, 5.2rem);
  line-height: 1.02;
}

.eg-visible p {
  margin-top: 0.65rem;
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: 1.18rem;
}

.eg-valuestore {
  min-height: 1370px;
  padding-top: 5.6rem;
  padding-bottom: 9rem;
}

.eg-tiles-valuestore {
  top: -31rem;
  left: 50%;
  width: min(1054px, 116vw);
  transform: translateX(-56%);
}

.eg-valuestore h2 {
  color: var(--eg-navy);
}

.eg-valuestore .ws-large {
  width: min(670px, 100%);
  color: var(--eg-navy);
  font-family: "Ubuntu", Arial, sans-serif;
  font-size: clamp(3rem, 4.7vw, 4.75rem);
  line-height: 1.03;
}

.eg-valuestore .ws-boxed {
  width: min(520px, 100%);
  margin-left: auto;
  margin-right: auto;
  /* background: rgba(192, 20, 102, 0.16); */
  color: var(--eg-navy);
  text-align: center;
}

.eg-button-pink {
  margin-top: 0.5rem;
  background: var(--eg-pink);
  color: var(--ws-white);
}

.eg-button-pink:hover,
.eg-button-pink:focus-visible {
  background: var(--eg-navy);
  color: var(--ws-white);
}

.eg-valuestore .ws-caption {
  color: var(--eg-navy);
}

.eg-valuestore .ws-app-grid div {
  min-height: 211px;
  border: 3px solid rgba(176, 222, 237, 0.78);
  border-radius: 16px;
  background: var(--eg-navy);
}

.eg-valuestore .ws-app-grid {
  width: min(670px, 100%);
}

@media (max-width: 1180px) {
  .eg-hero-copy {
    padding-left: 5rem;
  }

  .eg-flow-wrap {
    margin-left: -4rem;
  }

  .eg-case-label {
    left: max(-22px, calc((100vw - 1180px) / -2 - 22px));
  }

  .eg-hex-layout {
    grid-template-columns: minmax(0, 790px) minmax(260px, 1fr);
    gap: 1.4rem;
  }

  .eg-determines p {
    font-size: 0.98rem;
  }

  .eg-system {
    min-height: auto;
    padding-bottom: 6rem;
  }

  .eg-system::before,
  .eg-system::after {
    display: none;
  }

  .eg-hex-layout {
    grid-template-columns: 1fr;
    gap: 2.4rem;
  }

  .eg-hex-row {
    justify-content: center;
    width: min(900px, 100%);
    margin-left: auto;
    margin-right: auto;
  }

  .eg-hex-card {
    flex: 1 1 0;
    min-height: 286px;
    padding: 1.9rem 1.45rem;
  }

  .eg-hex-card h2 {
    font-size: 2.1rem;
  }

  .eg-hex-card p {
    font-size: 1.02rem;
  }

  .eg-determines {
    width: min(690px, 100%);
    margin: 0 auto;
    text-align: center;
  }

  .eg-determines h2 {
    font-size: 3.25rem;
  }

  .eg-determines p {
    max-width: 620px;
    margin-left: auto;
    margin-right: auto;
  }

  .eg-constraint {
    display: grid;
    gap: 3rem;
    min-height: auto;
    margin-top: 4rem;
  }

  .eg-speed,
  .eg-line-note,
  .eg-isolated,
  .eg-visible {
    position: relative;
    inset: auto;
    width: min(640px, 100%);
    margin: 0 auto;
    text-align: center;
    transform: none;
  }

  .eg-line {
    display: block;
    position: relative;
    top: auto;
    bottom: auto;
    left: auto;
    width: 7px;
    height: 280px;
    margin: 0 auto 1.3rem;
  }

  .eg-visible {
    margin-top: 2rem;
  }
}

@media (min-width: 992px) and (max-width: 1500px) {
  .eg-system {
    min-height: clamp(1420px, 128vw, 1760px);
    padding-bottom: 2rem;
  }

  .eg-system::before,
  .eg-system::after {
    display: block;
  }

  .eg-system::before {
    top: clamp(330px, 29vw, 390px);
    left: calc(50% + clamp(76px, 8.4vw, 126px));
    width: clamp(6px, 0.55vw, 8px);
    height: clamp(720px, 68vw, 890px);
  }

  .eg-system::after {
    top: clamp(1030px, 96vw, 1260px);
    left: calc(50% + clamp(79px, 8.6vw, 130px));
    width: clamp(32px, 3vw, 42px);
    height: clamp(32px, 3vw, 42px);
  }

  .eg-hex-layout {
    grid-template-columns: minmax(0, 1fr) clamp(245px, 25vw, 335px);
    gap: clamp(0.5rem, 1.5vw, 1.45rem);
    align-items: center;
  }

  .eg-hex-row {
    justify-content: flex-start;
    width: auto;
    margin-left: 0;
    margin-right: 0;
  }

  .eg-hex-card {
    flex: 0 0 clamp(210px, 22.8vw, 306px);
    min-height: clamp(245px, 26.2vw, 350px);
    padding: clamp(1.15rem, 2vw, 2.3rem) clamp(0.75rem, 1.4vw, 2rem);
  }

  .eg-hex-card h2 {
    font-size: clamp(1.45rem, 2.85vw, 2.55rem);
    overflow-wrap: normal;
    word-break: normal;
  }

  .eg-hex-card p {
    font-size: clamp(0.78rem, 1.25vw, 1.25rem);
  }

  .eg-determines {
    width: auto;
    margin: 0;
    text-align: left;
  }

  .eg-determines h2 {
    font-size: clamp(2rem, 3.7vw, 4.15rem);
  }

  .eg-determines p {
    max-width: min(300px, 100%);
    margin-left: 0;
    margin-right: 0;
    font-size: clamp(0.78rem, 1vw, 1.08rem);
  }

  .eg-constraint {
    display: block;
    min-height: clamp(1020px, 88vw, 1270px);
    margin-top: -0.8rem;
  }

  .eg-speed,
  .eg-line-note,
  .eg-isolated,
  .eg-visible {
    position: absolute;
    inset: auto;
    margin: 0;
    transform: none;
  }

  .eg-speed {
    top: clamp(185px, 18vw, 255px);
    left: 22%;
    width: min(445px, 36vw);
    text-align: right;
  }

  ul.centered-list {
    text-align: left;
    /* 1. Keep text and bullets aligned to the left internally */
    display: inline-block;
    /* 2. Shrink the UL width to fit the longest line */
    list-style: disc;
    list-style-position: inside;
    /* 3. Keep the standard bullets attached to the text */
    padding-left: 0;
    /* 4. Remove extra bullet gap */
    margin: 0 auto;
  }

  .list-wrapper {
    text-align: center;
    /* 5. Center the inline-block UL */
    width: 100%;
  }

  .eg-speed h2 {
    font-size: clamp(2.4rem, 4.25vw, 4.25rem);
  }

  .eg-speed p,
  .eg-line-note p,
  .eg-isolated p {
    font-size: clamp(0.74rem, 1vw, 1rem);
  }

  .eg-line-note {
    top: clamp(48px, 5vw, 66px);
    left: calc(50% + clamp(90px, 11.3vw, 150px));
    width: min(300px, 30vw);
    text-align: left;
  }

  .eg-line {
    display: none;
  }

  .eg-isolated {
    top: clamp(355px, 34vw, 430px);
    left: calc(50% + clamp(90px, 11.3vw, 150px));
    width: min(380px, 32vw);
    text-align: left;
  }

  .eg-isolated h2 {
    font-size: clamp(2.4rem, 4.25vw, 4.2rem);
  }

  .eg-visible {
    top: clamp(1110px, 103vw, 1335px);
    left: 50%;
    width: min(620px, 100%);
    text-align: center;
    transform: translateX(-50%);
  }

  .eg-visible h2 {
    font-size: clamp(3rem, 5.1vw, 5.2rem);
  }
}

@media (min-width: 992px) and (max-width: 1180px) {
  .eg-system {
    min-height: auto;
    padding-bottom: 6rem;
  }

  .eg-system::before,
  .eg-system::after {
    display: none;
  }

  .eg-hex-layout {
    grid-template-columns: 1fr;
    gap: 3rem;
  }

  .eg-hex-row {
    justify-content: center;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }

  .eg-hex-card {
    flex: 0 1 clamp(285px, 30vw, 340px);
    min-height: clamp(330px, 35vw, 390px);
    padding: 1.8rem 1.2rem;
  }

  .eg-hex-card h2 {
    font-size: clamp(2rem, 3.3vw, 2.8rem);
  }

  .eg-hex-card p {
    font-size: clamp(1rem, 1.8vw, 1.25rem);
  }

  .eg-determines {
    width: min(690px, 100%);
    margin: 0 auto;
    text-align: center;
  }

  .eg-determines h2 {
    font-size: clamp(3.2rem, 5.5vw, 4.25rem);
  }

  .eg-determines p {
    max-width: 620px;
    margin-left: auto;
    margin-right: auto;
    font-size: 1rem;
  }

  .eg-constraint {
    display: grid;
    gap: 3.2rem;
    min-height: auto;
    margin-top: 5rem;
  }

  .eg-speed,
  .eg-line-note,
  .eg-isolated,
  .eg-visible {
    position: relative;
    inset: auto;
    width: min(680px, 100%);
    margin: 0 auto;
    text-align: center;
    transform: none;
  }

  .eg-line {
    display: block;
    position: relative;
    top: auto;
    bottom: auto;
    left: auto;
    width: 7px;
    height: 300px;
    margin: 0 auto 1.3rem;
  }

  .eg-visible {
    margin-top: 2rem;
  }
}

@media (max-width: 991.98px) {

  .eg-hero,
  .eg-system,
  .eg-valuestore {
    min-height: auto;
  }

  .eg-hero-grid,
  .eg-hex-layout {
    grid-template-columns: 1fr;
  }

  .eg-hero-copy {
    padding-left: 0;
    text-align: center;
  }

  .eg-case-label {
    position: static;
    margin: 1rem auto 1.5rem;
  }

  .eg-flow-wrap {
    padding-top: 3rem;
    margin-left: 0;
  }

  .eg-flow-img {
    margin-right: auto;
  }

  .eg-hex-row {
    flex-direction: column;
    gap: 0.35rem;
    justify-content: center;
    margin-left: 0;
  }

  .eg-hex-card,
  .eg-hex-card+.eg-hex-card {
    flex-basis: auto;
    width: min(340px, 100%);
    min-height: 390px;
    margin-left: 0;
  }

  .eg-determines {
    text-align: center;
  }

  .eg-determines p {
    margin-left: auto;
    margin-right: auto;
  }

  .eg-constraint {
    display: grid;
    gap: 3rem;
    min-height: auto;
    margin-top: 4rem;
  }

  .eg-speed,
  .eg-line-note,
  .eg-isolated,
  .eg-visible {
    position: relative;
    inset: auto;
    width: min(640px, 100%);
    margin: 0 auto;
    text-align: center;
    transform: none;
  }

  .eg-line {
    display: block;
    position: relative;
    top: auto;
    bottom: auto;
    left: auto;
    width: 7px;
    height: 280px;
    margin: 0 auto 1.3rem;
  }

  .eg-visible {
    margin-top: 2rem;
  }

  .eg-path-line {
    display: none;
  }

  .eg-system::before,
  .eg-system::after {
    display: none;
  }
}

@media (max-width: 680px) {
  .engpass-page .ws-container {
    width: min(calc(100vw - 28px), 362px);
    max-width: min(calc(100vw - 28px), 362px);
  }

  .eg-hero {
    padding-top: 5rem;
  }

  .eg-geometry-hero {
    width: 520px;
  }

  .eg-eyebrow {
    font-size: 0.88rem;
  }

  .eg-case-label {
    min-height: 36px;
    font-size: 0.78rem;
  }

  .eg-hero-copy h1 {
    font-size: 3rem;
  }

  .eg-lead {
    font-size: 1.35rem;
  }

  .eg-button,
  .eg-button-pink {
    min-height: 38px;
    font-size: 0.8rem;
  }

  .eg-flow-img {
    width: min(330px, 100%);
  }

  .eg-hex-row {
    flex-direction: column;
    gap: 0.35rem;
  }

  .eg-hex-card,
  .eg-hex-card+.eg-hex-card {
    flex-basis: auto;
    width: min(292px, 100%);
    min-height: 335px;
    margin-left: 0;
  }

  .eg-hex-card h2 {
    font-size: 2rem;
  }

  .eg-determines h2,
  .eg-speed h2,
  .eg-isolated h2,
  .eg-visible h2 {
    font-size: 2.65rem;
  }

  .eg-tiles-system {
    top: 78rem;
    left: -22rem;
    width: 760px;
  }

  .eg-tiles-valuestore {
    top: -9rem;
    width: 760px;
    transform: translateX(-58%);
  }

  .eg-valuestore {
    padding-top: 5rem;
  }

  .eg-valuestore .ws-large {
    font-size: 2.2rem;
  }

  .eg-valuestore .ws-app-grid div {
    min-height: 126px;
    border-radius: 8px;
  }
}

.bestande-page {
  --bd-navy: #010a2d;
  --bd-pink: #c01466;
  --bd-pink-deep: #4b0b45;
  --bd-blue: #b0deed;
  --bd-white: #ffffff;
  background: var(--bd-navy);
  color: var(--bd-white);
}

.bestande-page .ws-section {
  background: transparent;
}

.bestande-page .ws-container {
  width: min(1280px, 100%);
}

.bestande-page h1,
.bestande-page h2,
.bestande-page h3,
.bestande-page h4 {
  color: var(--bd-white);
}

.bestande-page p {
  color: inherit;
}

.bestande-page span,
.bestande-page .bd-pink {
  color: var(--bd-pink);
}

.bd-hero {
  min-height: 1138px;
  padding: 0;
}

.bd-geometry {
  top: -325px;
  left: 0;
  width: min(1200px, 91vw);
  max-width: none;
}

.bd-case-label {
  position: absolute;
  z-index: 3;
  top: 253px;
  left: -18px;
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding: 0.35rem 1.25rem;
  background: var(--bd-white);
  color: var(--bd-navy);
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: 0.86rem;
  line-height: 1;
}

.bd-hero-grid {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 720px) minmax(380px, 1fr);
  align-items: start;
}

.bd-hero-copy {
  padding-top: 50px;
  padding-left: 80px;
}

.bd-hero-copy h1 {
  width: min(720px, 100%);
  font-size: clamp(4.75rem, 5.7vw, 5.95rem);
  line-height: 1.02;
}

.bd-lead {
  width: min(620px, 100%);
  margin-top: 1.15rem;
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
  font-size: clamp(2rem, 2.7vw, 2.65rem);
  line-height: 1.02;
}

.bd-button,
.bd-button-pink {
  min-height: 46px;
  border-radius: 999px;
  font-size: 0.82rem;
  line-height: 1.05;
}

.bd-button {
  flex-direction: column;
  margin-top: 4.7rem;
  padding: 0.55rem 2.15rem;
  background: var(--bd-white);
  color: var(--bd-navy);
}

.bd-button:hover,
.bd-button:focus-visible {
  background: var(--bd-pink);
  color: var(--bd-white);
}

.bd-button span {
  color: inherit;
}

.bd-barrels-wrap {
  padding-top: 371px;
  padding-right: 20px;
}

.bd-barrels-img {
  width: min(428px, 25vw);
  margin-left: auto;
  position: absolute;
  right: 0;
  margin-top: 10rem;
}

.bd-waiting {
  min-height: 760px;
  margin-top: 10vmin;
  padding: 0;
}

.bd-waiting .ws-container {
  min-height: 760px;
}

.bd-flow-img {
  position: absolute;
  z-index: 2;
  top: 0;
  left: 270px;
  width: min(753px, 70vw);
  max-width: none;
}

.bd-wait-copy {
  position: absolute;
  z-index: 2;
  top: 155px;
  left: 280px;
  width: 500px;
  padding-left: 32px;
}

.bd-wait-copy::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 19px;
  height: 266px;
  border-radius: 999px;
  background: var(--bd-pink);
}

.bd-wait-copy h2 {
  font-size: clamp(3.1rem, 4.25vw, 4.28rem);
  line-height: 0.98;
}

.bd-wait-copy h2 span {
  color: var(--bd-pink);
}

.bd-wait-copy p {
  width: min(350px, 100%);
  margin-top: 1.05rem;
  font-size: 1.18rem;
  line-height: 1.08;
}

.bd-valuestore {
  min-height: 1585px;
  padding-top: 95px;
  padding-bottom: 8rem;
}

.bd-tiles {
  top: -413px;
  left: -125px;
  width: min(1088px, 108vw);
  max-width: none;
}

.bd-valuestore .ws-container {
  width: min(940px, calc(100% - 44px));
}

.bd-valuestore h2 {
  color: var(--bd-white);
  font-size: clamp(4.15rem, 5.25vw, 5.15rem);
  line-height: 0.98;
}

.bd-valuestore .ws-large {
  width: min(560px, 100%);
  margin: 0.3rem auto 0;
  color: var(--bd-white);
  font-family: "Ubuntu", Arial, sans-serif;
  font-size: clamp(2.7rem, 4.1vw, 4.08rem);
  line-height: 1.02;
}

.bd-valuestore .ws-boxed {
  width: min(520px, 100%);
  margin: 0.45rem auto 0;
  /* background: rgba(255, 255, 255, 0.16); */
  color: var(--bd-white);
  text-align: center;
}

.bd-button-pink {
  margin-top: 1rem;
  padding: 0.7rem 2rem;
  background: var(--bd-pink);
  color: var(--bd-white);
}

.bd-button-pink:hover,
.bd-button-pink:focus-visible {
  background: var(--bd-white);
  color: var(--bd-navy);
}

.bd-valuestore .ws-caption {
  /* width: min(620px, 100%); */
  margin-top: 2.05rem;
  color: var(--bd-white);
  font-size: 0.95rem;
  line-height: 1.08;
}

.bd-valuestore .ws-app-grid {
  width: min(670px, 100%);
}

.bd-valuestore .ws-app-grid div {
  min-height: 211px;
  border: 1px solid rgba(255, 255, 255, 0.95);
  border-radius: 16px;
  background: var(--bd-navy);
}

@media (max-width: 1180px) {
  .bd-hero-copy {
    padding-left: 50px;
  }

  .bd-flow-img {
    left: 190px;
  }

  .bd-wait-copy {
    left: 205px;
  }

  .bd-barrels-wrap {
    padding-right: 12px;
  }
}

@media (max-width: 980px) {

  .bd-hero,
  .bd-waiting,
  .bd-waiting .ws-container,
  .bd-valuestore {
    min-height: auto;
  }

  .bd-hero {
    padding: 4.5rem 0 3rem;
  }

  .bd-case-label {
    position: relative;
    top: auto;
    left: auto;
    width: fit-content;
    margin: 0 auto 2rem;
  }

  .bd-hero-grid {
    grid-template-columns: 1fr;
    gap: 3rem;
  }

  .bd-hero-copy {
    padding: 0 0.4rem;
    text-align: center;
  }

  .bd-hero-copy h1,
  .bd-lead {
    margin-left: auto;
    margin-right: auto;
  }

  .bd-button {
    margin-top: 2rem;
  }

  .bd-barrels-wrap {
    padding: 0 1rem;
  }

  .bd-barrels-img {
    margin-right: auto;
  }

  .bd-waiting {
    margin-top: 0;
    padding: 3rem 0 4rem;
  }

  .bd-flow-img {
    position: relative;
    top: auto;
    left: auto;
    width: min(720px, 100%);
    margin: 0 auto 2.5rem;
  }

  .bd-wait-copy {
    position: relative;
    top: auto;
    left: auto;
    width: min(560px, calc(100% - 28px));
    margin: 0 auto;
    padding-left: 0;
    text-align: center;
  }

  .bd-wait-copy::before {
    display: none;
  }

  .bd-wait-copy p {
    margin-left: auto;
    margin-right: auto;
  }

  .bd-valuestore {
    padding-top: 5rem;
  }
}

@media (max-width: 680px) {

  .bestande-page .ws-container,
  .bd-valuestore .ws-container {
    width: min(calc(100vw - 28px), 362px);
    max-width: min(calc(100vw - 28px), 362px);
  }

  .bd-geometry {
    top: -220px;
    left: -210px;
    width: 840px;
  }

  .bd-hero-copy h1 {
    font-size: 3.45rem;
  }

  .bd-lead {
    font-size: 1.95rem;
  }

  .bd-barrels-img {
    width: min(340px, 100%);
  }

  .bd-wait-copy h2 {
    font-size: 2.65rem;
  }

  .bd-wait-copy p {
    font-size: 1rem;
  }

  .bd-tiles {
    top: -6rem;
    left: 50%;
    width: 760px;
    transform: translateX(-58%);
  }

  .bd-valuestore h2 {
    font-size: 3.35rem;
  }

  .bd-valuestore .ws-large {
    font-size: 2.25rem;
  }

  .bd-valuestore .ws-boxed {
    font-size: 1.05rem;
  }

  .bd-valuestore .ws-app-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .bd-valuestore .ws-app-grid div {
    min-height: 126px;
    border-radius: 8px;
  }
}

/* Shopfloor management page */
.shopfloor-page {
  --sf-navy: #000936;
  --sf-blue: #b0deed;
  background: var(--sf-navy);
  color: #fff;
  min-height: 100vh;
}

.shopfloor-page .ws-section {
  background: var(--sf-navy);
  overflow: hidden;
  padding: 0;
}

.shopfloor-page .ws-container {
  max-width: 1400px;
  width: min(1400px, calc(100vw - 48px));
}

.shopfloor-page h1,
.shopfloor-page h2,
.shopfloor-page h3,
.shopfloor-page h4 {
  color: #fff;
  overflow-wrap: normal;
  word-break: normal;
}

.shopfloor-page p,
.shopfloor-page li {
  color: #fff;
  font-size: 1.08rem;
  line-height: 1.14;
}

.shopfloor-page .sf-blue,
.shopfloor-page .sf-kicker {
  color: var(--sf-blue);
  font-family: "UbuntuBold", "Ubuntu", Arial, sans-serif;
}

.sf-chevron {
  height: auto;
  max-width: none !important;
  opacity: 1;
}

.sf-hero {
  min-height: 760px;
}

.sf-chevron-hero {
  left: 102px;
  top: -155px;
  width: 1019px;
}

.sf-hero-copy {
  margin-left: 50px;
  padding-top: 50px;
  position: relative;
  width: 900px;
  z-index: 2;
}

.sf-kicker {
  font-size: 1.22rem !important;
  line-height: 1.1 !important;
  margin-bottom: 14px !important;
}

.sf-hero h1 {
  font-size: clamp(4.1rem, 6.2vw, 5.9rem);
  line-height: 1.08;
  margin-bottom: 28px;
}

.sf-hero-lead {
  font-size: 1.92rem !important;
  line-height: 1.12 !important;
  margin-bottom: 27px !important;
}

.sf-hero-copy p:not(.sf-kicker):not(.sf-hero-lead) {
  margin-bottom: 22px;
  width: 510px;
}

.sf-questions {
  min-height: 900px;
}

.sf-questions .ws-container {
  padding-top: 78px;
}

.sf-questions h2 {
  font-size: clamp(3.4rem, 5vw, 4.6rem);
  line-height: 1.08;
  margin-bottom: 28px;
}

.sf-questions .sf-blue {
  font-size: 1rem;
  margin-bottom: 26px;
}

.sf-question-list {
  margin: 0 auto;
  max-width: 430px;
}

.sf-question-list p {
  font-size: 1.08rem;
  line-height: 1.08;
  margin-bottom: 26px;
}

.sf-question-list strong {
  display: block;
}

.sf-direct {
  min-height: 1080px;
}

.sf-chevron-mid {
  right: -185px;
  top: -125px;
  width: 963px;
}

.sf-direct-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  padding-top: 160px;
}

.sf-direct-main {
  margin-left: 138px;
  width: 100%;
}

.sf-direct-main h2 {
  font-size: clamp(3.2rem, 4.7vw, 4.45rem);
  line-height: 1.13;
  margin-bottom: 31px;
}

.sf-direct-lead {
  font-size: 1.72rem !important;
  line-height: 1.14 !important;
  margin-bottom: 24px !important;
}

.sf-direct-main>p:not(.sf-kicker):not(.sf-direct-lead) {
  margin-bottom: 44px;
}

.sf-direct-main h3 {
  font-size: clamp(3.5rem, 5.2vw, 4.85rem);
  line-height: 1.14;
  margin-top: 45px;
}

.sf-direct-side {
  align-self: end;
  margin-left: 120px;
  padding-bottom: 205px;
  width: 410px;
}

.sf-direct-side p {
  margin-bottom: 31px;
}

.sf-better {
  min-height: 930px;
}

.sf-chevron-bottom {
  left: -72px;
  top: 0;
  width: 768px;
}

.sf-better .ws-container {
  padding-top: 70px;
}

.sf-change {
  margin: 0 auto 74px;
  max-width: 520px;
}

.sf-change h2 {
  font-size: 2.12rem;
  line-height: 1.1;
  margin-bottom: 20px;
}

.sf-change ul {
  display: inline-block;
  list-style-position: inside;
  padding-left: 0;
  text-align: center;
}

.sf-change li {
  font-size: 1rem;
  line-height: 1.08;
}

.sf-better-heading {
  font-size: clamp(3.25rem, 4.9vw, 4.6rem) !important;
  line-height: 1.12 !important;
  margin-bottom: 27px !important;
}

.sf-better h3 {
  font-size: 2.35rem;
  line-height: 1.05;
  margin-bottom: 18px;
}

.sf-better p {
  font-size: 1.12rem;
  line-height: 1.12;
}

.sf-live {
  min-height: 700px;
}

.sf-live .ws-container {
  padding-top: 175px;
}

.sf-live h2 {
  font-size: clamp(3.5rem, 5.3vw, 5rem);
  line-height: 1.14;
  margin-bottom: 29px;
}

.sf-live p {
  font-size: 1.3rem;
  line-height: 1.11;
}

@media (max-width: 1180px) {

  .sf-hero-copy,
  .sf-direct-main {
    margin-left: 60px;
  }

  .sf-direct-side {
    margin-left: 60px;
  }
}

@media (max-width: 980px) {
  .shopfloor-page .ws-container {
    max-width: 680px;
  }

  .sf-hero {
    min-height: 720px;
  }

  .sf-chevron-hero {
    left: -70px;
  }

  .sf-hero-copy {
    margin-left: 0;
    width: min(640px, 100%);
  }

  .sf-hero-copy p:not(.sf-kicker):not(.sf-hero-lead) {
    width: min(510px, 100%);
  }

  .sf-direct-grid {
    grid-template-columns: 1fr;
    padding-top: 100px;
  }

  .sf-direct {
    min-height: auto;
    padding-bottom: 130px !important;
  }

  .sf-direct-main {
    margin-left: 0;
    width: min(610px, 100%);
  }

  .sf-direct-side {
    margin-left: 0;
    margin-top: 70px;
    padding-bottom: 0;
    width: min(430px, 100%);
  }

  .sf-chevron-mid {
    right: -440px;
    top: 190px;
  }
}

@media (max-width: 680px) {
  .shopfloor-page .ws-container {
    max-width: min(calc(100vw - 54px), 318px);
    width: min(calc(100vw - 54px), 318px);
  }

  .shopfloor-page p,
  .shopfloor-page li {
    font-size: 0.88rem;
  }

  .sf-hero {
    min-height: 690px;
  }

  .sf-chevron-hero {
    left: -252px;
    top: -60px;
    width: 720px;
  }

  .sf-hero-copy {
    padding-top: 88px;
  }

  .sf-kicker {
    font-size: 0.84rem !important;
  }

  .sf-hero h1 {
    font-size: 2.62rem;
    overflow-wrap: anywhere;
  }

  .sf-hero-lead {
    font-size: 1.28rem !important;
  }

  .sf-hero-copy p:not(.sf-kicker):not(.sf-hero-lead) {
    margin-bottom: 17px;
  }

  .sf-questions {
    min-height: auto;
    padding-bottom: 95px !important;
  }

  .sf-questions .ws-container {
    padding-top: 42px;
  }

  .sf-questions h2 {
    font-size: 2.55rem;
  }

  .sf-question-list p {
    font-size: 0.9rem;
    margin-bottom: 22px;
  }

  .sf-direct-grid {
    padding-top: 84px;
  }

  .sf-chevron-mid {
    right: -535px;
    top: 160px;
    width: 780px;
  }

  .sf-direct-main h2 {
    font-size: 2.2rem;
    overflow-wrap: anywhere;
  }

  .sf-direct-lead {
    font-size: 1.18rem !important;
  }

  .sf-direct-main h3 {
    font-size: 2.45rem;
  }

  .sf-direct-side {
    margin-top: 48px;
  }

  .sf-better {
    min-height: auto;
    padding-bottom: 120px !important;
  }

  .sf-chevron-bottom {
    left: -265px;
    top: 0;
    width: 620px;
  }

  .sf-better .ws-container {
    padding-top: 42px;
  }

  .sf-change {
    margin-bottom: 58px;
  }

  .sf-change h2 {
    font-size: 1.55rem;
  }

  .sf-change ul {
    list-style: none;
    padding-left: 0;
  }

  .sf-change li {
    font-size: 0.82rem;
  }

  .sf-better-heading {
    font-size: 2.25rem !important;
  }

  .sf-better h3 {
    font-size: 1.35rem;
  }

  .sf-live {
    min-height: 560px;
  }

  .sf-live .ws-container {
    padding-top: 95px;
  }

  .sf-live h2 {
    font-size: 2.35rem;
  }

  .sf-live p {
    font-size: 0.96rem;
  }
}

.dpp-page h1,
.dpp-page h2,
.dpp-page h3,
.dpp-page h4,
.dpp-page p,
.dpp-page li {
  color: var(--dpp-text);
}

.dpp-page .dpp-kicker,
.dpp-page .dpp-flumen-sub,
.dpp-page .dpp-center-copy h2 span {
  color: var(--dpp-cyan) !important;
}

.dpp-page .dpp-hero-copy h1 span,
.dpp-page .dpp-intro h2 span,
.dpp-page .dpp-cost-copy h2 span,
.dpp-page .dpp-flumen-copy h2 span {
  color: var(--dpp-blue) !important;
}
