/* =========================================
   NeuroBalance Analytics - Process Scene
   Reduzierte Version:
   - Mittelpunkt-Marker
   - links gro�e Schritt-Typografie
   - rechts nur Flie�text, keine zweite Headline
   - keine Bullet-Liste, kein Bildcontainer, keine Card
========================================= */

.nb-process-scene{
  --nb-process-stage-top: 88px;
  --nb-process-stage-height: calc(100svh - var(--nb-process-stage-top) - 24px);
  --nb-process-lane-height: min(78svh, 860px);
  --nb-process-shell-width: min(1480px, calc(100vw - 56px));
  --nb-process-focus-y: 50%;
  --nb-process-step-gap: 230px;
  --nb-process-rail-width: 2px;
  --nb-process-marker-size: 18px;

  --nb-process-ink: #081523;
  --nb-process-ink-soft: #52687f;
  --nb-process-ink-muted: rgba(8, 21, 35, .26);
  --nb-process-line: rgba(8, 21, 35, .12);
  --nb-process-line-strong: rgba(8, 21, 35, .24);
  --nb-process-accent: #00c5ff;

  position: relative;
  overflow: clip;
  padding: clamp(112px, 9vw, 156px) 0 clamp(120px, 10vw, 180px);
  color: var(--nb-process-ink);
  background:
    radial-gradient(1100px 520px at 14% 10%, rgba(16, 58, 92, .075) 0%, transparent 72%),
    radial-gradient(960px 500px at 86% 18%, rgba(0, 197, 255, .045) 0%, transparent 74%),
    linear-gradient(180deg, #f7fafc 0%, #f2f6f9 56%, #edf2f6 100%);
}

.nb-process-scene::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(90deg, rgba(10, 22, 35, .025) 1px, transparent 1px),
    linear-gradient(180deg, rgba(10, 22, 35, .02) 1px, transparent 1px);
  background-size:118px 118px;
  mask-image:linear-gradient(180deg, rgba(0,0,0,.72), rgba(0,0,0,.28) 70%, transparent 100%);
  opacity:.5;
}

.nb-process-scene-shell{
  position:relative;
  z-index:1;
  width:var(--nb-process-shell-width);
  max-width:100%;
  margin:0 auto;
}

/* Header */

.nb-process-scene-header{
  max-width:980px;
  margin:0 auto clamp(52px, 5vw, 82px);
  text-align:center;
}

.nb-process-scene-header .nb-section-label{
  justify-content:center;
}

.nb-process-scene-header .nb-section-label::after{
  content:"";
  width:38px;
  height:1px;
  background:linear-gradient(90deg, transparent, var(--nb-process-accent));
}

.nb-process-scene-header .nb-section-title{
  max-width:14ch;
  margin-inline:auto;
  color:var(--nb-process-ink);
  text-wrap:balance;
}

.nb-process-scene-header .nb-section-copy{
  max-width:66ch;
  margin-inline:auto;
  color:var(--nb-process-ink-soft);
  font-size:1.06rem;
}

/* Sticky Scene */

.nb-process-scene-scroll{
  position:relative;
  min-height:calc(var(--nb-process-steps, 6) * 110svh);
}

.nb-process-scene-stage{
  position:sticky;
  top:var(--nb-process-stage-top);
  height:var(--nb-process-stage-height);
  display:grid;
  grid-template-columns:minmax(360px, .98fr) 92px minmax(420px, .88fr);
  gap:clamp(34px, 5vw, 86px);
  align-items:center;
  overflow:visible;
}

.nb-process-scene-left,
.nb-process-scene-center,
.nb-process-scene-right{
  position:relative;
  height:var(--nb-process-lane-height);
}

/* Left labels */

.nb-process-scene-left{
  display:flex;
  justify-content:flex-end;
  align-items:stretch;
  padding-right:clamp(10px, 1.4vw, 24px);
  overflow:visible;
}

