.elementor-17 .elementor-element.elementor-element-b088bd5{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-17 .elementor-element.elementor-element-f4924f2{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-17 .elementor-element.elementor-element-f171c62{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-17 .elementor-element.elementor-element-5187d17{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-17 .elementor-element.elementor-element-54667a6{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-17 .elementor-element.elementor-element-d4361f0{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-17 .elementor-element.elementor-element-80e5f46{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-17 .elementor-element.elementor-element-3d66100{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}body.elementor-page-17:not(.elementor-motion-effects-element-type-background), body.elementor-page-17 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#F8FAFC;}:root{--page-title-display:none;}@media(max-width:767px){.elementor-17 .elementor-element.elementor-element-3d66100:not(.elementor-motion-effects-element-type-background), .elementor-17 .elementor-element.elementor-element-3d66100 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://svenbombach-performance.de/wp-content/uploads/2026/03/image-1-4.webp");}.elementor-17 .elementor-element.elementor-element-3d66100{--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}}/* Start custom CSS for html, class: .elementor-element-837e290 *//* ============================================================
   HERO FREELANCER FOKUS · sbf- Prefix
   Änderungen:
   - Buttons bekommen sbf-btn-fx Hover Effekt (Ripple + Arrow Move)
   - Button Padding oben und unten auf 18px
   ============================================================ */

.sbf-hero,
.sbf-hero * {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

.sbf-hero {
  position: relative;
  background: transparent;
  font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Text', 'Helvetica Neue', 'Segoe UI', Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  overflow: hidden;
}

.sbf-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 72px 32px 60px;
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 52px;
  align-items: start;
}

.sbf-left {
  display: flex;
  flex-direction: column;
  gap: 22px;
}

/* Eyebrow */
.sbf-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 700;
  color: #15803D;
  letter-spacing: 0.03em;
  background: rgba(34,197,94,.09);
  border: 1px solid rgba(34,197,94,.22);
  padding: 5px 13px;
  border-radius: 999px;
  width: fit-content;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.sbf-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #22C55E;
  flex-shrink: 0;
  animation: sbf-pulse 2s ease-in-out infinite;
}

@keyframes sbf-pulse {
  0%, 100% { opacity: 1; box-shadow: 0 0 0 0 rgba(34,197,94,.4); }
  50% { opacity: 0.5; box-shadow: 0 0 0 4px rgba(34,197,94,0); }
}

/* H1 */
.sbf-h1 {
  font-size: 42px;
  font-weight: 800;
  color: #0B1220;
  line-height: 1.16;
  letter-spacing: -0.03em;
}

.sbf-h1-em {
  font-style: normal;
  color: #2563EB;
}

/* Subline */
.sbf-sub {
  font-size: 17px;
  color: rgba(15,23,42,.75);
  line-height: 1.6;
  font-weight: 400;
}

/* Kurzprofil */
.sbf-profile {
  font-size: 14px;
  color: rgba(71,85,105,.82);
  line-height: 1.72;
  padding-left: 14px;
  border-left: 2px solid rgba(37,99,235,.22);
}

/* CTAs */
.sbf-ctas {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

/* ============================================================
   BUTTON HOVER EFFEKT
   ============================================================ */

.sbf-btn-fx {
  position: relative;
  overflow: hidden;
  transform: translateZ(0);
}

.sbf-btn-fx::before {
  content: '';
  position: absolute;
  left: var(--fx-x, 50%);
  top: var(--fx-y, 50%);
  width: 18px;
  height: 18px;
  border-radius: 999px;
  transform: translate(-50%, -50%) scale(0);
  opacity: 0;
  transition: transform 0.45s ease, opacity 0.45s ease;
  pointer-events: none;
}

.sbf-btn-fx .sbf-btn-ico {
  transition: transform 0.2s ease;
}

.sbf-btn-fx:hover .sbf-btn-ico {
  transform: translateX(2px);
}

.sbf-btn-fx:focus-visible {
  outline: 3px solid rgba(37,99,235,.25);
  outline-offset: 3px;
}

/* Optional: Ripple folgt Mausposition */
.sbf-btn-fx {
  --fx-x: 50%;
  --fx-y: 50%;
}

/* Primary CTA */
.sbf-btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 18px 28px;
  border-radius: 999px;
  background: #2563EB;
  color: #FFFFFF;
  font-size: 15px;
  font-weight: 700;
  text-decoration: none;
  transition: background 0.15s ease, transform 0.1s ease, box-shadow 0.15s ease;
  box-shadow: 0 4px 16px rgba(37,99,235,.32);
  white-space: nowrap;
}

.sbf-btn-primary::before {
  background: rgba(255,255,255,.18);
}

.sbf-btn-primary:hover {
  background: #1D4ED8;
  transform: translateY(-1px);
  box-shadow: 0 8px 24px rgba(37,99,235,.42);
}

.sbf-btn-primary:hover::before {
  transform: translate(-50%, -50%) scale(8);
  opacity: 1;
}

.sbf-btn-primary:active { transform: translateY(0); }

/* Trust Card */
.sbf-trust {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 9px 12px;
  background: rgba(255,255,255,0.78);
  border: 1px solid rgba(226,232,240,.8);
  border-radius: 14px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 2px 10px rgba(11,18,32,.05);
  width: fit-content;
  max-width: 100%;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.sbf-trust:hover {
  border-color: rgba(37,99,235,.2);
  box-shadow: 0 3px 14px rgba(37,99,235,.08);
}

.sbf-trust-avatar {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  object-fit: cover;
  object-position: center 12%;
  flex-shrink: 0;
  border: 1.5px solid rgba(226,232,240,.9);
  box-shadow: 0 2px 6px rgba(11,18,32,.08);
  display: block;
}

.sbf-trust-txt {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.sbf-trust-txt strong {
  font-size: 13.5px;
  font-weight: 700;
  color: #0B1220;
  line-height: 1.3;
  white-space: nowrap;
}

.sbf-trust-txt span {
  font-size: 12px;
  color: rgba(100,116,139,.8);
  line-height: 1.4;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sbf-trust-check {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: rgba(34,197,94,.07);
  border: 1px solid rgba(34,197,94,.12);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-left: 2px;
}

.sbf-trust-check svg { stroke: rgba(34,197,94,.9); }

/* RECHTE SPALTE */
.sbf-right {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.sbf-card {
  position: relative;
  border-radius: 16px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.sbf-card-primary {
  background: rgba(255,255,255,0.88);
  border: 1.5px solid rgba(37,99,235,.28);
  box-shadow:
    0 0 0 4px rgba(37,99,235,.05),
    0 8px 32px rgba(37,99,235,.12),
    0 2px 6px rgba(11,18,32,.06);
}

.sbf-card-primary:hover {
  transform: translateY(-3px);
  box-shadow:
    0 0 0 4px rgba(37,99,235,.08),
    0 14px 40px rgba(37,99,235,.18),
    0 2px 6px rgba(11,18,32,.06);
}

.sbf-card-secondary {
  background: rgba(255,255,255,0.72);
  border: 1px solid rgba(226,232,240,.7);
  box-shadow: 0 2px 12px rgba(11,18,32,.05);
}

.sbf-card-secondary:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(11,18,32,.08);
}

.sbf-card-badge {
  position: absolute;
  top: 14px;
  right: 14px;
  background: #2563EB;
  color: #FFFFFF;
  font-size: 10.5px;
  font-weight: 800;
  padding: 3px 10px;
  border-radius: 999px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.sbf-card-top {
  padding: 20px 20px 14px;
  border-bottom: 1px solid rgba(226,232,240,.55);
}

.sbf-card-eyebrow {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(100,116,139,.65);
  margin-bottom: 8px;
}

.sbf-card-h {
  font-size: 20px;
  font-weight: 800;
  color: #0B1220;
  line-height: 1.22;
  letter-spacing: -0.02em;
  margin-bottom: 8px;
}

.sbf-card-h-sm { font-size: 17px; }

.sbf-card-h-muted {
  font-size: 13px;
  font-weight: 500;
  color: rgba(100,116,139,.7);
  letter-spacing: 0;
}

.sbf-card-benefit {
  font-size: 13px;
  color: rgba(71,85,105,.82);
  line-height: 1.5;
}

.sbf-card-list {
  list-style: none;
  padding: 13px 20px;
  margin: 0;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.sbf-card-list li {
  font-size: 13px;
  color: rgba(71,85,105,.88);
  line-height: 1.5;
  padding-left: 16px;
  position: relative;
}

.sbf-card-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 7px;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: #2563EB;
  opacity: 0.55;
}

.sbf-card-list-sm li {
  font-size: 12.5px;
  color: rgba(100,116,139,.82);
}

.sbf-card-list-sm li::before { opacity: 0.3; }

.sbf-card-foot {
  padding: 12px 20px 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  border-top: 1px solid rgba(226,232,240,.5);
}

/* Card Buttons */
.sbf-card-btn-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 18px 18px;
  border-radius: 999px;
  background: rgba(255,255,255,.55);
  color: rgba(71,85,105,.86);
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
  border: 1px solid rgba(226,232,240,.9);
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease, transform 0.1s ease, box-shadow 0.15s ease;
  width: 100%;
}

.sbf-card-btn-outline::before {
  background: rgba(37,99,235,.10);
}

.sbf-card-btn-outline:hover {
  background: rgba(255,255,255,.82);
  color: #2563EB;
  border-color: rgba(37,99,235,.28);
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(37,99,235,.10);
}

.sbf-card-btn-outline:hover::before {
  transform: translate(-50%, -50%) scale(10);
  opacity: 1;
}

.sbf-card-micro {
  font-size: 11px;
  color: rgba(100,116,139,.6);
  text-align: center;
  line-height: 1.4;
}

/* PROOF LEISTE */
.sbf-proof {
  border-top: 1px solid rgba(226,232,240,.7);
  background: rgba(255,255,255,.6);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.sbf-proof-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 16px 32px;
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}

.sbf-proof-item {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 13px;
  font-weight: 500;
  color: rgba(71,85,105,.8);
  white-space: nowrap;
}

.sbf-proof-item svg { stroke: #22C55E; flex-shrink: 0; }

.sbf-proof-sep {
  width: 1px;
  height: 14px;
  background: rgba(226,232,240,.85);
  flex-shrink: 0;
}

.sbf-proof-green {
  color: #15803D;
  font-weight: 600;
}

.sbf-proof-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #22C55E;
  flex-shrink: 0;
  animation: sbf-pulse 2s ease-in-out infinite;
}

/* MOBILE */
@media (max-width: 960px) {
  .sbf-inner {
    grid-template-columns: 1fr;
    gap: 36px;
    padding: 48px 24px 40px;
  }
  .sbf-h1 { font-size: 32px; }
}

@media (max-width: 680px) {
  .sbf-h1 { font-size: 26px; }
  .sbf-sub { font-size: 15px; }

  .sbf-ctas {
    flex-direction: column;
    align-items: stretch;
  }

  .sbf-btn-primary {
    justify-content: center;
    text-align: center;
  }

  .sbf-trust {
    width: 100%;
    padding: 9px 11px;
  }

  .sbf-trust-txt span {
    white-space: normal;
  }

  .sbf-trust-avatar {
    width: 42px;
    height: 42px;
    border-radius: 10px;
  }

  .sbf-proof-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
    padding: 14px 20px;
  }

  .sbf-proof-sep { display: none; }
}

@media (max-width: 400px) {
  .sbf-inner { padding: 32px 16px 28px; }
  .sbf-h1 { font-size: 23px; }
  .sbf-trust-txt strong { font-size: 13px; }
  .sbf-trust-txt span { font-size: 11.5px; }
}/* ============================================================
   MICH KENNENLERNEN BUTTON · Ripple + Arrow + Colorize
   ============================================================ */

.sbf-btn-primary {
  --color-background: #2563EB;
  --color-background-hover: #1D4ED8;
  --color-outline: rgba(37,99,235,.28);
  --color-shadow: rgba(0,0,0,.28);
  --color-text: #ffffff;

  display: inline-flex;
  align-items: center;
  gap: 0;
  padding: 0.6em 0 0.6em 1.4em;
  border-radius: 999px;
  background: var(--color-background);
  color: var(--color-text);
  font-size: 16px;
  font-weight: 700;
  text-decoration: none;
  border: none;
  cursor: pointer;
  box-shadow: 0 0 0.25em 0 rgba(37,99,235,.45);
  transition: 1s;
  white-space: nowrap;
  position: relative;
  overflow: visible;
}

.sbf-btn-primary:active {
  transform: scale(0.97);
}

.sbf-btn-primary:hover {
  outline: 0.1em solid transparent;
  outline-offset: 0.2em;
  box-shadow: 0 0 1em 0 rgba(37,99,235,.55);
  animation:
    sbf-ripple 1s linear infinite,
    sbf-colorize 1s infinite;
  transition: 0.5s;
}

/* Label */
.sbf-btn-primary .sbf-btn-label {
  margin-right: 0.3em;
  transition: 0.5s;
  position: relative;
  z-index: 2;
}

.sbf-btn-primary:hover .sbf-btn-label {
  text-shadow: 5px 5px 5px var(--color-shadow);
}

.sbf-btn-primary:active .sbf-btn-label {
  text-shadow: none;
}

/* Arrow SVG */
.sbf-btn-primary svg {
  fill: var(--color-text);
  margin-right: -0.16em;
  position: relative;
  z-index: 2;
  transition: 0.5s;
  flex-shrink: 0;
}

.sbf-btn-primary:hover svg {
  margin-right: 0.55em;
  filter: drop-shadow(5px 5px 2.5px var(--color-shadow));
  transition: 0.5s;
}

.sbf-btn-primary:active svg {
  filter: none;
}

/* Polygon Animation */
.sbf-btn-primary svg polygon:nth-child(1) {
  transition: 0.4s;
  transform: translateX(-60%);
}

.sbf-btn-primary svg polygon:nth-child(2) {
  transition: 0.5s;
  transform: translateX(-30%);
}

.sbf-btn-primary:hover svg polygon:nth-child(1) {
  transform: translateX(0%);
  animation: sbf-opacity 1s infinite 0.6s;
}

.sbf-btn-primary:hover svg polygon:nth-child(2) {
  transform: translateX(0%);
  animation: sbf-opacity 1s infinite 0.4s;
}

.sbf-btn-primary:hover svg polygon:nth-child(3) {
  animation: sbf-opacity 1s infinite 0.2s;
}

/* Keyframes */
@keyframes sbf-opacity {
  0%   { opacity: 1; }
  50%  { opacity: 0; }
  100% { opacity: 1; }
}

@keyframes sbf-colorize {
  0%   { background: var(--color-background); }
  50%  { background: var(--color-background-hover); }
  100% { background: var(--color-background); }
}

@keyframes sbf-ripple {
  0%   { outline: 0em solid transparent; outline-offset: -0.1em; }
  50%  { outline: 0.2em solid var(--color-outline); outline-offset: 0.2em; }
  100% { outline: 0.4em solid transparent; outline-offset: 0.4em; }
}/* ============================================================
   OVERDRIVE: Missing Pieces
   - Trust Avatar wieder sichtbar und sauber
   - Bewerbungsmappe Button styled (secondary)
   - Höhe 18px oben/unten
   ============================================================ */

/* Trust Avatar: falls irgendwo display none oder size überschrieben wurde */
.sbf-trust-avatar{
  display: block !important;
  width: 48px !important;
  height: 48px !important;
  border-radius: 12px !important;
  object-fit: cover !important;
  object-position: center 12% !important;
  flex-shrink: 0 !important;
  border: 1.5px solid rgba(226,232,240,.9) !important;
  box-shadow: 0 2px 6px rgba(11,18,32,.08) !important;
}

/* Secondary Button Style */
.sbf-btn-secondary{
  --fx-outline: rgba(37,99,235,.22);

  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;

  padding-top: 18px !important;
  padding-bottom: 18px !important;
  padding-left: 24px !important;
  padding-right: 22px !important;

  border-radius: 999px !important;
  text-decoration: none !important;

  background: rgba(255,255,255,.75) !important;
  border: 1px solid rgba(226,232,240,.95) !important;

  color: rgba(71,85,105,.92) !important;
  font-size: 14px !important;
  font-weight: 700 !important;

  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);

  transition: background .15s ease, color .15s ease, border-color .15s ease, transform .12s ease, box-shadow .15s ease;
}

/* Icon im secondary */
.sbf-btn-secondary svg{
  stroke: currentColor !important;
}

/* Hover Secondary */
.sbf-btn-secondary:hover{
  background: rgba(255,255,255,.95) !important;
  color: #2563EB !important;
  border-color: rgba(37,99,235,.30) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 10px 26px rgba(37,99,235,.10) !important;
}

/* Ripple Farbe für Secondary */
.sbf-btn-secondary.sbf-btn-fx::before{
  background: rgba(37,99,235,.12) !important;
}/* OVERDRIVE: "Mich kennenlernen" größer */
.sbf-btn-primary{
  font-size: 17px !important;
  padding-top: 16px !important;
  padding-bottom: 16px !important;
  padding-left: 30px !important;
  padding-right: 30px !important;
}

/* Pfeil minimal größer, damit es proportional bleibt */
.sbf-btn-primary svg{
  height: 0.95em !important;
  width: 1.55em !important;
}/* ============================================================
   OVERDRIVE: Sekundäre Buttons
   - Teilzeit Remote (Card Button)
   - Bewerbungsmappe öffnen (Hero Secondary)
   - Mehr erfahren: anderer Hover
   - Höhe oben/unten immer 18px
   ============================================================ */

/* 1) Bewerbungsmappe öffnen: leichter blauer Rand */
.sbf-btn-secondary{
  border: 1px solid rgba(37,99,235,.26) !important;
  box-shadow: 0 0 0 3px rgba(37,99,235,.08) !important;
  padding-top: 18px !important;
  padding-bottom: 18px !important;
}

/* Hover: etwas "cleaner" statt stark blau */
.sbf-btn-secondary:hover{
  background: rgba(37,99,235,.06) !important;
  border-color: rgba(37,99,235,.38) !important;
  color: #1D4ED8 !important;
  box-shadow: 0 0 0 4px rgba(37,99,235,.12) !important;
}

/* 2) Teilzeit Remote Button: gleicher leichter blauer Rand */
.sbf-card-secondary .sbf-card-btn-outline{
  border: 1px solid rgba(37,99,235,.24) !important;
  box-shadow: 0 0 0 3px rgba(37,99,235,.06) !important;
  padding-top: 18px !important;
  padding-bottom: 18px !important;
}

/* 3) Mehr erfahren (alle .sbf-card-btn-outline): anderer Hover
   Ziel: weniger "button push", mehr "glow + underline" */
.sbf-card-btn-outline:hover{
  transform: none !important;
  background: rgba(255,255,255,.92) !important;
  border-color: rgba(37,99,235,.40) !important;
  color: #2563EB !important;
  box-shadow: 0 12px 34px rgba(37,99,235,.12) !important;
}

/* optional: leichter underline Effekt nur beim Text */
.sbf-card-btn-outline:hover .sbf-btn-label{
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* Icon Move etwas stärker bei "Mehr erfahren" */
.sbf-card-btn-outline:hover .sbf-btn-ico{
  transform: translateX(4px) !important;
}/* ============================================================
   FIX: Hover nur für den oberen "Mehr erfahren" Button
   Ziel: .sbf-card-primary .sbf-card-btn-outline
   ============================================================ */

.sbf-card-primary .sbf-card-btn-outline{
  border: 1px solid rgba(37,99,235,.24) !important;
  box-shadow: 0 0 0 3px rgba(37,99,235,.06) !important;
}

/* Hover greift sicher */
.sbf-card-primary .sbf-card-btn-outline:hover{
  transform: none !important;
  background: rgba(255,255,255,.92) !important;
  border-color: rgba(37,99,235,.45) !important;
  color: #2563EB !important;
  box-shadow: 0 12px 34px rgba(37,99,235,.14) !important;
}

/* Text underline */
.sbf-card-primary .sbf-card-btn-outline:hover .sbf-btn-label{
  text-decoration: underline !important;
  text-underline-offset: 3px !important;
}

/* Icon move */
.sbf-card-primary .sbf-card-btn-outline:hover .sbf-btn-ico{
  transform: translateX(4px) !important;
}/* ============================================================
   OVERRIDE: Ripple Kreis aus Buttons entfernen
   ============================================================ */

.sbf-btn-primary.sbf-btn-fx::before,
.sbf-btn-secondary.sbf-btn-fx::before,
.sbf-card-btn-outline.sbf-btn-fx::before {
  display: none !important;
}/* ============================================================
   FIX PACK: Button Konflikte auflösen
   Ziel: nur 1 Stil fuer sbf-btn-primary
   Pack das GANZ ANS ENDE
   ============================================================ */

/* Primary Button: final */
.sbf-btn-primary{
  --color-background: #2563EB;
  --color-background-hover: #1D4ED8;
  --color-outline: rgba(37,99,235,.28);
  --color-shadow: rgba(0,0,0,.28);
  --color-text: #ffffff;

  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;

  padding: 18px 30px !important;
  border-radius: 999px !important;

  background: var(--color-background) !important;
  color: var(--color-text) !important;

  font-size: 17px !important;
  font-weight: 700 !important;
  text-decoration: none !important;

  border: none !important;
  cursor: pointer !important;

  box-shadow: 0 0 0.25em 0 rgba(37,99,235,.45) !important;
  transition: 0.5s !important;

  position: relative !important;
  overflow: hidden !important; /* wichtig: sauber */
}

/* Hover Animation */
.sbf-btn-primary:hover{
  background: var(--color-background-hover) !important;
  outline: 0.1em solid transparent !important;
  outline-offset: 0.2em !important;
  box-shadow: 0 0 1em 0 rgba(37,99,235,.55) !important;
  animation: sbf-ripple 1s linear infinite, sbf-colorize 1s infinite !important;
}

/* Active */
.sbf-btn-primary:active{ transform: scale(0.98) !important; }

/* Label */
.sbf-btn-primary .sbf-btn-label{
  margin-right: 0.2em !important;
  transition: 0.5s !important;
  position: relative !important;
  z-index: 2 !important;
}

.sbf-btn-primary:hover .sbf-btn-label{
  text-shadow: 5px 5px 5px var(--color-shadow) !important;
}

/* Arrow */
.sbf-btn-primary svg{
  height: 0.95em !important;
  width: 1.55em !important;
  fill: var(--color-text) !important;
  margin-right: -0.16em !important;
  position: relative !important;
  z-index: 2 !important;
  transition: 0.5s !important;
  flex-shrink: 0 !important;
}

.sbf-btn-primary:hover svg{
  margin-right: 0.55em !important;
  filter: drop-shadow(5px 5px 2.5px var(--color-shadow)) !important;
}

/* Polygon Animation */
.sbf-btn-primary svg polygon:nth-child(1){
  transition: 0.4s !important;
  transform: translateX(-60%) !important;
}
.sbf-btn-primary svg polygon:nth-child(2){
  transition: 0.5s !important;
  transform: translateX(-30%) !important;
}
.sbf-btn-primary:hover svg polygon:nth-child(1){
  transform: translateX(0%) !important;
  animation: sbf-opacity 1s infinite 0.6s !important;
}
.sbf-btn-primary:hover svg polygon:nth-child(2){
  transform: translateX(0%) !important;
  animation: sbf-opacity 1s infinite 0.4s !important;
}
.sbf-btn-primary:hover svg polygon:nth-child(3){
  animation: sbf-opacity 1s infinite 0.2s !important;
}

/* Ripple Kreis per ::before komplett aus */
.sbf-btn-primary.sbf-btn-fx::before{ display: none !important; }

/* Keyframes bleiben wie bei dir *//* ============================================================
   FIX: Hero Background (Poster + Video) darf NICHT im Flow sein
   Ziel: Bild + Video als Layer im Hintergrund, Content drüber
   Pack ganz ans Ende
   ============================================================ */

/* Hero muss Layer Context sein */
.sbf-hero{
  position: relative !important;
  overflow: hidden !important;
}

/* Content immer über dem Background */
.sbf-inner,
.sbf-proof{
  position: relative !important;
  z-index: 2 !important;
}

/* Background Wrapper: deckt mehrere mögliche Klassennamen ab */
.sbf-hero__bg,
.sbf-bg,
.sbf-background,
.sbf-hero-bg{
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
  pointer-events: none !important;
}

/* Bild und Video dürfen nicht als Block im Flow auftauchen */
.sbf-hero__bg img,
.sbf-bg img,
.sbf-background img,
.sbf-hero-bg img,
.sbf-hero__bg video,
.sbf-bg video,
.sbf-background video,
.sbf-hero-bg video{
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  display: block !important;
  object-fit: cover !important;
}

/* Video über Poster, aber erst sichtbar wenn geladen (JS setzt Klasse) */
.sbf-hero__bg video,
.sbf-bg video,
.sbf-background video,
.sbf-hero-bg video{
  opacity: 0 !important;
  transition: opacity .45s ease !important;
}

/* Wenn JS die Klasse setzt: Video einblenden */
.sbf-hero.is-video-ready .sbf-hero__bg video,
.sbf-hero.is-video-ready .sbf-bg video,
.sbf-hero.is-video-ready .sbf-background video,
.sbf-hero.is-video-ready .sbf-hero-bg video{
  opacity: 1 !important;
}

/* Optional: leichter Overlay damit Text immer lesbar bleibt */
.sbf-hero::before{
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 1 !important;
  background: radial-gradient(
    1200px 700px at 15% 25%,
    rgba(255,255,255,.80),
    rgba(255,255,255,.25) 55%,
    rgba(255,255,255,.06) 100%
  ) !important;
  pointer-events: none !important;
}/* Safety: wenn Video spielt, sichtbar */
.sbf-bg__video[style*="display: none"] { display: block !important; }
.sbf-bg__video { opacity: 1 !important; }/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-6952ff4 *//* ================================
   ABOUT (Section 2) + Tabs Widget
   (ohne CTA Button in der linken Card)
   ================================ */

.sb-about{
  background: #FFFFFF;
  padding: 64px 0;
}

.sb-about__inner{
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 16px;
}

.sb-about__grid{
  display: grid;
  grid-template-columns: 0.95fr 1.05fr;
  gap: 40px;
  align-items: start;
}

/* Left column wrapper (Card) */
.sb-about__right{
  display: flex;
  justify-content: flex-start;
}

/* Text */
.sb-about__eyebrow{
  margin: 0 0 10px 0;
  font-weight: 800;
  font-size: 13px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(71,85,105,.95);
}

.sb-about__title{
  margin: 0 0 12px 0;
  font-size: clamp(26px, 2.6vw, 34px);
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: #0F172A;
}

.sb-about__text{
  margin: 0 0 16px 0;
  font-size: 16px;
  line-height: 1.65;
  color: rgba(71,85,105,.95);
  max-width: 720px;
}

.sb-about__bullets{
  margin: 0 0 16px 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}

.sb-about__bullets li{
  position: relative;
  padding-left: 26px;
  font-size: 15px;
  line-height: 1.6;
  color: rgba(71,85,105,.95);
}

.sb-about__bullets li::before{
  content: "";
  position: absolute;
  left: 0;
  top: .55em;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #2563EB;
  box-shadow: 0 0 0 6px rgba(37,99,235,.12);
}

.sb-about__meta{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 0 0 18px 0;
}

.sb-about__pill{
  display: inline-flex;
  align-items: center;
  padding: 8px 12px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 13px;
  color: rgba(15,23,42,.92);
  background: rgba(241,245,249,.85);
  border: 1px solid rgba(226,232,240,.95);
}

/* CTA rechts unten */
.sb-about__cta{
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.sb-about__btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 16px;
  border-radius: 999px;
  font-weight: 800;
  font-size: 15px;
  text-decoration: none;
  color: #FFFFFF;
  background: #2563EB;
  border: 1px solid rgba(37,99,235,.35);
  box-shadow: 0 14px 28px rgba(37,99,235,.22);
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}

.sb-about__btn:hover{
  transform: translateY(-1px);
  background: #1D4ED8;
  box-shadow: 0 18px 34px rgba(37,99,235,.28);
}

.sb-about__link{
  font-weight: 800;
  font-size: 14px;
  color: #1D4ED8;
  text-decoration: none;
  padding: 10px 6px;
  border-radius: 10px;
}

.sb-about__link:hover{
  background: rgba(37,99,235,.08);
}

/* ================================
   Option 3 Tabs Card
   ================================ */

.sb-pathCard{
  background: rgba(248,250,252,.95);
  border: 1px solid rgba(226,232,240,.95);
  border-radius: 22px;
  padding: 20px;
  box-shadow: 0 18px 50px rgba(2,6,23,.08);
  width: 100%;
  max-width: 560px;
}

.sb-pathCard__top{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 14px;
}

.sb-pathCard__kicker{
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: 12px;
  color: rgba(71,85,105,.95);
}

.sb-pathTabs{
  display: inline-flex;
  background: rgba(226,232,240,.55);
  border: 1px solid rgba(226,232,240,.95);
  border-radius: 999px;
  padding: 4px;
  gap: 4px;
}

.sb-pathTab{
  appearance: none;
  border: 0;
  background: transparent;
  cursor: pointer;
  font-weight: 900;
  font-size: 13px;
  color: rgba(71,85,105,.95);
  padding: 9px 12px;
  border-radius: 999px;
  transition: background .15s ease, color .15s ease, transform .15s ease, box-shadow .15s ease;
  white-space: nowrap;
}

.sb-pathTab:hover{
  transform: translateY(-1px);
  background: rgba(37,99,235,.10);
  color: #1D4ED8;
}

.sb-pathTab.is-active{
  background: #2563EB;
  color: #fff;
  box-shadow: 0 10px 22px rgba(37,99,235,.22);
}

.sb-pathPanels{ position: relative; }

.sb-pathPanel{
  display: none;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(226,232,240,.92);
  border-radius: 18px;
  padding: 16px;
}

.sb-pathPanel.is-active{
  display: block;
  animation: sbFadeSlide .22s ease-out both;
}

@keyframes sbFadeSlide{
  from{ opacity: 0; transform: translateY(6px); }
  to{ opacity: 1; transform: translateY(0); }
}

.sb-pathLead{
  margin: 0 0 12px 0;
  font-size: 14px;
  line-height: 1.55;
  color: rgba(71,85,105,.96);
}

.sb-pathList{
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}

.sb-pathList li{
  position: relative;
  padding-left: 22px;
  font-size: 14px;
  line-height: 1.55;
  color: rgba(15,23,42,.92);
}

.sb-pathList li::before{
  content: "";
  position: absolute;
  left: 0;
  top: .55em;
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: #2563EB;
  box-shadow: 0 0 0 6px rgba(37,99,235,.12);
}

.sb-pathHint{
  margin: 12px 0 0 0;
  font-size: 12.5px;
  color: rgba(71,85,105,.9);
}

/* Responsive */
@media (max-width: 980px){
  .sb-about{
    padding: 48px 0;
  }
  .sb-about__grid{
    grid-template-columns: 1fr;
    gap: 22px;
  }
  .sb-pathCard{
    max-width: none;
  }
  .sb-pathCard__top{
    flex-direction: column;
    align-items: flex-start;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-40f7571 *//* ================================
   SERVICES / LEISTUNGEN (Accordion Cards)
   + Chevron (Pfeil) statt Plus
   ================================ */

.sb-services{
  background: #F8FAFC;
  padding: 64px 0;
  border-top: 1px solid rgba(226,232,240,.7);
  border-bottom: 1px solid rgba(226,232,240,.7);
}

.sb-services__inner{
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 16px;
}

.sb-services__head{
  max-width: 720px;
  margin-bottom: 26px;
}

.sb-services__title{
  margin: 0 0 10px 0;
  font-size: clamp(26px, 2.4vw, 34px);
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: #0F172A;
}

.sb-services__subtitle{
  margin: 0;
  font-size: 16px;
  line-height: 1.6;
  color: rgba(71,85,105,.95);
}

/* Grid */
.sb-services__grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

/* Card base */
.sb-serviceCard{
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(226,232,240,.95);
  border-radius: 18px;
  padding: 0; /* Accordion steuert padding */
  box-shadow: 0 12px 30px rgba(2,6,23,.06);
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
  overflow: hidden;
}

.sb-serviceCard:hover{
  transform: translateY(-2px);
  box-shadow: 0 18px 44px rgba(2,6,23,.10);
  border-color: rgba(37,99,235,.25);
}

/* Accordion reset */
.sb-acc{ appearance: none; }
.sb-acc > summary{ list-style: none; }
.sb-acc > summary::-webkit-details-marker{ display: none; }

/* Summary area */
.sb-acc__summary{
  cursor: pointer;
  padding: 18px 18px;
}

.sb-acc__top{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 6px;
}

.sb-serviceCard__title{
  margin: 0;
  font-size: 18px;
  line-height: 1.25;
  color: #0F172A;
  letter-spacing: -0.01em;
}

.sb-serviceCard__text{
  margin: 0;
  font-size: 15px;
  line-height: 1.6;
  color: rgba(71,85,105,.95);
}

/* ================================
   ICON: Chevron (Pfeil) statt Plus
   ================================ */
.sb-acc__icon{
  width: 28px;
  height: 28px;
  border-radius: 999px;
  background: rgba(37,99,235,.10);
  border: 1px solid rgba(37,99,235,.18);
  position: relative;
  flex: 0 0 auto;
  transition: transform .18s ease, background .18s ease;
}

/* Pfeil zeichnen (▼) */
.sb-acc__icon::before{
  content:"";
  position:absolute;
  left: 50%;
  top: 50%;
  width: 8px;
  height: 8px;
  border-right: 2px solid rgba(37,99,235,.95);
  border-bottom: 2px solid rgba(37,99,235,.95);
  transform: translate(-50%,-60%) rotate(45deg);
  border-radius: 1px;
}

/* den alten zweiten Strich entfernen */
.sb-acc__icon::after{
  content: none;
}

/* Open state */
.sb-acc[open]{
  border-color: rgba(37,99,235,.28);
}
.sb-acc[open] .sb-acc__icon{
  transform: rotate(180deg);
  background: rgba(37,99,235,.14);
}

/* Content */
.sb-acc__content{
  padding: 0 18px 18px 18px;
}

.sb-acc__list{
  margin: 10px 0 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}

.sb-acc__list li{
  position: relative;
  padding-left: 22px;
  font-size: 14px;
  line-height: 1.55;
  color: rgba(15,23,42,.92);
}

.sb-acc__list li::before{
  content: "";
  position: absolute;
  left: 0;
  top: .55em;
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: #2563EB;
  box-shadow: 0 0 0 6px rgba(37,99,235,.12);
}

/* CTA Row */
.sb-services__cta{
  margin-top: 22px;
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.sb-services__note{
  margin: 0;
  font-size: 14px;
  color: rgba(71,85,105,.9);
}

/* Responsive */
@media (max-width: 980px){
  .sb-services{
    padding: 48px 0;
  }
  .sb-services__grid{
    grid-template-columns: 1fr;
  }
}/* ==========================================
   OVERDRIVE: Pfeil Effekt für Kontakt Buttons
   Greift auf .button (UIVERSE) + .sb-services__btn
   ========================================== */

.button,
a.button,
button.button,
.sb-services__btn{
  --main-size: 16px;
  --color-text: #ffffff;

  /* Clean Tech blau */
  --color-background: #2563EB;
  --color-background-hover: #1D4ED8;
  --color-outline: rgba(37,99,235,.25);
  --color-shadow: rgba(2,6,23,.35);

  cursor: pointer;
  display: inline-flex;
  justify-content: center;
  align-items: center;

  gap: 10px;

  text-decoration: none;
  border: none;
  border-radius: 999px;

  padding: 12px 16px 12px 18px;

  font-family: "Poppins", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: var(--main-size);
  line-height: 1;

  color: var(--color-text);
  background: var(--color-background);
  box-shadow: 0 0 0.2em 0 var(--color-background);

  transition: 0.5s;
  -webkit-tap-highlight-color: transparent;
}

.button:active,
.sb-services__btn:active{
  transform: scale(0.98);
}

.button:hover,
.sb-services__btn:hover{
  outline: 0.1em solid transparent;
  outline-offset: 0.2em;
  box-shadow: 0 0 1em 0 var(--color-background);
  animation: sbRipple 1s linear infinite, sbColorize 1s infinite;
  transition: 0.5s;
}

/* Text */
.button span,
.sb-services__btn span{
  margin-right: 0.3em;
  transition: 0.5s;
}

.button:hover span,
.sb-services__btn:hover span{
  text-shadow: 5px 5px 5px var(--color-shadow);
}

.button:active span,
.sb-services__btn:active span{
  text-shadow: none;
}

/* SVG */
.button svg,
.sb-services__btn svg{
  height: 0.9em;
  width: 1.4em;
  fill: var(--color-text);
  margin-right: -0.16em;
  position: relative;
  transition: 0.5s;
}

.button:hover svg,
.sb-services__btn:hover svg{
  margin-right: 0.66em;
  transition: 0.5s;
  filter: drop-shadow(5px 5px 2.5px var(--color-shadow));
}

.button:active svg,
.sb-services__btn:active svg{
  filter: none;
}

/* Polygon Animation */
.button svg polygon:nth-child(1),
.sb-services__btn svg polygon:nth-child(1){
  transition: 0.4s;
  transform: translateX(-60%);
}

.button svg polygon:nth-child(2),
.sb-services__btn svg polygon:nth-child(2){
  transition: 0.5s;
  transform: translateX(-30%);
}

.button:hover svg polygon:nth-child(1),
.sb-services__btn:hover svg polygon:nth-child(1){
  transform: translateX(0%);
  animation: sbOpacity 1s infinite 0.6s;
}

.button:hover svg polygon:nth-child(2),
.sb-services__btn:hover svg polygon:nth-child(2){
  transform: translateX(0%);
  animation: sbOpacity 1s infinite 0.4s;
}

.button:hover svg polygon:nth-child(3),
.sb-services__btn:hover svg polygon:nth-child(3){
  animation: sbOpacity 1s infinite 0.2s;
}

/* Fokus sichtbar */
.button:focus-visible,
.sb-services__btn:focus-visible{
  outline: 3px solid rgba(34,197,94,.35);
  outline-offset: 3px;
}

/* Keyframes */
@keyframes sbOpacity{
  0%{ opacity: 1; }
  50%{ opacity: 0; }
  100%{ opacity: 1; }
}

@keyframes sbColorize{
  0%{ background: var(--color-background); }
  50%{ background: var(--color-background-hover); }
  100%{ background: var(--color-background); }
}

@keyframes sbRipple{
  0%{
    outline: 0em solid transparent;
    outline-offset: -0.1em;
  }
  50%{
    outline: 0.2em solid var(--color-outline);
    outline-offset: 0.2em;
  }
  100%{
    outline: 0.4em solid transparent;
    outline-offset: 0.4em;
  }
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce){
  .button,
  .button:hover,
  .sb-services__btn,
  .sb-services__btn:hover{
    animation: none !important;
    transition: none !important;
  }
  .button svg,
  .sb-services__btn svg,
  .button span,
  .sb-services__btn span{
    filter: none !important;
    text-shadow: none !important;
    transition: none !important;
  }
}/* Button breiter machen */
.button,
a.button,
button.button,
.sb-services__btn{
  padding: 18px 12px 18px 24px; /* vorher: 12px 16px 12px 18px */
}/* ============================================================
   OVERDRIVE: Accordion Cards dürfen Nachbar-Card nicht "mitziehen"
   Ziel: In der Grid-Zeile wächst nur die geöffnete Card
   ============================================================ */

/* Grid: Items oben ausrichten statt strecken */
.sb-services__grid{
  align-items: start !important;
}

/* Jede Card ist ihre eigene Höhe */
.sb-services__grid > .sb-serviceCard{
  align-self: start !important;
  height: auto !important;
}

/* Sicherstellen, dass der Details-Content nicht durch Fremd-CSS auf 0 fällt */
.sb-serviceCard.sb-acc .sb-acc__content{
  display: block;
}

/* Optional: falls irgendwo max-height/overflow gesetzt wurde */
.sb-serviceCard.sb-acc{
  max-height: none !important;
}
.sb-serviceCard.sb-acc .sb-acc__content{
  max-height: none !important;
  overflow: visible !important;
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-6b76594 *//* ================================
   WHY SECTION (Text + Scroll Widget)
   ================================ */

.sb-whyW{
  background: #FFFFFF;
  padding: 64px 0;
}

.sb-whyW__inner{
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 16px;
}

.sb-whyW__grid{
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 28px;
  align-items: start;
}

/* Left text */
.sb-whyW__eyebrow{
  margin: 0 0 10px 0;
  font-weight: 800;
  font-size: 13px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(71,85,105,.95);
}

.sb-whyW__title{
  margin: 0 0 10px 0;
  font-size: clamp(26px, 2.4vw, 34px);
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: #0F172A;
}

.sb-whyW__subtitle{
  margin: 0 0 16px 0;
  font-size: 16px;
  line-height: 1.6;
  color: rgba(71,85,105,.95);
  max-width: 620px;
}

.sb-whyW__mini{
  margin: 0 0 18px 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}

.sb-whyW__mini li{
  position: relative;
  padding-left: 24px;
  font-size: 15px;
  line-height: 1.55;
  color: rgba(71,85,105,.95);
}

.sb-whyW__mini li::before{
  content:"";
  position:absolute;
  left:0;
  top:.55em;
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: #2563EB;
  box-shadow: 0 0 0 6px rgba(37,99,235,.12);
}

.sb-whyW__link{
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  font-weight: 900;
  color: #1D4ED8;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(37,99,235,.08);
  border: 1px solid rgba(37,99,235,.16);
  transition: transform .15s ease, background .15s ease;
}

.sb-whyW__link:hover{
  transform: translateY(-1px);
  background: rgba(37,99,235,.12);
}

/* Widget wrapper */
.sb-whyW__widget{
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 14px;
  align-items: start;
  justify-content: end;
}

/* Rail */
.sb-whyW__rail{
  position: relative;
  width: 44px;
  display: flex;
  justify-content: center;
  padding-top: 10px;
}

.sb-whyW__line{
  position: absolute;
  top: 10px;
  left: 50%;
  transform: translateX(-50%);
  width: 6px;
  height: calc(100% - 10px);
  background: rgba(37,99,235,.18);
  border-radius: 999px;
  overflow: hidden;
}

.sb-whyW__line::after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, rgba(37,99,235,1), rgba(37,99,235,.45));
  transform: translateY(100%);
  transition: transform .15s linear;
}

.sb-whyW__dots{
  display: grid;
  gap: 14px;
  position: relative;
  z-index: 2;
}

.sb-whyW__dot{
  width: 14px;
  height: 14px;
  border-radius: 999px;
  background: #FFFFFF;
  border: 2px solid rgba(37,99,235,.35);
  box-shadow: 0 0 0 6px rgba(37,99,235,.08);
  transition: transform .2s ease, background .2s ease, border-color .2s ease;
}

.sb-whyW__dot.is-active{
  background: #2563EB;
  border-color: rgba(37,99,235,.65);
  transform: scale(1.05);
}

/* Scroll card */
.sb-whyW__card{
  background: rgba(248,250,252,.95);
  border: 1px solid rgba(226,232,240,.95);
  border-radius: 18px;
  box-shadow: 0 18px 50px rgba(2,6,23,.08);
  padding: 14px;
  max-height: 320px;
  overflow: auto;
  scroll-behavior: smooth;
}

/* nicer scrollbar (optional) */
.sb-whyW__card::-webkit-scrollbar{
  width: 10px;
}
.sb-whyW__card::-webkit-scrollbar-thumb{
  background: rgba(148,163,184,.55);
  border-radius: 999px;
  border: 3px solid rgba(248,250,252,.95);
}
.sb-whyW__card::-webkit-scrollbar-track{
  background: transparent;
}

.sb-whyW__item{
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(226,232,240,.85);
  background: rgba(255,255,255,.85);
  margin-bottom: 12px;
}

.sb-whyW__item:last-child{
  margin-bottom: 0;
}

.sb-whyW__item h3{
  margin: 0 0 6px 0;
  font-size: 15px;
  color: #0F172A;
  letter-spacing: -0.01em;
}

.sb-whyW__item p{
  margin: 0;
  font-size: 14px;
  line-height: 1.55;
  color: rgba(71,85,105,.95);
}

/* Responsive */
@media (max-width: 980px){
  .sb-whyW{
    padding: 48px 0;
  }
  .sb-whyW__grid{
    grid-template-columns: 1fr;
  }
  .sb-whyW__widget{
    grid-template-columns: 1fr;
  }
  .sb-whyW__rail{
    display: none;
  }
  .sb-whyW__card{
    max-height: 360px;
  }
}/* Fill-Segment in der Linie (nur zwischen sichtbaren Punkten) */
.sb-whyW__line{
  position: relative; /* wichtig */
}

.sb-whyW__lineFill{
  position: absolute;
  left: 0;
  width: 100%;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(37,99,235,1), rgba(37,99,235,.45));
  top: 0;
  height: 0;
  transition: top .12s linear, height .12s linear;
}/* ===== OVERRIDE: Rail/Dots rechts neben die Card ===== */
.sb-whyW__widget{
  grid-template-columns: 1fr 44px !important; /* Card | Rail */
}

.sb-whyW__rail{
  grid-column: 2 !important;
  grid-row: 1 !important;
  justify-content: center !important;
}

.sb-whyW__card{
  grid-column: 1 !important;
  grid-row: 1 !important;
}

/* Optional: bisschen Abstand zur Card */
.sb-whyW__widget{
  gap: 14px !important; /* hier kannst du erhöhen */
}/* ===== OVERRIDE: Why-Section Hintergrund wie die anderen (leicht grau) ===== */
.sb-whyW{
  background: #F8FAFC !important;               /* leichter Grau-Ton */
  border-top: 1px solid rgba(226,232,240,.7);
  border-bottom: 1px solid rgba(226,232,240,.7);
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-b56772d *//* ================================
   CERTS TEASER – 2x2 Grid (gleichwertig)
   Background: Weiß
   ================================ */

.sb-certsD{
  background: #FFFFFF; /* <<< wie gewünscht weiß */
  padding: 64px 0;
}

.sb-certsD__inner{
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 16px;
}

.sb-certsD__grid{
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 22px;
  align-items: start;
}

/* Copy */
.sb-certsD__eyebrow{
  margin: 0 0 10px 0;
  font-weight: 800;
  font-size: 13px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(71,85,105,.95);
}

.sb-certsD__title{
  margin: 0 0 10px 0;
  font-size: clamp(26px, 2.4vw, 34px);
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: #0F172A;
}

.sb-certsD__subtitle{
  margin: 0 0 14px 0;
  font-size: 16px;
  line-height: 1.6;
  color: rgba(71,85,105,.95);
  max-width: 620px;
}

.sb-certsD__link{
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  font-weight: 900;
  color: #1D4ED8;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(37,99,235,.08);
  border: 1px solid rgba(37,99,235,.16);
  transition: transform .15s ease, background .15s ease;
}

.sb-certsD__link:hover{
  transform: translateY(-1px);
  background: rgba(37,99,235,.12);
}

/* Cards wrapper (clickable) */
.sb-certsD__cards{
  text-decoration: none;
  color: inherit;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

/* Card base */
.sb-certD{
  background: rgba(248,250,252,.95);
  border: 1px solid rgba(226,232,240,.95);
  border-radius: 18px;
  box-shadow: 0 18px 50px rgba(2,6,23,.08);
  overflow: hidden;
  transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
  display: grid;
  grid-template-rows: auto 1fr;
}

.sb-certD:hover{
  transform: translateY(-2px);
  box-shadow: 0 24px 70px rgba(2,6,23,.12);
  border-color: rgba(37,99,235,.30);
}

/* Media */
.sb-certD__media{
  position: relative;
  background: rgba(255,255,255,.92);
  border-bottom: 1px solid rgba(226,232,240,.85);
}

.sb-certD__media img{
  width: 100%;
  height: 140px;
  object-fit: contain;
  display: block;
  padding: 12px;
}

/* Badge TOP */
.sb-certD__badge{
  position: absolute;
  top: 12px;
  left: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  font-weight: 900;
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #1D4ED8;
  background: rgba(37,99,235,.10);
  border: 1px solid rgba(37,99,235,.18);
}

/* Body */
.sb-certD__body{
  padding: 12px 14px 14px 14px;
}

.sb-certD__title{
  margin: 0;
  font-weight: 900;
  color: #0F172A;
  letter-spacing: -0.01em;
  line-height: 1.2;
  font-size: 15px;
}

.sb-certD__meta{
  margin: 6px 0 0 0;
  font-size: 13px;
  color: rgba(71,85,105,.92);
}

/* Slight emphasis for TOP without breaking grid symmetry */
.sb-certD--top{
  border-color: rgba(37,99,235,.22);
  box-shadow: 0 22px 70px rgba(37,99,235,.10);
}

/* Ausbildung: minimal anderer Ton (aber gleichwertig) */
.sb-certD--edu .sb-certD__meta{
  color: rgba(71,85,105,.95);
}

/* Responsive */
@media (max-width: 980px){
  .sb-certsD{
    padding: 48px 0;
  }
  .sb-certsD__grid{
    grid-template-columns: 1fr;
  }
  .sb-certD__media img{
    height: 130px;
  }
}/* ===== Zertifikate Teaser: Extras gegen "leere Fläche" ===== */
.sb-certsD__extras{
  margin-top: 14px;
  display: grid;
  gap: 12px;
  max-width: 560px;
}

.sb-certsD__pills{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.sb-certsD__pill{
  display: inline-flex;
  align-items: center;
  padding: 8px 12px;
  border-radius: 999px;
  font-weight: 800;
  font-size: 13px;
  color: rgba(15,23,42,.92);
  background: rgba(241,245,249,.9);
  border: 1px solid rgba(226,232,240,.95);
}

.sb-certsD__miniList{
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 8px;
}

.sb-certsD__miniList li{
  position: relative;
  padding-left: 22px;
  font-size: 14px;
  line-height: 1.6;
  color: rgba(71,85,105,.95);
}

.sb-certsD__miniList li::before{
  content:"";
  position: absolute;
  left: 0;
  top: .6em;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #2563EB;
  box-shadow: 0 0 0 6px rgba(37,99,235,.10);
}.sb-certsD__cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  text-decoration: none;
  color: inherit;
}

.sb-certD {
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-7200d65 *//* ============================================================
   NEXT STEP CTA (Bewerbungs-Layout) · sb-next
   ============================================================ */

.sb-next{
  padding: 64px 0;
  background: transparent;
}

.sb-next__inner{
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 16px;
}

.sb-nextCard{
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 18px;

  border-radius: 22px;
  background: rgba(255,255,255,.85);
  border: 1px solid rgba(226,232,240,.95);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 18px 60px rgba(2,6,23,.08);

  padding: 22px;
}

/* Left */
.sb-nextCard__eyebrow{
  margin: 0 0 8px 0;
  font-weight: 900;
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(71,85,105,.9);
}

.sb-nextCard__title{
  margin: 0 0 10px 0;
  font-size: clamp(22px, 2.2vw, 30px);
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: #0F172A;
}

.sb-nextCard__text{
  margin: 0 0 14px 0;
  font-size: 15.5px;
  line-height: 1.7;
  color: rgba(71,85,105,.95);
  max-width: 60ch;
}

.sb-nextCard__pills{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.sb-nextCard__pill{
  display: inline-flex;
  align-items: center;
  padding: 9px 12px;
  border-radius: 999px;
  font-weight: 800;
  font-size: 13px;
  color: rgba(15,23,42,.92);
  background: rgba(37,99,235,.08);
  border: 1px solid rgba(37,99,235,.18);
}

/* Right */
.sb-nextCard__right{
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: flex-start;
  justify-content: center;
}

.sb-nextCard__btn{
  text-decoration: none;
  border-radius: 999px;
  font-weight: 900;
}

/* Secondary link button */
.sb-nextCard__btn--secondary{
  display: inline-flex;
  align-items: center;
  justify-content: center;

  padding: 18px 22px;
  border-radius: 999px;

  background: rgba(255,255,255,.75);
  border: 1px solid rgba(37,99,235,.26);

  color: #1D4ED8;
  font-size: 15px;
  font-weight: 900;

  transition: background .15s ease, border-color .15s ease, transform .12s ease, box-shadow .15s ease;
}

.sb-nextCard__btn--secondary:hover{
  background: rgba(37,99,235,.06);
  border-color: rgba(37,99,235,.40);
  transform: translateY(-1px);
  box-shadow: 0 12px 30px rgba(37,99,235,.12);
}

.sb-nextCard__hint{
  margin: 2px 0 0 0;
  font-size: 13px;
  color: rgba(71,85,105,.85);
}

/* Responsive */
@media (max-width: 980px){
  .sb-next{
    padding: 48px 0;
  }
  .sb-nextCard{
    grid-template-columns: 1fr;
  }
  .sb-nextCard__right{
    align-items: stretch;
  }
  .sb-nextCard__btn--secondary{
    width: 100%;
  }
}/* End custom CSS */