.webdesign-section {
  background: #02040a;
}

.webdesign-section::after {
  display: none;
}

.section-bg-video-wrap {
  position: absolute;
  inset: 0;
  z-index: -3;
  overflow: hidden;
}

.section-bg-video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center center;
  filter: saturate(1.08) contrast(1.04) brightness(.86);
}

.section-bg-video-mobile {
  display: none;
}

.section-bg-video-overlay {
  position: absolute;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  background:
    radial-gradient(circle at 73% 18%, rgba(97, 171, 255, .18), transparent 34%),
    linear-gradient(90deg, rgba(2, 4, 10, .78) 0%, rgba(2, 4, 10, .56) 43%, rgba(2, 4, 10, .72) 100%),
    linear-gradient(180deg, rgba(2, 4, 10, .42) 0%, rgba(2, 4, 10, .18) 42%, rgba(2, 4, 10, .76) 100%);
}

.webdesign-section .section-shell {
  position: relative;
  z-index: 1;
}

.webdesign-loop-card {
  position: relative;
  min-height: 380px;
  border: 1px solid rgba(255, 255, 255, .14);
  border-radius: 32px;
  overflow: hidden;
  background: rgba(4, 11, 24, .7);
  box-shadow: var(--shadow-dark);
  backdrop-filter: blur(18px);
}

.webdesign-loop-card::before,
.webdesign-loop-card::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.webdesign-loop-card::before {
  z-index: 2;
  background:
    radial-gradient(circle at 86% 18%, rgba(244, 210, 173, .22), transparent 34%),
    linear-gradient(180deg, rgba(2, 4, 10, .06), rgba(2, 4, 10, .24));
}

.webdesign-loop-card::after {
  z-index: 3;
  border-radius: inherit;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .08), inset 0 -70px 90px rgba(2, 4, 10, .24);
}

.webdesign-loop-video {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center center;
  background: #050914;
}

#leistungen .service-card {
  isolation: isolate;
  min-height: 280px;
  padding: 24px 26px 22px;
  background: #fff;
  transform-origin: center center;
}

#leistungen .service-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    radial-gradient(190px 130px at 36% 67%, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, .99) 56%, rgba(255, 255, 255, .74) 72%, rgba(255, 255, 255, 0) 100%),
    radial-gradient(120px 82px at 22% 44%, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, .98) 58%, rgba(255, 255, 255, .66) 72%, rgba(255, 255, 255, 0) 100%),
    linear-gradient(90deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, .99) 34%, rgba(255, 255, 255, .76) 54%, rgba(255, 255, 255, .18) 78%, rgba(255, 255, 255, 0) 100%);
}

#leistungen .service-card:hover {
  transform: translateY(-6px) scale(1.015);
}

#leistungen .service-card > :not(.service-card-visual) {
  position: relative;
  z-index: 2;
  max-width: 74%;
}

#leistungen .card-number {
  width: 42px;
  height: 42px;
  margin-bottom: 50px;
  border-radius: 13px;
}

#leistungen .service-card h3 {
  margin-bottom: 8px;
  font-size: 1.08rem;
}

#leistungen .service-card p {
  font-size: .88rem;
  line-height: 1.36;
}

.service-card-visual {
  position: absolute;
  top: -24px;
  right: -12px;
  bottom: -24px;
  left: 30%;
  z-index: 0;
  display: block;
  overflow: hidden;
  border-radius: inherit;
  pointer-events: none;
  background: #fff;
}

.service-card-visual::before,
.service-card-visual::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.service-card-visual::before {
  z-index: 1;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, .94) 24%, rgba(255, 255, 255, .58) 44%, rgba(255, 255, 255, .1) 70%, rgba(255, 255, 255, 0) 100%),
    radial-gradient(180px 120px at 9% 72%, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, .98) 55%, rgba(255, 255, 255, .22) 74%, rgba(255, 255, 255, 0) 100%),
    radial-gradient(130px 92px at 12% 31%, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, .94) 56%, rgba(255, 255, 255, .16) 74%, rgba(255, 255, 255, 0) 100%);
}

.service-card-visual::after {
  z-index: 2;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .02) 0%, rgba(255, 255, 255, .1) 50%, rgba(255, 255, 255, .58) 100%);
}

.service-card-visual img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center center;
  opacity: .84;
  filter: brightness(.74) contrast(1.16) saturate(.98);
  transform: scale(1.1);
  transition: transform .55s ease, opacity .3s ease, filter .3s ease;
}

#leistungen .service-card:hover .service-card-visual img,
#leistungen .service-card:focus-within .service-card-visual img {
  opacity: .92;
  filter: brightness(.78) contrast(1.18) saturate(1.02);
  transform: scale(1.16);
}

#leistungen .service-grid .service-card:nth-child(1) .service-card-visual img {
  object-position: 68% 50%;
}

#leistungen .service-grid .service-card:nth-child(2) .service-card-visual {
  left: 36%;
}

#leistungen .service-grid .service-card:nth-child(2) .service-card-visual img {
  object-position: 50% 50%;
  opacity: .92;
  filter: brightness(.7) contrast(1.22) saturate(1.03);
}