.nb-process-scene-labels{
  position:relative;
  width:min(100%, 680px);
  height:100%;
  overflow:visible;
}

.nb-process-scene-label{
  position:absolute;
  inset-inline:0;
  top:var(--nb-process-focus-y);
  transform:translateY(-50%);
  text-align:right;
  transition:opacity .28s ease, transform .34s ease, filter .28s ease;
  will-change:transform, opacity;
}

.nb-process-scene-label::after{
  content:"";
  position:absolute;
  right:-18px;
  top:50%;
  width:54px;
  height:2px;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(0,197,255,0), rgba(0,197,255,.72));
  transform:translateY(-50%) scaleX(0);
  transform-origin:right center;
  transition:transform .3s ease, opacity .3s ease;
  opacity:0;
}

.nb-process-scene-label-count{
  display:block;
  margin-bottom:12px;
  color:rgba(0,197,255,.85);
  font-size:.76rem;
  font-weight:900;
  letter-spacing:.22em;
  line-height:1;
}

.nb-process-scene-label-title{
  margin:0;
  color:rgba(8, 21, 35, .12);
  font-size:clamp(2.8rem, 5.2vw, 5.85rem);
  line-height:.88;
  font-weight:900;
  letter-spacing:-.072em;
  text-wrap:balance;
}

.nb-process-scene-label.is-current{
  opacity:1;
}

.nb-process-scene-label.is-current::after{
  opacity:1;
  transform:translateY(-50%) scaleX(1);
}

.nb-process-scene-label.is-current .nb-process-scene-label-title{
  color:var(--nb-process-ink);
}

.nb-process-scene-label.is-past{
  opacity:.42;
}

.nb-process-scene-label.is-past .nb-process-scene-label-title{
  color:rgba(8, 21, 35, .24);
}

.nb-process-scene-label.is-future{
  opacity:.18;
}

.nb-process-scene-label.is-future .nb-process-scene-label-title{
  color:rgba(8, 21, 35, .14);
}

/* Rail */

.nb-process-scene-center{
  display:flex;
  justify-content:center;
  align-items:stretch;
}

.nb-process-scene-rail{
  position:relative;
  width:100%;
  height:100%;
  overflow:visible;
}

.nb-process-scene-rail-line{
  position:absolute;
  left:50%;
  top:calc(var(--nb-process-focus-y) - var(--nb-process-rail-visible-above));
  height:calc(var(--nb-process-rail-visible-above) + var(--nb-process-rail-visible-below));
  width:var(--nb-process-rail-width);
  transform:translateX(-50%);
  border-radius:999px;
  background:linear-gradient(180deg,
    rgba(8,21,35,.18) 0%,
    rgba(8,21,35,.10) 50%,
    rgba(8,21,35,.16) 100%);
}

.nb-process-scene-rail-progress{
  position:absolute;
  left:50%;
  top:calc(var(--nb-process-focus-y) - var(--nb-process-rail-visible-above));
  width:var(--nb-process-rail-width);
  height:var(--nb-process-rail-visible-above);
  transform:translateX(-50%);
  border-radius:999px;
  background:linear-gradient(180deg, rgba(8,21,35,.98), rgba(0,197,255,.75));
}

.nb-process-scene-anchor{
  position:absolute;
  left:50%;
  top:var(--nb-process-focus-y);
  width:12px;
  height:12px;
  transform:translate(-50%, -50%);
  border-radius:50%;
  background:#fff;
  border:1px solid rgba(8,21,35,.16);
  box-shadow:0 0 0 6px rgba(255,255,255,.72);
  transition:opacity .24s ease, background-color .24s ease, border-color .24s ease;
}

.nb-process-scene-anchor.is-current{
  opacity:.16;
}

.nb-process-scene-anchor.is-past{
  background:rgba(8,21,35,.72);
  border-color:rgba(8,21,35,.42);
  opacity:.58;
}

.nb-process-scene-anchor.is-future{
  opacity:.7;
}

