/* ===== Scrollytelling für Leistungen – Desktop & Mobil ===== */

/* Sticky-Sektion ist jetzt überall aktiv */
.lei-sticky{ display:block; position:relative; }

.lei-pin{
  position: sticky;
  top: calc(var(--pinTop, 12vh));
  min-height: 72vh;
  display: grid;
  place-items: center;
}
.lei-stage{ position: relative; width:100%; min-height:58vh; }

/* Eine Karte pro Step – übereinander gelegt */
.lei-step{
  position:absolute; left:50%; top:0;
  width: min(92vw, var(--cardMax, 980px));
  transform: translate(-50%, 20px) scale(.96);
  opacity:0; pointer-events:none; z-index:1;
  transition: transform .6s cubic-bezier(.2,.8,.2,1), opacity .6s ease;
}
.lei-step.active{
  opacity:1; transform: translate(-50%, 0) scale(1);
  pointer-events:auto; z-index:3;
}

/* Kartenaufbau – Standard: MOBIL (Icon oben, Text unten) */
.lei-card{
  display:grid;
  grid-template-columns: 1fr;            /* stacked */
  gap: 14px 18px;
  align-items:start;
}
.lei-icon{ position:relative; border-radius:12px; overflow:hidden; max-width: clamp(160px, 52vw, 260px); margin: 0 auto 8px; }
.lei-icon img{
  width:100%; height:auto; display:block;
  filter: hue-rotate(var(--hue,0deg)) drop-shadow(0 0 14px rgba(255,255,255,.28));
  transform: translateZ(0);
}
.lei-body{ max-width: 64ch; margin: 0 auto; }
.lei-body h3{ margin: .2em 0 .35em; }
.lei-body p{ line-height:1.6; }

/* Desktop: Icon links / Text rechts + größere Icons */
@media (min-width:1024px){
  .lei-card{
    grid-template-columns: clamp(140px, 16vw, 220px) 1fr;
    gap: 18px 24px;
  }
  .lei-icon{ max-width: none; margin: 0; } /* volle Spaltenbreite nutzen */
  .lei-body{ max-width: 60ch; margin: 0; }
}

/* Icon/Text-Reveal – Icon zuerst, Text 120ms später */
.lei-step .lei-icon{ opacity:0; transform: translateX(-16px); transition: opacity .55s ease, transform .55s ease; }
.lei-step .lei-body{ opacity:0; transform: translateX(16px);  transition: opacity .55s ease .12s, transform .55s ease .12s; }
.lei-step.active .lei-icon, .lei-step.active .lei-body{ opacity:1; transform:none; }

/* Shimmer beim Aktivieren */
.lei-icon::after{
  content:""; position:absolute; inset:-25%;
  background: linear-gradient(120deg,transparent 30%, rgba(255,255,255,.40) 50%, transparent 70%);
  transform: translateX(-120%) rotate(10deg);
  pointer-events:none; opacity:0;
}
.lei-step.spark .lei-icon::after{ opacity:1; animation: leiShimmer .85s ease-out both; }
@keyframes leiShimmer{ to{ transform: translateX(120%) rotate(10deg); } }

/* Fallback: Original-Grid nur dann ausblenden, wenn JS es markiert hat */
.mk-lei-grid.lei-built{ display:none !important; }