#leistungen .service-grid .service-card:nth-child(2) .service-card-visual::before {
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, .95) 23%, rgba(255, 255, 255, .62) 43%, rgba(255, 255, 255, .12) 70%, rgba(255, 255, 255, 0) 100%),
    radial-gradient(190px 130px at 8% 72%, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, .98) 56%, rgba(255, 255, 255, .2) 74%, rgba(255, 255, 255, 0) 100%),
    radial-gradient(135px 95px at 11% 31%, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, .94) 56%, rgba(255, 255, 255, .14) 74%, rgba(255, 255, 255, 0) 100%);
}

#leistungen .service-grid .service-card:nth-child(2) .service-card-visual::after {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .02) 0%, rgba(255, 255, 255, .08) 48%, rgba(255, 255, 255, .54) 100%);
}

#leistungen .service-grid .service-card:nth-child(2):hover .service-card-visual img,
#leistungen .service-grid .service-card:nth-child(2):focus-within .service-card-visual img {
  opacity: .98;
  filter: brightness(.74) contrast(1.24) saturate(1.06);
}

#leistungen .service-grid .service-card:nth-child(3) .service-card-visual img {
  object-position: 70% 50%;
}

#prozess.process-section {
  background:
    linear-gradient(180deg, rgba(2, 4, 10, .36) 0%, rgba(2, 4, 10, .12) 46%, rgba(2, 4, 10, .58) 100%),
    linear-gradient(90deg, rgba(2, 4, 10, .56) 0%, rgba(2, 4, 10, .06) 50%, rgba(2, 4, 10, .6) 100%),
    url("webdesign-process-background.png") center center / cover no-repeat,
    #02040a;
}

#prozess.process-section .particle-canvas,
#prozess.process-section .energy-ribbon {
  display: none;
}

#prozess.process-section::after {
  opacity: .08;
}

#prozess .section-shell {
  position: relative;
  z-index: 1;
}

#prozess .section-head.center {
  max-width: 720px;
  margin-bottom: 44px;
}

#prozess .process-grid {
  gap: clamp(14px, 1.6vw, 20px);
}

#prozess .process-step {
  position: relative;
  isolation: isolate;
  min-height: 260px;
  overflow: hidden;
  border-color: rgba(255, 255, 255, .14);
  background: rgba(8, 16, 29, .62);
  box-shadow: 0 30px 90px rgba(0, 0, 0, .26), inset 0 1px 0 rgba(255, 255, 255, .08);
}

#prozess .process-step::before,
#prozess .process-step::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

#prozess .process-step::before {
  z-index: -2;
  background-size: cover;
  background-position: center center;
  opacity: .58;
  transform: scale(1.04);
  transition: transform .55s ease, opacity .25s ease, filter .25s ease;
  filter: brightness(.82) contrast(1.08) saturate(1.03);
}

#prozess .process-step::after {
  z-index: -1;
  background:
    radial-gradient(circle at 82% 12%, rgba(255, 225, 180, .16), transparent 34%),
    linear-gradient(180deg, rgba(5, 11, 22, .28) 0%, rgba(5, 11, 22, .54) 60%, rgba(5, 11, 22, .78) 100%),
    linear-gradient(90deg, rgba(5, 11, 22, .82) 0%, rgba(5, 11, 22, .54) 42%, rgba(5, 11, 22, .24) 100%);
}

#prozess .process-step:hover::before,
#prozess .process-step:focus-within::before {
  opacity: .72;
  transform: scale(1.11);
  filter: brightness(.9) contrast(1.12) saturate(1.08);
}

#prozess .process-step span,
#prozess .process-step h3,
#prozess .process-step p {
  position: relative;
  z-index: 1;
}

#prozess .process-step span {
  color: var(--gold-2);
  text-shadow: 0 8px 28px rgba(0, 0, 0, .42);
}

#prozess .process-step p {
  color: rgba(255, 255, 255, .7);
}

#prozess .process-grid .process-step:nth-child(1)::before {
  background-image: url("webdesign-process-01.png");
}

#prozess .process-grid .process-step:nth-child(2)::before {
  background-image: url("webdesign-process-02.png");
}

#prozess .process-grid .process-step:nth-child(3)::before {
  background-image: url("webdesign-process-03.png");
}

#prozess .process-grid .process-step:nth-child(4)::before {
  background-image: url("webdesign-process-04.png");
}

@media (max-width: 1080px) {
  #prozess .process-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 820px) {
  .section-bg-video-desktop {
    display: none;
  }

  .section-bg-video-mobile {
    display: block;
  }

  .section-bg-video-overlay {
    background:
      radial-gradient(circle at 50% 16%, rgba(97, 171, 255, .18), transparent 38%),
      linear-gradient(180deg, rgba(2, 4, 10, .52) 0%, rgba(2, 4, 10, .26) 44%, rgba(2, 4, 10, .82) 100%);
  }

  .webdesign-loop-card {
    min-height: 390px;
  }

  #leistungen .service-card {
    padding: 24px;
  }

  #leistungen .service-card:hover {
    transform: translateY(-4px) scale(1.01);
  }

  #leistungen .service-card > :not(.service-card-visual) {
    max-width: 78%;
  }

  .service-card-visual {
    top: -18px;
    bottom: -18px;
    left: 44%;
  }

  #leistungen .service-grid .service-card:nth-child(2) .service-card-visual {
    left: 48%;
  }

  #prozess .section-head.center {
    max-width: 620px;
    margin-bottom: 30px;
  }

  #prozess .process-grid {
    grid-template-columns: 1fr;
  }

  #prozess .process-step {
    min-height: 230px;
  }
}