.nb-process-scene-marker{
  position:absolute;
  left:50%;
  top:var(--nb-process-focus-y);
  width:var(--nb-process-marker-size);
  height:var(--nb-process-marker-size);
  transform:translate(-50%, -50%);
  border-radius:50%;
  background:#071523;
  box-shadow:
    0 0 0 10px rgba(255,255,255,.94),
    0 18px 36px rgba(8,21,35,.16),
    0 0 0 1px rgba(8,21,35,.08);
  z-index:4;
}

/* Right text panels: no card, no repeated headline */

.nb-process-scene-right{
  display:flex;
  align-items:center;
  padding-left:clamp(4px, 1vw, 18px);
}

.nb-process-scene-panels{
  position:relative;
  width:100%;
  min-height:320px;
}

.nb-process-scene-panel{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  opacity:0;
  transform:translateY(18px);
  pointer-events:none;
  transition:
    opacity .3s ease,
    transform .42s cubic-bezier(.22, 1, .36, 1);
}

.nb-process-scene-panel.is-active{
  opacity:1;
  transform:none;
  pointer-events:auto;
}

.nb-process-scene-panel-head,
.nb-process-scene-panel-kicker,
.nb-process-scene-panel-title,
.nb-process-scene-panel-list,
.nb-process-scene-panel-media{
  display:none !important;
}

.nb-process-scene-panel-card{
  display:block;
  width:min(100%, 560px);
  min-height:0;
  height:auto;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  overflow:visible;
}

.nb-process-scene-panel-card::before{
  display:none;
}

.nb-process-scene-panel-content{
  width:100%;
  max-width:560px;
}

.nb-process-scene-panel-copy{
  margin:0;
  color:var(--nb-process-ink-soft);
  font-size:clamp(1.18rem, 1.55vw, 1.5rem);
  line-height:1.85;
  letter-spacing:-.01em;
}

/* Laptop */

@media (max-width: 1399.98px){
  .nb-process-scene-stage{
    grid-template-columns:minmax(320px, .95fr) 84px minmax(360px, .82fr);
    gap:clamp(28px, 4vw, 62px);
  }

  .nb-process-scene-label-title{
    font-size:clamp(2.5rem, 4.8vw, 5.1rem);
  }

  .nb-process-scene-panel-copy{
    font-size:clamp(1.08rem, 1.35vw, 1.28rem);
  }
}

@media (max-width: 1199.98px){
  .nb-process-scene{
    --nb-process-stage-top: 78px;
    --nb-process-shell-width: min(1400px, calc(100vw - 36px));
  }

  .nb-process-scene-stage{
    grid-template-columns:minmax(260px, .9fr) 72px minmax(300px, .8fr);
    gap:24px;
  }

  .nb-process-scene-label-title{
    font-size:clamp(2.15rem, 4.3vw, 4.2rem);
  }

  .nb-process-scene-label::after{
    right:-10px;
    width:38px;
  }
}

/* Tablet / Mobile: static stacked version */

