/* =========================================
   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 / CARDS ============ */
  
  .landing .features{display:grid;gap:18px}
  .landing .features-col{place-self:start}
  .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{
    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
  }
  
  /* ============ 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{
    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}
  
    /* ============ 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{
      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{
      position:absolute;font-size:2.2rem;line-height:1;color:color-mix(in oklab,var(--brand) 35%,transparent)
    }
    .landing .quote p::before{left:8px;top:-10px;opacity:.55}
    .landing .quote p::after{right:10px;bottom:-16px;opacity:.45}
    .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{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{
    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{
    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:720px){
    .landing .slider-controls{right:12px;bottom:12px}
  }
  
  @media (min-width:980px){
    .landing .section-inner{grid-template-columns:1.05fr .95fr;align-items:center}
    .landing .hero-media{min-height:480px}
  
    /* Slider-Track: kein echtes Padding/Gap (JS-Schrittweite), optischer Frame via ::before */
    .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{
      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{
      position:absolute;top:18px;bottom:18px;right:0;width:1px;
      background:color-mix(in oklab,var(--line) 75%,transparent);opacity:.6;pointer-events:none
    }
  
    /* Desktop-Layout: 2/3 Quote : 1/3 Person (Person-Card zentriert) */
    .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 (sonst gilt min-width:auto und sie “blasen” auf) */
.landing .slide-link > * { min-width: 0; }

/* Untrennbare Wörter dürfen umbrechen */
.landing .person .role,
.landing .person .company,
.landing .meta {
  overflow-wrap: anywhere;
  word-break: break-word; /* Fallback */
}