/* =========================================
   Landing Page – Optimierte Styles
   Abhängig von layout.css (Tokens/Buttons/Container)
   ========================================= */

   .landing{
    --accent: var(--brand);
    --panel: var(--surface);
    --line: var(--border);
  }
  
  /* ============ Sections / Rhythm ============ */
  
  .landing .section{
    position: relative;
    padding-top: clamp(40px, 3vw, 100px);
    padding-bottom: clamp(10px, .75vw, 25px);
  }
  
  .landing .section-inner{
    display: grid;
    gap: 36px;
    grid-template-columns: 1fr;
  }
  
  .landing .section-grid-2{
    display: grid;
    gap: 24px;
    grid-template-columns: 1fr;
    align-items: start;
  }
  
  .landing .section--band{
    padding-top: 18px;
    padding-bottom: 12px;
  }
  
  .landing .section--video{
    padding-top: 30px;
  }
  
  /* ============ Type ============ */
  
  .landing .headline{
    font-weight: 800;
    line-height: 1.05;
  }
  
  .landing .h2{
    font-size: clamp(1.8rem, 4vw, 2.6rem);
  }
  
  .landing .h3{
    font-size: clamp(1.6rem, 3vw, 2.2rem);
  }
  
  .landing .sub{
    color: var(--muted);
    font-size: clamp(1rem, 1.2vw, 1.125rem);
  }
  
  .landing .eyebrow{
    letter-spacing: .14em;
    text-transform: uppercase;
    font-weight: 700;
    color: var(--accent);
    font-size: .8rem;
  }
  
  .landing .muted{
    color: var(--muted);
  }
  
  .landing .top-gap{
    margin-top: 18px;
  }
  
  .landing .ink-accent,
  .landing .ink-accent-main{
    color: var(--brand);
  }
  
  .landing .ink-accent-main{
    font-size: 1.1rem;
  }
  
  .landing .ink-accent-sub{
    color: color-mix(in oklab, var(--text) 78%, var(--muted) 22%);
  }
  
  /* ============ CTA Row ============ */
  
  .landing .cta-row{
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 12px;
  }
  
  /* ============ HERO (Copy / Media / UI) ============ */
  
  .landing .hero-copy{
    display: grid;
    gap: 14px;
    align-content: start;
  }
  
  .landing .hero-ui{
    display: grid;
    gap: 10px;
    margin-top: 10px;
  }
  
  .landing .hero-pill{
    display: inline-flex;
    align-items: center;
    gap: 10px;
    width: fit-content;
    padding: 8px 12px;
    border-radius: 999px;
    border: 1px solid var(--line);
    background: color-mix(in oklab, var(--panel) 88%, transparent);
    box-shadow: 0 10px 22px rgba(0,0,0,.18);
  }
  
  .landing .hero-tag{
    font-size: .85rem;
    color: color-mix(in oklab, var(--text) 86%, var(--muted) 14%);
    line-height: 1.2;
  }
  
  .landing .hero-grid{
    display: grid;
    gap: 12px;
    grid-template-columns: 1fr;
    margin-top: 8px;
  }
  
  .landing .hero-card{
    border: 1px solid var(--line);
    border-radius: 16px;
    padding: 14px;
    background: linear-gradient(
      180deg,
      color-mix(in oklab, var(--panel) 94%, #fff 6%),
      var(--panel)
    );
    box-shadow: 0 10px 22px rgba(0,0,0,.16);
  }
  
  .landing .hero-media{
    position: relative;
    min-height: 260px;
    border-radius: 24px;
    overflow: hidden;
    background:
      radial-gradient(1200px 500px at 10% 10%, color-mix(in oklab, var(--accent) 22%, transparent), transparent 50%),
      radial-gradient(900px 400px at 80% 40%, color-mix(in oklab, var(--accent) 14%, transparent), transparent 60%),
      linear-gradient(180deg, color-mix(in oklab, var(--panel) 92%, #000 8%), var(--panel));
    border: 1px solid var(--line);
    box-shadow: var(--shadow);
  }
  
  .landing .hero-media-img{
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    opacity: .96;
  }
  
  .landing .hero-orb{
    position: absolute;
    right: -120px;
    bottom: -120px;
    width: 420px;
    height: 420px;
    border-radius: 50%;
    background: radial-gradient(circle at 30% 30%, #fff, var(--accent));
    filter: blur(10px);
    opacity: .14;
    animation: float-orb 14s ease-in-out infinite alternate;
  }
  
  /* ============ Logos ============ */
  
  .landing .logos-lead{
    margin-top: 14px;
  }
  
  .landing .logo-row{
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    align-items: center;
    justify-items: center;
    filter: grayscale(1);
    opacity: .7;
  }
  
  .landing .logo-row img{
    height: 28px;
  }
  
  /* ============ Metrics ============ */
  
  .landing .metrics{
    display: flex;
    flex-wrap: wrap;
    gap: 14px 26px;
    margin-top: 14px;
  }
  
  .landing .metric{
    min-width: 120px;
  }
  
  .landing .metric strong{
    display: block;
    font-size: 2rem;
    color: var(--brand);
  }
  
  .landing .metric span{
    font-size: 1rem;
    color: var(--muted);
  }
  
  /* ============ CTA BAND ============ */
  
  .landing .cta-band{
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    flex-wrap: wrap;
    padding: 16px 20px;
    margin-block: 8px 18px;
    border-radius: 16px;
    border: 1px dashed var(--line);
    background: linear-gradient(
      90deg,
      color-mix(in oklab, var(--brand) 8%, transparent),
      transparent
    );
    box-shadow: 0 8px 20px rgba(0,0,0,.25);
  }
  
  .landing .cta-band-title{
    font-size: clamp(1.05rem, 2vw, 1.4rem);
    font-weight: 700;
  }
  
  .landing .cta-band-sub{
    font-size: clamp(.98rem, 1.6vw, 1.15rem);
    color: var(--muted);
    margin-top: 2px;
  }
  
  .landing .cta-band-actions{
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
  }
  
  /* ============ FEATURES / STACK ============ */
  
  .landing .features{
    display: grid;
    gap: 18px;
  }
  
  .landing .features-stack{
    display: grid;
    gap: 18px;
  }
  
  .landing .features-intro{
    max-width: 780px;
  }
  
  .landing .features-flow{
    width: 100%;
  }
  
  .landing .features-col{
    place-self: start;
    width: 100%;
  }
  
  /* ============ Cards ============ */
  
  .landing .cards{
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
  }
  
  .landing .cards--two{
    grid-template-columns: 1fr;
  }
  
  .landing .card{
    position: relative;
    overflow: hidden;
    min-height: 200px;
    padding: 20px;
    border-radius: 16px;
    border: 1px solid var(--line);
    background: linear-gradient(
      180deg,
      color-mix(in oklab, var(--panel) 94%, #fff 6%),
      var(--panel)
    );
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
    display: flex;
    flex-direction: column;
  }
  
  .landing .card:hover{
    transform: translateY(-3px);
    box-shadow: 0 10px 28px rgba(0,0,0,.32);
    border-color: color-mix(in oklab, var(--brand) 22%, var(--line));
  }
  
  .landing .card::after{
    content: "";
    position: absolute;
    inset: auto -40px -40px auto;
    width: 140px;
    height: 140px;
    border-radius: 50%;
    background: radial-gradient(circle at 30% 30%, #fff, var(--accent));
    filter: blur(18px);
    opacity: .07;
  }
  
  .landing .icon{
    width: 44px;
    height: 44px;
    border-radius: 12px;
    border: 1px solid var(--line);
    background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.01));
    display: grid;
    place-items: center;
    margin-bottom: 12px;
  }
  
  /* ============ Dynamisches Diagramm / Flow ============ */
  
  .landing .flow-card{
    position: relative;
    width: 100%;
    margin: 0;
    border: 1px solid color-mix(in oklab, var(--line) 86%, var(--brand) 14%);
    border-radius: 26px;
    padding: 18px;
    background:
      radial-gradient(900px 220px at 10% 0%, color-mix(in oklab, var(--brand) 8%, transparent), transparent 60%),
      linear-gradient(
        180deg,
        color-mix(in oklab, var(--panel) 98%, #fff 2%),
        color-mix(in oklab, var(--panel) 94%, #000 6%)
      );
    box-shadow:
      0 18px 48px rgba(0,0,0,.18),
      inset 0 1px 0 rgba(255,255,255,.04);
  }
  
  .landing .flow-card__head{
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
    flex-wrap: wrap;
    margin-bottom: 16px;
  }
  
  .landing .flow-card__title{
    margin: 4px 0 0;
  }
  
  .landing .flow-diagram{
    position: relative;
    width: 100%;
    min-height: 360px;
    margin: 0;
    border-radius: 20px;
    overflow: hidden;
    border: 1px solid color-mix(in oklab, var(--line) 88%, transparent);
    background:
      linear-gradient(
        180deg,
        color-mix(in oklab, var(--panel) 96%, #0b1220 4%) 0%,
        color-mix(in oklab, var(--panel) 100%, #fff 0%) 100%
      );
    isolation: isolate;
  }
  
  .landing .flow-diagram__svg{
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    display: block;
    color: color-mix(in oklab, var(--brand) 78%, #7aa2ff 22%);
    z-index: 1;
  }
  
  .landing .flow-diagram__nodes{
    position: absolute;
    inset: 0;
    z-index: 2;
  }
  
  .landing .flow-label,
  .landing .flow-node{
    position: absolute;
    transform: translate(-50%, -50%);
  }
  
  .landing .flow-label.caption{
    font-size: .84rem;
    color: color-mix(in oklab, var(--text) 68%, var(--muted) 32%);
    transform: translate(-50%, 0);
    text-align: center;
    white-space: nowrap;
  }
  
  .landing .flow-node.circle{
    width: 54px;
    height: 54px;
    border-radius: 50%;
    background: #111444;
    border: 1px solid color-mix(in oklab, #111444 82%, #ffffff 18%);
    box-shadow:
      0 10px 24px rgba(17,20,68,.24),
      inset 0 1px 0 rgba(255,255,255,.14);
  }
  
  .landing .flow-node.box{
    width: 150px;
    min-height: 78px;
    padding: 12px 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    line-height: 1.3;
    font-size: clamp(.92rem, .95vw, 1rem);
    color: color-mix(in oklab, var(--text) 92%, #0f172a 8%);
    border: 1px solid color-mix(in oklab, var(--line) 78%, var(--brand) 22%);
    border-radius: 16px;
    background:
      linear-gradient(
        180deg,
        color-mix(in oklab, #ffffff 96%, var(--brand) 4%),
        color-mix(in oklab, var(--panel) 94%, #fff 6%)
      );
    box-shadow:
      0 10px 22px rgba(0,0,0,.08),
      inset 0 1px 0 rgba(255,255,255,.7);
    backdrop-filter: blur(6px);
  }
  
  .landing .flow-node.box strong{
    font-weight: 800;
    color: var(--brand);
  }
  
  .landing .flow-node.box.report-box{
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
  }
  
  .landing .flow-node.box.report-box span,
  .landing .flow-node.box.report-box strong{
    display: block;
    width: 100%;
    text-align: center;
  }
  
  .landing .flow-node.box.report-box strong{
    font-weight: 800;
    color: var(--brand);
  }
  
  .landing .flow-edge{
    stroke: currentColor;
    stroke-width: 2.5;
    stroke-linecap: round;
    stroke-linejoin: round;
    fill: none;
    opacity: .95;
  }
  
  /* ============ Highlight Cards ============ */
  
  .landing .cards.top-gap{
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
  }
  
  .landing .cards.top-gap .card{
    --hi: var(--accent);
    border-radius: 18px;
    padding: 22px;
    min-height: 180px;
  }
  
  .landing .cards.top-gap .card:nth-child(3n+2){
    --hi: var(--info);
  }
  
  .landing .cards.top-gap .card:nth-child(3n){
    --hi: var(--warn);
  }
  
  .landing .cards.top-gap .card:hover{
    border-color: color-mix(in oklab, var(--hi) 28%, var(--line));
    box-shadow: 0 14px 28px rgba(0,0,0,.32);
  }
  
  .landing .cards.top-gap .card::before{
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    height: 3px;
    width: 100%;
    background: linear-gradient(
      90deg,
      color-mix(in oklab, var(--hi) 85%, #fff 15%),
      transparent 120%
    );
    transform: scaleX(.6);
    transform-origin: left center;
    opacity: .85;
    transition: transform .25s ease;
  }
  
  .landing .cards.top-gap .card:hover::before{
    transform: scaleX(1);
  }
  
  .landing .cards.top-gap .icon{
    width: 50px;
    height: 50px;
    border-radius: 14px;
    background:
      radial-gradient(circle at 30% 30%, rgba(255,255,255,.16), rgba(255,255,255,.02)),
      linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.01));
    border: 1px solid color-mix(in oklab, var(--hi) 35%, var(--line));
    box-shadow:
      0 0 0 1px var(--line),
      0 0 18px color-mix(in oklab, var(--hi) 18%, transparent);
  }
  
  .landing .cards.top-gap h4{
    margin: 6px 0;
    letter-spacing: .2px;
  }
  
  .landing .cards.top-gap p{
    margin: 0;
  }
  
  /* ============ Benefits Loop with Progress ============ */
  
  .landing .benefits-sequence{
    perspective: 1200px;
  }
  
  .landing .benefit-card{
    position: relative;
    overflow: hidden;
    opacity: .45;
    transform: translateY(10px) scale(.985);
    filter: blur(1px);
    transition:
      opacity .45s ease,
      transform .45s cubic-bezier(.22,1,.36,1),
      filter .45s ease,
      box-shadow .35s ease,
      border-color .35s ease;
    isolation: isolate;
  }
  
  .landing .benefit-card.active{
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
    border-color: color-mix(in oklab, var(--brand) 28%, var(--line));
    box-shadow:
      0 18px 40px rgba(0,0,0,.24),
      0 0 0 1px color-mix(in oklab, var(--brand) 14%, transparent),
      0 0 24px color-mix(in oklab, var(--brand) 10%, transparent);
  }
  
  .landing .benefit-card::before{
    content: "";
    position: absolute;
    left: 18px;
    right: 18px;
    top: 0;
    height: 2px;
    border-radius: 999px;
    background: linear-gradient(
      90deg,
      color-mix(in oklab, var(--brand) 78%, #fff 22%),
      color-mix(in oklab, var(--info) 55%, transparent),
      transparent 85%
    );
    transform: scaleX(.18);
    transform-origin: left center;
    opacity: .35;
    transition:
      transform .7s cubic-bezier(.22,1,.36,1),
      opacity .35s ease;
  }
  
  .landing .benefit-card.active::before{
    transform: scaleX(1);
    opacity: .95;
  }
  
  .landing .benefit-card__grid{
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    opacity: .08;
    background-image:
      linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
      linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
    background-size: 22px 22px;
    mask-image: linear-gradient(180deg, rgba(0,0,0,.95), rgba(0,0,0,.08));
    transition: opacity .35s ease;
  }
  
  .landing .benefit-card.active .benefit-card__grid{
    opacity: .22;
  }
  
  .landing .benefit-card__beam{
    position: absolute;
    top: -30%;
    left: -60%;
    width: 55%;
    height: 160%;
    pointer-events: none;
    z-index: 1;
    opacity: 0;
    background: linear-gradient(
      90deg,
      transparent 0%,
      rgba(255,255,255,.00) 20%,
      rgba(255,255,255,.16) 50%,
      rgba(255,255,255,.00) 80%,
      transparent 100%
    );
    transform: skewX(-22deg) translateX(0);
  }
  
  .landing .benefit-card.active .benefit-card__beam{
    animation: fintech-sheen 1s cubic-bezier(.22,1,.36,1) forwards;
  }
  
  .landing .benefit-card__content{
    position: relative;
    z-index: 2;
  }
  
  .landing .benefit-card h3,
  .landing .benefit-card p{
    position: relative;
    z-index: 2;
    opacity: 1;
    transition:
      transform .4s cubic-bezier(.22,1,.36,1),
      opacity .4s ease;
  }
  
  .landing .benefit-card h3{
    transform: translateY(4px);
  }
  
  .landing .benefit-card p{
    transform: translateY(6px);
  }
  
  .landing .benefit-card.active h3,
  .landing .benefit-card.active p{
    transform: translateY(0);
    opacity: 1;
  }
  
  /* Progress Track */
  .landing .benefit-card__progress{
    position: relative;
    z-index: 2;
    margin-top: 16px;
    width: 100%;
    height: 6px;
    border-radius: 999px;
    overflow: hidden;
    background: color-mix(in oklab, var(--line) 72%, transparent);
    box-shadow: inset 0 1px 2px rgba(0,0,0,.18);
  }
  
  /* Progress Fill */
  .landing .benefit-card__progress-bar{
    display: block;
    width: 0%;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(
      90deg,
      color-mix(in oklab, var(--brand) 88%, #fff 12%),
      color-mix(in oklab, var(--info) 72%, var(--brand) 28%)
    );
    box-shadow: 0 0 16px color-mix(in oklab, var(--brand) 20%, transparent);
  }
  
  /* Nur aktive Karte animiert */
  .landing .benefit-card.active .benefit-card__progress-bar{
    animation: benefit-progress 2s linear forwards;
  }
  
  @keyframes benefit-progress{
    from{ width: 0%; }
    to{ width: 100%; }
  }
  
  @keyframes fintech-sheen{
    0%{
      opacity: 0;
      transform: skewX(-22deg) translateX(0);
    }
    15%{
      opacity: .9;
    }
    100%{
      opacity: 0;
      transform: skewX(-22deg) translateX(320%);
    }
  }
  
  /* ============ Slider / Testimonials ============ */
  
  .landing .slider{
    position: relative;
    overflow: hidden;
    padding: 0;
    border-radius: 24px;
    border: 1px solid color-mix(in oklab, var(--line) 80%, var(--brand) 20%);
    background:
      linear-gradient(180deg, color-mix(in oklab, var(--brand) 8%, transparent), transparent 55%),
      linear-gradient(180deg, color-mix(in oklab, var(--panel) 96%, #000 4%), var(--panel));
    box-shadow: var(--shadow);
  }
  
  .landing .slides{
    display: flex;
    align-items: stretch;
    height: 100%;
    padding: 0;
    margin: 0;
    will-change: transform;
    transition: transform .6s ease;
  }
  
  .landing .slide,
  .landing figure.slide{
    position: relative;
    flex: 0 0 100%;
    width: 100%;
    min-width: 100%;
    margin: 0;
    box-sizing: border-box;
    padding: 16px 16px 18px;
    border-radius: 18px;
    background: linear-gradient(
      180deg,
      color-mix(in oklab, var(--panel) 96%, #fff 4%),
      var(--panel)
    );
    border: 1px solid color-mix(in oklab, var(--line) 86%, var(--brand) 14%);
    box-shadow: 0 8px 22px rgba(0,0,0,.22);
    display: flex;
    flex-direction: column;
    gap: 14px;
    min-height: clamp(150px, 26vh, 210px);
  }
  
  .landing .slide::before{
    content: "";
    position: absolute;
    left: 18px;
    right: 18px;
    top: 10px;
    height: 2px;
    border-radius: 999px;
    background: color-mix(in oklab, var(--brand) 55%, transparent);
    opacity: .25;
    pointer-events: none;
  }
  
  .landing .slide-link{
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-height: 100%;
    color: inherit;
    text-decoration: none;
    gap: 14px;
  }
  
  .landing .slide-link:focus-visible{
    outline: 3px solid color-mix(in oklab, var(--brand) 45%, transparent);
    outline-offset: 4px;
    border-radius: var(--radius);
  }
  
  .landing .slide-link:hover .slide{
    border-color: color-mix(in oklab, var(--brand) 22%, var(--line));
    box-shadow: 0 10px 28px rgba(0,0,0,.26);
  }
  
  .landing .quote{
    margin: 0;
    flex: 1 1 auto;
    font-size: clamp(1rem, 1vw, 1.12rem);
    line-height: 1.55;
    color: color-mix(in oklab, var(--text) 92%, var(--muted) 8%);
  }
  
  .landing .quote p{
    margin: 0;
    position: relative;
    padding: 12px 12px 12px 16px;
    border-left: 3px solid color-mix(in oklab, var(--brand) 45%, var(--line));
    border-radius: 10px;
    background: color-mix(in oklab, var(--panel) 92%, transparent);
    font-size: 1.15rem;
  }
  
  .landing .quote p::before,
  .landing .quote p::after{
    content: "";
    position: absolute;
    font-size: 2.2rem;
    line-height: 1;
    color: color-mix(in oklab, var(--brand) 35%, transparent);
  }
  
  .landing .person{
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: auto;
    padding-top: 12px;
    border-top: 1px solid color-mix(in oklab, var(--line) 92%, transparent);
  }
  
  .landing .avatar,
  .landing img.avatar{
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 1px solid var(--line);
    flex: none;
  }
  
  .landing .avatar{
    background: linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.02));
  }
  
  .landing img.avatar{
    display: block;
    object-fit: cover;
    background: none;
  }
  
  .landing .person strong{
    display: block;
  }
  
  .landing .meta{
    margin-top: 4px;
    font-size: .85rem;
    color: var(--muted);
    line-height: 1.2;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    min-height: calc(1.2em * 2);
  }
  
  .landing .slider-controls{
    position: absolute;
    right: 16px;
    bottom: 16px;
    display: flex;
    gap: 10px;
    z-index: 2;
  }
  
  .landing .ctrl{
    width: 40px;
    height: 40px;
    border-radius: 999px;
    cursor: pointer;
    user-select: none;
    border: 1px solid color-mix(in oklab, var(--line) 80%, var(--brand) 20%);
    background: color-mix(in oklab, var(--panel) 92%, transparent);
    box-shadow: 0 10px 22px rgba(0,0,0,.25);
    display: grid;
    place-items: center;
    font-size: .95rem;
    line-height: 1;
    transition: transform 120ms ease, box-shadow 160ms ease, border-color 160ms ease, background 160ms ease;
  }
  
  .landing .ctrl:hover{
    border-color: color-mix(in oklab, var(--brand) 28%, var(--line));
    box-shadow: 0 12px 26px rgba(0,0,0,.28);
    background: color-mix(in oklab, var(--panel) 88%, transparent);
  }
  
  .landing .ctrl:active{
    transform: translateY(1px);
  }
  
  .landing .ctrl:focus-visible{
    outline: 3px solid color-mix(in oklab, var(--brand) 35%, transparent);
    outline-offset: 3px;
  }
  
  /* ============ Video ============ */
  
  .landing .video-wrapper{
    position: relative;
    margin-top: 18px;
    border-radius: 18px;
    overflow: hidden;
    border: 1px solid var(--line);
    background: radial-gradient(circle at 0 0, color-mix(in oklab, var(--brand) 8%, transparent), transparent), var(--panel);
    box-shadow: var(--shadow);
  }
  
  .landing .video-wrapper::before{
    content: "";
    display: block;
    padding-top: 56.25%;
  }
  
  .landing .video-wrapper iframe{
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
    display: block;
  }
  
  /* ============ Final CTA ============ */
  
  .landing .section--final{
    position: relative;
    overflow: hidden;
  }
  
  .landing .section--final::before{
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,0));
    pointer-events: none;
  }
  
  .landing .section--final::after{
    content: "";
    position: absolute;
    right: -120px;
    bottom: -160px;
    width: 420px;
    height: 420px;
    border-radius: 50%;
    background: radial-gradient(circle at 35% 35%, #fff, var(--brand));
    filter: blur(18px);
    opacity: .1;
    pointer-events: none;
  }
  
  .landing .section--final .center{
    text-align: center;
    max-width: 760px;
    margin-inline: auto;
  }
  
  .landing .section--final .headline{
    margin-bottom: 8px;
  }
  
  .landing .section--final .muted{
    color: color-mix(in oklab, var(--text) 74%, var(--muted) 26%);
  }
  
  .landing .section--final .cta-row{
    justify-content: center;
    gap: 14px;
  }
  
  .landing .section--final .btn{
    min-width: 160px;
  }
  
  .landing .section--final .btn.btn--secondary{
    border-color: color-mix(in oklab, var(--brand) 22%, var(--line));
    background: linear-gradient(
      180deg,
      color-mix(in oklab, var(--surface) 72%, #fff 28%),
      var(--surface)
    );
  }
  
  .landing .section--final .btn.btn--primary{
    box-shadow: 0 10px 28px color-mix(in oklab, var(--brand) 28%, transparent);
  }
  
  /* ============ Reveal Animation ============ */
  
  .landing .reveal{
    opacity: 0;
    transform: translateY(14px);
    transition: opacity .6s ease, transform .6s ease;
  }
  
  .landing .reveal.in{
    opacity: 1;
    transform: none;
  }
  
  /* ============ Keyframes ============ */
  
  @keyframes float-orb{
    0%{
      transform: translate3d(0,0,0) scale(1);
    }
    50%{
      transform: translate3d(-16px,-10px,0) scale(1.02);
    }
    100%{
      transform: translate3d(6px,4px,0) scale(1);
    }
  }
  
  /* ============ Responsive ============ */
  
  @media (min-width: 680px){
    .landing .cards.top-gap{
      grid-template-columns: repeat(2, minmax(240px,1fr));
    }
  
    .landing .hero-grid{
      grid-template-columns: repeat(2, minmax(220px,1fr));
    }
  }
  
  @media (min-width: 700px){
    .landing .cards--two{
      grid-template-columns: repeat(2, minmax(240px,1fr));
    }
  }
  
  @media (min-width: 800px){
    .landing .section-grid-2{
      grid-template-columns: 1.1fr .9fr;
    }
  
    .landing .logo-row{
      grid-template-columns: repeat(6,1fr);
    }
  }
  
  @media (max-width: 900px){
    .landing .flow-diagram{
      min-height: 340px;
    }
  
    .landing .flow-node.box{
      width: 138px;
      min-height: 74px;
      font-size: .9rem;
      padding: 11px 12px;
    }
  }
  
  @media (max-width: 720px){
    .landing .slider-controls{
      right: 12px;
      bottom: 12px;
    }
  
    .landing .flow-card{
      padding: 16px;
      border-radius: 22px;
    }
  
    .landing .flow-diagram{
      min-height: 820px;
      border-radius: 18px;
      background:
        linear-gradient(
          180deg,
          color-mix(in oklab, var(--panel) 98%, #0b1220 2%) 0%,
          color-mix(in oklab, var(--panel) 100%, #fff 0%) 100%
        );
    }
  
    .landing .flow-card__head{
      margin-bottom: 12px;
    }
  
    .landing .flow-card__title{
      font-size: clamp(1.15rem, 5vw, 1.4rem);
      line-height: 1.2;
    }
  
    .landing .flow-label.caption{
      font-size: .78rem;
      letter-spacing: .02em;
    }
  
    .landing .flow-node.box{
      width: min(72vw, 240px);
      min-height: 74px;
      padding: 12px 14px;
      font-size: .92rem;
      line-height: 1.25;
      border-radius: 16px;
      box-shadow:
        0 10px 24px rgba(0,0,0,.12),
        inset 0 1px 0 rgba(255,255,255,.7);
    }
  
    .landing .flow-node.circle{
      width: 48px;
      height: 48px;
    }
  
    .landing .flow-edge{
      stroke-width: 2.2;
      opacity: 1;
    }
  
    .landing .flow-node.box.report-box{
      gap: 1px;
    }
  }
  
  @media (max-width: 420px){
    .landing .flow-diagram{
      min-height: 780px;
    }
  
    .landing .flow-node.box{
      width: min(78vw, 220px);
      min-height: 70px;
      font-size: .88rem;
      padding: 11px 12px;
    }
  
    .landing .flow-node.circle{
      width: 44px;
      height: 44px;
    }
  
    .landing .flow-label.caption{
      font-size: .74rem;
    }
  }
  
  @media (min-width: 980px){
    .landing .section-inner{
      grid-template-columns: 1.05fr .95fr;
      align-items: center;
    }
  
    .landing .hero-media{
      min-height: 480px;
    }
  
    .landing .slider{
      border-radius: 28px;
      border-color: color-mix(in oklab, var(--line) 72%, var(--brand) 28%);
      background:
        radial-gradient(900px 420px at 12% 15%, color-mix(in oklab, var(--brand) 16%, transparent), transparent 55%),
        radial-gradient(700px 340px at 85% 55%, color-mix(in oklab, var(--accent) 12%, transparent), transparent 60%),
        linear-gradient(180deg, color-mix(in oklab, var(--panel) 96%, #000 4%), var(--panel));
      box-shadow:
        0 18px 55px rgba(0,0,0,.35),
        0 0 0 1px color-mix(in oklab, var(--line) 70%, transparent);
    }
  
    .landing .slider::before{
      content: "";
      position: absolute;
      inset: 14px;
      border-radius: 22px;
      pointer-events: none;
      box-shadow:
        0 18px 55px rgba(0,0,0,.35),
        0 0 0 1px color-mix(in oklab, var(--line) 70%, transparent);
      opacity: .9;
    }
  
    .landing .slider > .slides{
      padding: 0;
      margin: 0;
      transition-timing-function: cubic-bezier(.2,.8,.2,1);
    }
  
    .landing .slider > .slides > .slide,
    .landing .slider > .slides > figure.slide{
      min-height: 180px;
      padding: 18px;
      border-radius: 22px;
      border-color: color-mix(in oklab, var(--line) 78%, var(--brand) 22%);
      box-shadow:
        0 14px 36px rgba(0,0,0,.28),
        inset 0 1px 0 rgba(255,255,255,.06);
      background:
        radial-gradient(520px 220px at 18% 12%, color-mix(in oklab, var(--brand) 10%, transparent), transparent 60%),
        linear-gradient(180deg, color-mix(in oklab, var(--panel) 94%, #fff 6%), var(--panel));
      background-clip: padding-box;
    }
  
    .landing .slide::before{
      top: 16px;
      height: 4px;
      opacity: .55;
      background: linear-gradient(
        90deg,
        color-mix(in oklab, var(--brand) 70%, #fff 30%),
        transparent 110%
      );
    }
  
    .landing .slide::after,
    .landing figure.slide::after{
      content: "";
      position: absolute;
      top: 18px;
      bottom: 18px;
      right: 0;
      width: 1px;
      background: color-mix(in oklab, var(--line) 75%, transparent);
      opacity: .6;
      pointer-events: none;
    }
  
    .landing .slide-link{
      display: grid;
      grid-template-columns: 2fr 1fr;
      column-gap: 18px;
      align-items: center;
      min-height: 100%;
    }
  
    .landing .quote{
      align-self: center;
      font-size: clamp(1.15rem, 1.2vw, 1.32rem);
      line-height: 1.62;
    }
  
    .landing .quote p{
      padding: 14px 16px 14px 18px;
      border-left-width: 4px;
      background: color-mix(in oklab, var(--panel) 88%, transparent);
    }
  
    .landing .quote p::before{
      top: -14px;
      font-size: 2.6rem;
      opacity: .6;
    }
  
    .landing .quote p::after{
      bottom: -20px;
      font-size: 2.6rem;
      opacity: .5;
    }
  
    .landing .person{
      justify-self: center;
      align-self: center;
      width: max-content;
      max-width: 100%;
      margin-top: 0;
      padding: 10px 12px;
      border-radius: 14px;
      text-align: left;
      border: 1px solid color-mix(in oklab, var(--line) 86%, transparent);
      background: color-mix(in oklab, var(--panel) 88%, transparent);
      box-shadow: 0 10px 22px rgba(0,0,0,.18);
      flex-direction: row;
    }
  
    .landing .person .avatar,
    .landing .person img.avatar{
      width: 42px;
      height: 42px;
      margin-left: auto;
      border-color: color-mix(in oklab, var(--line) 70%, var(--brand) 30%);
      box-shadow: 0 10px 22px rgba(0,0,0,.22);
    }
  
    .landing .meta{
      font-size: .9rem;
      min-height: 0;
    }
  
    .landing .slider-controls{
      right: 18px;
      bottom: 18px;
      gap: 12px;
    }
  
    .landing .ctrl{
      width: 44px;
      height: 44px;
      border-color: color-mix(in oklab, var(--line) 70%, var(--brand) 30%);
      background: color-mix(in oklab, var(--panel) 86%, transparent);
      box-shadow: 0 14px 28px rgba(0,0,0,.28);
    }
  
    .landing .ctrl:hover{
      transform: translateY(-1px);
      border-color: color-mix(in oklab, var(--brand) 36%, var(--line));
      box-shadow: 0 18px 36px rgba(0,0,0,.32);
    }
  }
  
  @media (min-width: 1040px){
    .landing .cards.top-gap{
      grid-template-columns: repeat(3, minmax(240px,1fr));
    }
  }
  
  @media (min-width: 1200px){
    .landing .quote{
      padding-right: 0;
    }
  }
  
  /* ============ Reduced Motion ============ */
  
  @media (prefers-reduced-motion: reduce){
    .landing *{
      transition: none !important;
      animation: none !important;
    }
  }
  
  .card h3{
    margin-top: 0;
  }
  
  /* Grid-Kinder dürfen schrumpfen */
  .landing .slide-link > *{
    min-width: 0;
  }
  
  .landing .person .role,
  .landing .person .company,
  .landing .meta{
    overflow-wrap: anywhere;
    word-break: break-word;
  }