@media (max-width: 991.98px){
  .nb-process-scene{
    --nb-process-shell-width:calc(100vw - 28px);
    padding:88px 0 104px;
  }

  .nb-process-scene-scroll{
    min-height:auto;
  }

  .nb-process-scene-stage{
    position:relative;
    top:auto;
    height:auto;
    display:block;
  }

  .nb-process-scene-left,
  .nb-process-scene-center,
  .nb-process-scene-right{
    height:auto;
  }

  .nb-process-scene-center{
    display:none;
  }

  .nb-process-scene-labels,
  .nb-process-scene-panels{
    position:static;
    width:100%;
    height:auto;
    min-height:0;
  }

  .nb-process-scene-left{
    display:block;
    padding-right:0;
  }

  .nb-process-scene-right{
    display:block;
    padding-left:0;
    margin-top:28px;
  }

  .nb-process-scene-label,
  .nb-process-scene-panel{
    position:relative;
    inset:auto;
    top:auto !important;
    display:block;
    opacity:1 !important;
    transform:none !important;
    pointer-events:auto;
  }

  .nb-process-scene-label{
    margin:0 0 16px;
    padding:24px 0;
    text-align:left;
    border-top:1px solid rgba(8,21,35,.10);
  }

  .nb-process-scene-label::after{
    display:none;
  }

  .nb-process-scene-label-title{
    max-width:12ch;
    color:var(--nb-process-ink) !important;
    font-size:clamp(2rem, 10vw, 3.5rem);
  }

  .nb-process-scene-panel{
    display:none;
    margin-bottom:34px;
  }

  .nb-process-scene-panel.is-active{
    display:block;
  }

  .nb-process-scene-panel-card{
    width:100%;
  }

  .nb-process-scene-panel-copy{
    font-size:1.06rem;
    line-height:1.75;
  }
}
.nb-process-scene{
  --nb-process-stage-top: 0px;
  --nb-process-stage-height: 100svh;
  --nb-process-lane-height: 100svh;
  --nb-process-shell-width: min(1480px, calc(100vw - 56px));
  --nb-process-rail-width: 2px;
  --nb-process-marker-size: 18px;
}

.nb-process-scene-stage{
  position:sticky;
  top:var(--nb-process-stage-top);
  height:var(--nb-process-stage-height);
  display:grid;
  grid-template-columns:minmax(0, 1fr) 92px minmax(0, 1fr);
  gap:clamp(56px, 6vw, 112px);
  align-items:center;
  overflow:visible;
}
.nb-process-scene-left{
  display:flex;
  justify-content:flex-end;
  align-items:stretch;
  padding-right:0;
  overflow:visible;
}

.nb-process-scene-labels{
  position:relative;
  width:min(100%, 620px);
  height:100%;
  margin-left:auto;
  overflow:visible;
}

.nb-process-scene-label{
  position:absolute;
  inset-inline:auto 0;
  width:min(100%, 620px);
  top:var(--nb-process-focus-y);
  transform:translateY(-50%);
  text-align:right;
}

.nb-process-scene-label::after{
  display:none;
}

.nb-process-scene-label-title{
  max-width:12ch;
  margin-left:auto;
  font-size:clamp(2.65rem, 4.7vw, 5.35rem);
  line-height:.9;
  letter-spacing:-.068em;
  text-wrap:balance;
}
.nb-process-scene-right{
  display:flex;
  align-items:center;
  padding-left:0;
}

.nb-process-scene-panels{
  position:relative;
  width:100%;
  max-width:620px;
  min-height:260px;
}

.nb-process-scene-panel{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  opacity:0;
  transform:translateY(18px);
  pointer-events:none;
  transition:
    opacity .3s ease,
    transform .42s cubic-bezier(.22, 1, .36, 1);
}

.nb-process-scene-panel.is-active{
  opacity:1;
  transform:none;
  pointer-events:auto;
}

.nb-process-scene-panel-content{
  width:100%;
  max-width:560px;
}

.nb-process-scene-panel-copy{
  margin:0;
  color:var(--nb-process-ink-soft);
  font-size:clamp(1.18rem, 1.55vw, 1.5rem);
  line-height:1.85;
  letter-spacing:-.01em;
}
.nb-process-scene{
  --nb-process-stage-top: 0px;
  --nb-process-stage-height: 100svh;
  --nb-process-lane-height: 100svh;
}
.nb-process-scene-stage{
  top:var(--nb-process-stage-top);
  height:var(--nb-process-stage-height);
  align-items:center;
}
.nb-process-scene{
  --nb-process-stage-top: 84px;
  --nb-process-stage-height: calc(100svh - 84px);
  --nb-process-lane-height: calc(100svh - 84px);
}
.nb-process-scene-rail-line{
  position:absolute;
  left:50%;
  top:0;
  bottom:auto;
  width:var(--nb-process-rail-width);
  height:100%;
  transform:translateX(-50%);
  border-radius:999px;
  background:linear-gradient(180deg,
    rgba(8,21,35,.18) 0%,
    rgba(8,21,35,.10) 50%,
    rgba(8,21,35,.16) 100%);
}

.nb-process-scene-rail-progress{
  position:absolute;
  left:50%;
  top:0;
  width:var(--nb-process-rail-width);
  height:0;
  transform:translateX(-50%);
  border-radius:999px;
  background:linear-gradient(180deg, rgba(8,21,35,.98), rgba(0,197,255,.75));
}
.nb-process-scene{
  padding: clamp(100px, 9vw, 130px) 0 clamp(36px, 5vw, 60px);
}
/* Mobile hard override: process scene darf mobil nicht sticky/absolute sein */
@media (max-width: 991.98px){
  .nb-process-scene{
    --nb-process-shell-width:calc(100vw - 28px);
    padding:72px 0 88px;
  }

  .nb-process-scene-scroll{
    min-height:auto !important;
  }

  .nb-process-scene-stage{
    position:relative !important;
    top:auto !important;
    height:auto !important;
    display:block !important;
  }

  .nb-process-scene-left,
  .nb-process-scene-right{
    display:block !important;
    height:auto !important;
    padding:0 !important;
  }

  .nb-process-scene-center{
    display:none !important;
  }

  .nb-process-scene-labels,
  .nb-process-scene-panels{
    position:static !important;
    width:100% !important;
    max-width:none !important;
    height:auto !important;
    min-height:0 !important;
    margin:0 !important;
    overflow:visible !important;
  }

  .nb-process-scene-label{
    position:relative !important;
    inset:auto !important;
    top:auto !important;
    left:auto !important;
    right:auto !important;
    width:100% !important;
    max-width:none !important;
    margin:0 0 16px !important;
    padding:20px 0 !important;
    text-align:left !important;
    opacity:1 !important;
    transform:none !important;
    pointer-events:auto !important;
    border-top:1px solid rgba(8,21,35,.10);
  }

  .nb-process-scene-label::after{
    display:none !important;
  }

  .nb-process-scene-label-title{
    max-width:none !important;
    margin:0 !important;
    color:var(--nb-process-ink) !important;
    font-size:clamp(1.9rem, 10vw, 3.1rem) !important;
    line-height:.96 !important;
    letter-spacing:-.05em !important;
  }

  .nb-process-scene-panel{
    position:relative !important;
    inset:auto !important;
    top:auto !important;
    width:100% !important;
    display:none !important;
    opacity:1 !important;
    transform:none !important;
    pointer-events:auto !important;
  }

  .nb-process-scene-panel.is-active{
    display:block !important;
  }

  .nb-process-scene-panel-copy{
    font-size:1.04rem !important;
    line-height:1.72 !important;
  }
}
.nb-process-scene-mobile{
  display:none;
}

@media (max-width: 991.98px){
  .nb-process-scene-scroll{
    display:none !important;
  }

  .nb-process-scene-mobile{
    display:grid;
    gap:0;
  }

  .nb-process-mobile-step{
    padding:24px 0 28px;
    border-top:1px solid rgba(8,21,35,.10);
  }

  .nb-process-mobile-step:first-child{
    border-top:0;
  }

  .nb-process-mobile-count{
    display:block;
    margin-bottom:10px;
    color:rgba(0,197,255,.9);
    font-size:.72rem;
    font-weight:900;
    letter-spacing:.22em;
    line-height:1;
  }

  .nb-process-mobile-title{
    margin:0 0 14px;
    color:var(--nb-process-ink);
    font-size:clamp(2rem, 10vw, 3.2rem);
    line-height:.96;
    font-weight:900;
    letter-spacing:-.055em;
  }

  .nb-process-mobile-copy{
    margin:0;
    color:var(--nb-process-ink-soft);
    font-size:1.04rem;
    line-height:1.72;
  }
}