/* ============================================================
   FloW v4 — „Helles Licht"
   Heller Grund · Verlaufs-Akzente Blau→Türkis→Grün · Editorial
   ============================================================ */
:root{
  --bg:      #FAFBFD;
  --bg-soft: #F2F6FA;
  --ink:     #0A1B2E;
  --ink-2:   #3A5168;
  --mute:    #6B7F93;
  --line:    #E3E9F0;
  --blue:    #1E7FD6;
  --teal:    #18B9A6;
  --green:   #4FAE3A;
  --grad:    linear-gradient(100deg, var(--blue) 0%, var(--teal) 55%, var(--green) 100%);
  --card:    #FFFFFF;
  --shadow-soft: 0 2px 6px rgba(10,27,46,.05), 0 18px 50px -12px rgba(30,127,214,.14);
  --shadow-deep: 0 4px 10px rgba(10,27,46,.06), 0 36px 90px -18px rgba(30,127,214,.28);
  --r: 20px;
  --disp: "Clash Display", sans-serif;
  --body: "General Sans", sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{overflow-x:clip}
body{font-family:var(--body);background:var(--bg);color:var(--ink);line-height:1.65;font-size:17px;
  background-image:
    radial-gradient(1100px 600px at 88% -8%, rgba(30,127,214,.07), transparent 60%),
    radial-gradient(900px 540px at -10% 28%, rgba(24,185,166,.06), transparent 60%)}
img{max-width:100%;height:auto;display:block}
a{color:var(--blue);text-decoration:none}
.container{max-width:1200px;margin:0 auto;padding:0 28px}
:focus-visible{outline:3px solid var(--teal);outline-offset:3px;border-radius:6px}
::selection{background:rgba(24,185,166,.25)}

h1,h2,h3{font-family:var(--disp);line-height:1.06;letter-spacing:-.015em;font-weight:600}
h2{font-size:clamp(2.1rem,4.2vw,3.2rem)}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-2);font-weight:600;margin-bottom:18px}
.eyebrow::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--grad)}
.lede{color:var(--ink-2);font-size:1.1rem;max-width:60ch}

/* feine Körnung, gegen das Sterile */
body::after{content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.18;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 0.97 0 0 0 0 0.98 0 0 0 0 0.99 0 0 0 0.5 0'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)'/%3E%3C/svg%3E")}
main,header,footer{position:relative;z-index:2}

/* ---------- Header: großer Banner, schrumpft beim Scrollen (wie Original) ---------- */
:root{--logo-h-max:118px;--logo-h-min:37px;--scroll-t:0}
.hdr{position:sticky;top:0;z-index:60;background:rgba(250,251,253,.8);
  -webkit-backdrop-filter:saturate(160%) blur(14px);backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid transparent;transition:border-color .2s;contain:layout style}
.hdr.scrolled{border-bottom-color:var(--line)}
.hdr .container{display:flex;align-items:center;gap:30px;padding-top:6px;padding-bottom:6px}
.brand{display:flex;align-items:center;color:var(--ink)}
.brand img{height:calc(var(--logo-h-min) + (var(--logo-h-max) - var(--logo-h-min)) * (1 - var(--scroll-t)));width:auto;object-fit:contain}
.hdr nav{display:flex;gap:26px;margin-left:auto;align-items:center}
.hdr nav a{color:var(--ink-2);font-size:.95rem;font-weight:500;transition:color .2s}
.hdr nav a:hover{color:var(--ink)}
.hdr nav a.btn{color:#fff}
/* Hamburger — nur mobil */
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;
  margin-left:auto;background:none;border:0;cursor:pointer;padding:10px}
.nav-toggle span{display:block;height:2px;width:100%;background:var(--ink);border-radius:2px;transition:transform .25s,opacity .2s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.btn{display:inline-block;font-weight:600;font-size:1.02rem;padding:15px 32px;border-radius:999px;color:#fff;background:var(--grad);
  box-shadow:0 10px 30px -6px rgba(24,185,166,.45);transition:transform .2s,box-shadow .2s,filter .2s}
.btn:hover{transform:translateY(-2px);box-shadow:0 16px 40px -8px rgba(24,185,166,.55);filter:brightness(1.06)}
.btn.mini{padding:10px 20px;font-size:.92rem}
.btn.ghost{background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-soft);color:var(--ink);font-weight:500;margin-left:14px}
.btn.ghost:hover{border-color:var(--teal);box-shadow:0 10px 30px -6px rgba(24,185,166,.25)}

/* ============================================================
   HERO — hell, asymmetrisch, Bild als Kino-Moment
   ============================================================ */
.hero{position:relative;padding:84px 0 40px;overflow:visible}
.hero .container{display:grid;grid-template-columns:1.02fr .98fr;gap:54px;align-items:center}
.hero h1{font-size:clamp(2.8rem,5.4vw,4.4rem);margin:.3em 0 .4em;max-width:17ch}
.hero h1 .hw{display:inline-block;overflow:hidden;vertical-align:bottom}
.hero h1 .hw>span{display:inline-block}
@media (prefers-reduced-motion: no-preference){
  .hero h1 .hw>span{transform:translateY(110%);animation:rise .8s cubic-bezier(.2,.7,.2,1) forwards}
  @keyframes rise{to{transform:translateY(0)}}
  .h-rise{opacity:0;animation:fadeUp .9s ease .5s forwards}
  @keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
}
.hero-sub{font-size:clamp(1.12rem,1.7vw,1.38rem);font-weight:500;color:var(--ink);max-width:42ch;margin-bottom:12px}
.hero-lede{color:var(--mute);max-width:48ch;font-size:1.02rem;margin-bottom:34px}

/* Orbit-Bühne rechts: die Werkzeuge kreisen um deinen Betrieb */
.hero-visual{position:relative;display:grid;place-items:center;min-height:480px}
.orbit-wrap{position:relative;width:480px;height:480px}
.orbit-core{position:absolute;inset:50%;translate:-50% -50%;width:148px;height:148px;display:grid;place-items:center;
  text-align:center;background:#fff;border-radius:50%;box-shadow:var(--shadow-deep), 0 0 0 1px var(--line);z-index:3}
.orbit-core b{font-family:var(--disp);font-weight:600;font-size:1.02rem;line-height:1.15;display:block}
.orbit-core small{display:block;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;margin-top:4px;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.orbit{position:absolute;inset:50%;translate:-50% -50%;border:1.5px dashed #C9D7E5;border-radius:50%}
.orbit.o1{width:300px;height:300px;--r:150px;--dur:30s}
.orbit.o2{width:460px;height:460px;--r:230px;--dur:52s}
.osat{position:absolute;top:50%;left:50%;width:0;height:0;transform:rotate(var(--a)) translateX(var(--r))}
.pill{position:absolute;left:0;top:0;transform:translate(-50%,-50%)}
.pi{display:inline-flex;align-items:center;gap:8px;white-space:nowrap;transform:rotate(calc(-1 * var(--a)));
  background:#fff;border:1px solid var(--line);border-radius:999px;padding:9px 16px;
  font-size:.84rem;font-weight:600;color:var(--ink);box-shadow:0 10px 28px -8px rgba(10,27,46,.18)}
.pi::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--grad);flex:0 0 auto}
@media (prefers-reduced-motion: no-preference){
  .orbit{animation:spin var(--dur) linear infinite}
  .orbit.o2{animation-direction:reverse}
  @keyframes spin{to{rotate:360deg}}
  .pill{animation:spinBack var(--dur) linear infinite}
  .orbit.o2 .pill{animation-direction:reverse}
  @keyframes spinBack{from{transform:translate(-50%,-50%) rotate(0deg)}to{transform:translate(-50%,-50%) rotate(-360deg)}}
}
/* Pillen: weichen der Maus aus (JS setzt --px/--py), Hover füllt mit Verlauf */
.pi{translate:var(--px,0px) var(--py,0px);transition:translate .45s cubic-bezier(.2,.7,.3,1.4),background .25s,color .25s,border-color .25s;cursor:pointer}
.pi:hover{background:var(--grad);color:#fff;border-color:transparent}
.pi:hover::before{background:#fff}
.orbit-glow{position:absolute;inset:50%;translate:-50% -50%;width:540px;height:540px;border-radius:50%;
  background:radial-gradient(circle, rgba(30,127,214,.10), rgba(24,185,166,.05) 55%, transparent 72%);z-index:-1}

/* Trust-Zeile */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-top:74px;background:rgba(255,255,255,.55)}
.trust .container{display:flex;flex-wrap:wrap;gap:14px 44px;justify-content:center;padding-top:20px;padding-bottom:20px}
.trust span{display:inline-flex;align-items:center;gap:9px;font-size:.86rem;font-weight:600;color:var(--ink-2);letter-spacing:.02em}
.trust span::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--grad)}

/* ============================================================
   Gedanken-Spalten — drei Bahnen, verschiedene Geschwindigkeiten
   ============================================================ */
.thoughts{padding:84px 0 0;overflow:hidden}
.thoughts .label{text-align:center;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--mute);margin-bottom:8px;font-weight:600}
.thoughts h2{text-align:center;max-width:22ch;margin:0 auto}
.tcols{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:46px;height:430px;overflow:hidden;
  -webkit-mask-image:linear-gradient(180deg,transparent,#000 12%,#000 86%,transparent);
  mask-image:linear-gradient(180deg,transparent,#000 12%,#000 86%,transparent)}
.tcol{display:flex;flex-direction:column;gap:20px;will-change:transform}
@media (prefers-reduced-motion: no-preference){
  .tcol{animation:colUp linear infinite}
  .tcol:nth-child(1){animation-duration:34s}
  .tcol:nth-child(2){animation-duration:46s}
  .tcol:nth-child(3){animation-duration:39s}
  @keyframes colUp{to{transform:translateY(-50%)}}
}
.tq{background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px 26px;box-shadow:var(--shadow-soft);flex:0 0 auto}
.tq q{font-size:1.04rem;font-weight:500;color:var(--ink);font-style:italic;quotes:"„" "“";line-height:1.5}
.tq .who{display:inline-flex;align-items:center;gap:8px;margin-top:14px;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--mute);font-weight:700}
.tq .who::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--grad)}

/* ============================================================
   Sektionen
   ============================================================ */
section.blk{position:relative;padding:110px 0}

/* ---------- Live-System ---------- */
.sys-panel{background:var(--card);border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow-soft);padding:54px;margin-top:46px}
.chips{display:flex;flex-wrap:wrap;gap:11px;margin-bottom:38px}
.chip{font-family:var(--body);font-size:.97rem;font-weight:600;color:var(--ink-2);background:var(--bg-soft);border:1px solid var(--line);border-radius:999px;padding:11px 22px;cursor:pointer;transition:all .22s ease}
.chip:hover{border-color:var(--teal);color:var(--ink);transform:translateY(-1px)}
.chip[aria-pressed="true"]{background:var(--grad);border-color:transparent;color:#fff;box-shadow:0 8px 24px -6px rgba(24,185,166,.5)}
.sysgrid{display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:stretch}
.sys-canvas{position:relative;background:linear-gradient(180deg,#FBFCFE,#F4F8FB);border:1px solid var(--line);border-radius:var(--r);padding:12px}
#plan{width:100%;height:auto;display:block}
#plan .node rect{fill:#fff;stroke:url(#stroke-grad);stroke-width:1.5;rx:13;filter:drop-shadow(0 4px 10px rgba(10,27,46,.07))}
#plan .node.core rect{stroke-width:2.4}
#plan .node text{fill:var(--ink);font-family:var(--disp);font-weight:600;font-size:16px}
#plan .node .sub{fill:var(--mute);font-family:var(--body);font-weight:500;font-size:10.5px;letter-spacing:.05em}
#plan .edge{stroke:url(#stroke-grad);stroke-width:2;fill:none;opacity:.9}
#plan .pulse{fill:var(--teal);filter:drop-shadow(0 0 5px rgba(24,185,166,.8))}
#plan .traveller{fill:var(--teal);opacity:0;transition:opacity .5s ease 1.4s;filter:drop-shadow(0 0 6px rgba(24,185,166,.9))}
#plan.drawn .traveller{opacity:.95}
#plan .node,#plan .edge{opacity:0;transition:opacity .55s ease}
#plan.drawn .node{opacity:1}
#plan.drawn .edge{opacity:.9}
@media (prefers-reduced-motion: no-preference){
  #plan.drawn .edge{stroke-dasharray:300;stroke-dashoffset:300;animation:draw 1s ease forwards}
  @keyframes draw{to{stroke-dashoffset:0}}
}
.sys-side{display:flex;flex-direction:column;gap:20px}
.thought-card,.proof-card{background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--r);padding:26px 28px;transition:opacity .3s ease}
.fade .thought-card,.fade .proof-card{opacity:0}
.thought-card q{font-size:1.14rem;font-weight:500;color:var(--ink);font-style:italic;quotes:"„" "“"}
.thought-card .who{display:block;margin-top:10px;font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;color:var(--mute);font-weight:600}
.proof-card{background:#fff;box-shadow:var(--shadow-soft)}
.proof-card .tag{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.proof-card h3{font-size:1.26rem;margin:.4em 0 .35em}
.proof-card p{font-size:.95rem;color:var(--ink-2)}
.proof-card .status{display:inline-flex;align-items:center;gap:8px;margin-top:14px;font-size:.85rem;color:var(--green);font-weight:600}
.proof-card .status::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 8px rgba(79,174,58,.7)}

/* ---------- Fälle: editorial, Bild + Text versetzt ---------- */
.case-row{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center;margin-top:84px}
.case-row:first-of-type{margin-top:56px}
.case-row.flip .case-img{order:2}
.case-img{position:relative}
.case-img img{border-radius:24px;box-shadow:var(--shadow-deep)}
.case-img::before{content:"";position:absolute;inset:auto -16px -16px auto;width:55%;height:55%;background:var(--grad);opacity:.15;border-radius:28px;z-index:-1}
.case-row.flip .case-img::before{inset:auto auto -16px -16px}
.case-img .badge{position:absolute;top:18px;left:18px;background:rgba(255,255,255,.9);backdrop-filter:blur(8px);border-radius:999px;padding:7px 16px;font-size:.76rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-2)}
.case-txt .num{font-family:var(--disp);font-weight:700;font-size:.95rem;letter-spacing:.16em;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.case-txt h3{font-size:clamp(1.6rem,2.6vw,2.1rem);margin:.4em 0 .5em}
.case-txt p{color:var(--ink-2);font-size:1rem}
.case-txt .modules{margin-top:20px;display:flex;flex-wrap:wrap;gap:9px}
.case-txt .modules span{font-size:.78rem;font-weight:600;border:1px solid var(--line);background:#fff;border-radius:999px;padding:6px 14px;color:var(--ink-2);box-shadow:0 2px 6px rgba(10,27,46,.04)}

/* ---------- Methode: Verlaufs-Timeline ---------- */
.blk.tinted{background:linear-gradient(180deg,#F3F7FB, #FAFBFD);border-top:1px solid var(--line)}
.timeline{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:44px;margin-top:64px}
.timeline::before{content:"";position:absolute;top:7px;left:2%;right:2%;height:2.5px;background:var(--grad);border-radius:2px;opacity:.65}
.tstep{position:relative;padding-top:36px}
.tstep::before{content:"";position:absolute;top:0;left:0;width:16px;height:16px;border-radius:50%;background:var(--grad);box-shadow:0 0 0 5px #fff, 0 0 0 6px var(--line)}
.tstep .n{font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);font-weight:700}
.tstep h3{font-size:1.4rem;margin:.3em 0 .35em}
.tstep p{font-size:.97rem;color:var(--ink-2)}

/* ---------- Über ---------- */
.about{display:grid;grid-template-columns:1.1fr .9fr;gap:70px;align-items:center}
.about p{color:var(--ink-2)}
.about p+p{margin-top:1em}
.about .pwrap{position:relative;max-width:420px;justify-self:end}
.about .pwrap img{border-radius:24px;box-shadow:var(--shadow-deep);transform:rotate(-1.4deg)}
.about .pwrap::before{content:"";position:absolute;inset:-14px auto auto -14px;width:60%;height:60%;background:var(--grad);opacity:.16;border-radius:28px;z-index:-1}
.about .pcap{position:absolute;bottom:-18px;right:-12px;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-radius:14px;padding:12px 18px;box-shadow:0 18px 44px -8px rgba(10,27,46,.22);font-size:.86rem;font-weight:600;color:var(--ink)}
.about .pcap small{display:block;font-weight:500;color:var(--mute);font-size:.78rem}

/* ---------- CTA: der eine laute Farb-Moment ---------- */
.cta-panel{position:relative;background:var(--grad);border-radius:34px;padding:90px 60px;text-align:center;color:#fff;overflow:hidden;box-shadow:0 40px 110px -20px rgba(24,185,166,.5)}
.cta-panel::before{content:"";position:absolute;inset:0;background:
  radial-gradient(600px 300px at 20% 0%, rgba(255,255,255,.22), transparent 60%),
  radial-gradient(500px 280px at 90% 100%, rgba(255,255,255,.14), transparent 60%)}
.cta-panel>*{position:relative}
.cta-panel h2{color:#fff;font-size:clamp(2.2rem,4.6vw,3.6rem);max-width:18ch;margin:0 auto .35em}
.cta-panel p{color:rgba(255,255,255,.92);max-width:50ch;margin:0 auto 38px}
.btn.inverse{background:#fff;color:var(--ink);box-shadow:0 14px 40px -8px rgba(0,0,0,.3)}
.btn.inverse:hover{filter:none;transform:translateY(-2px)}
.btn.outline{background:transparent;border:1.5px solid rgba(255,255,255,.7);box-shadow:none;color:#fff;margin-left:14px}
.btn.outline:hover{border-color:#fff;background:rgba(255,255,255,.1)}

footer{border-top:1px solid var(--line);padding:46px 0;font-size:.88rem;color:var(--mute);margin-top:110px}
footer .container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:18px}
footer a{color:var(--ink-2)}

/* ---------- Scroll-Reveal: kurz, mit Blur — kein Fade-up-Slop ---------- */
/* Reveal nur wenn JS aktiv ist — ohne JS sind alle Inhalte sofort sichtbar */
.js .rv{opacity:0;transform:translateY(12px);filter:blur(7px);
  transition:opacity .65s cubic-bezier(.2,.7,.2,1),transform .65s cubic-bezier(.2,.7,.2,1),filter .65s ease}
.js .rv.in{opacity:1;transform:none;filter:none}
.js .rv-img{clip-path:inset(8% 6% 8% 6% round 24px);transform:scale(1.04);
  transition:clip-path .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.js .rv-img.in{clip-path:inset(0 0 0 0 round 24px);transform:none}
@media (prefers-reduced-motion: reduce){
  .js .rv,.js .rv-img{opacity:1;transform:none;filter:none;clip-path:none;transition:none}
}

/* Button-Schimmer: ein Lichtstreif, nur auf Hover */
.btn{position:relative;overflow:hidden}
.btn::after{content:"";position:absolute;top:0;left:-80%;width:50%;height:100%;
  background:linear-gradient(105deg,transparent,rgba(255,255,255,.45),transparent);
  transform:skewX(-18deg)}
/* Schimmer NUR beim Drüberfahren animieren; beim Verlassen springt er instant zurück (kein Rücklauf) */
.btn:hover::after{left:130%;transition:left .6s ease}
.btn.ghost::after,.btn.inverse::after{background:linear-gradient(105deg,transparent,rgba(30,127,214,.12),transparent)}

/* Mesh-Gradient-Shader hinter dem Hero */
.hero{position:relative}
#shader{position:absolute;inset:0;width:100%;height:100%;z-index:-1;opacity:.65;
  -webkit-mask-image:linear-gradient(180deg,#000 72%,transparent);
  mask-image:linear-gradient(180deg,#000 72%,transparent)}

/* Durchgehend sichtbarer Verlaufs-Rahmen ums System-Panel + weicher Glow */
@property --bb { syntax:"<angle>"; inherits:false; initial-value:0deg; }
.sys-panel{position:relative;isolation:isolate}
/* der scharfe Rahmen (2px, voller Markenverlauf, dauerhaft sichtbar) */
.sys-panel::before{content:"";position:absolute;inset:-2px;border-radius:30px;z-index:-1;
  background:conic-gradient(from var(--bb), #1E7FD6, #18B9A6, #4FAE3A, #18B9A6, #1E7FD6)}
/* der weiche Glow dahinter */
.sys-panel::after{content:"";position:absolute;inset:-7px;border-radius:34px;z-index:-2;opacity:.45;filter:blur(14px);
  background:conic-gradient(from var(--bb), #1E7FD6, #18B9A6, #4FAE3A, #18B9A6, #1E7FD6)}
@media (prefers-reduced-motion: no-preference){
  .sys-panel::before,.sys-panel::after{animation:bb 12s linear infinite}
  @keyframes bb{to{--bb:360deg}}
}

/* ---------- Mobile: eigenes Layout, nicht geschrumpft ---------- */
@media (max-width:1020px){
  .hero{padding-top:52px}
  .hero .container{grid-template-columns:1fr;gap:46px}
  .hero h1{max-width:none;font-size:clamp(2.5rem,11vw,3.4rem)}
  .hero-sub{font-size:1.15rem}
  /* CTAs untereinander, volle Breite — Daumen-Zone */
  .hero .btn{display:block;text-align:center;margin:0 0 12px}
  .hero .btn.ghost{margin-left:0}
  /* Orbit kompakt, ohne Beschnitt */
  .hero-visual{min-height:360px;min-width:0}
  .orbit-wrap{width:330px;height:330px}
  .orbit.o1{width:200px;height:200px;--r:100px}
  .orbit.o2{width:322px;height:322px;--r:161px}
  .orbit-core{width:112px;height:112px}
  .orbit-core b{font-size:.88rem}
  .pi{font-size:.72rem;padding:6px 11px}
  .orbit-glow{width:340px;height:340px}
  /* Trust: horizontal scrollbar statt umbrechen */
  .trust .container{flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start;gap:28px;
    scrollbar-width:none;-webkit-overflow-scrolling:touch;padding-left:20px;padding-right:20px}
  .trust span{flex:0 0 auto}
  /* Chips: Scroll-Snap-Reihe */
  .chips{flex-wrap:nowrap;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;
    margin:0 -22px 30px;padding:4px 22px 10px;
    -webkit-mask-image:linear-gradient(to right,#000 calc(100% - 34px),transparent);
    mask-image:linear-gradient(to right,#000 calc(100% - 34px),transparent)}
  .chips.at-end{-webkit-mask-image:none;mask-image:none}
  .chip{flex:0 0 auto;scroll-snap-align:start}
  .sysgrid{grid-template-columns:1fr;gap:26px}
  .sys-panel{padding:26px 22px;border-radius:22px}
  /* Fälle: Bild voll, Text folgt, Nummer als Anker */
  .case-row{grid-template-columns:1fr;gap:26px;margin-top:64px}
  .case-row.flip .case-img{order:0}
  .case-img img{border-radius:18px}
  .case-img::before{display:none}
  /* Methode: vertikale Linie mit Punkten */
  .timeline{grid-template-columns:1fr;gap:38px}
  .timeline::before{top:4px;bottom:4px;left:7px;right:auto;width:2.5px;height:auto}
  .tstep{padding-top:0;padding-left:38px}
  .tstep::before{top:4px}
  .about{grid-template-columns:1fr;gap:48px}
  .about .pwrap{justify-self:center;max-width:340px}
  /* Mobile-Navigation: Hamburger + aufklappendes Dropdown */
  .nav-toggle{display:flex}
  .hdr .container{gap:12px}
  .hdr nav{position:absolute;top:100%;left:0;right:0;margin:0;flex-direction:column;align-items:stretch;gap:2px;
    background:rgba(255,255,255,.97);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
    border-bottom:1px solid var(--line);padding:12px 24px 20px;
    box-shadow:0 24px 50px -16px rgba(10,27,46,.22);
    transform:translateY(-10px);opacity:0;visibility:hidden;transition:transform .25s ease,opacity .25s ease,visibility .25s}
  .hdr nav.open{transform:none;opacity:1;visibility:visible}
  .hdr nav a{padding:14px 4px;font-size:1.08rem;border-bottom:1px solid var(--line-soft, #EEF2F7)}
  .hdr nav a:last-child{border-bottom:0}
  .hdr nav a.btn{margin-top:12px;text-align:center;font-size:1rem}
  section.blk{padding:72px 0}
  .cta-panel{padding:58px 26px;border-radius:24px}
  .cta-panel .btn{display:block;margin:0 0 12px}
  .cta-panel .btn.outline{margin-left:0}
  /* Gedanken: eine Bahn reicht auf dem Telefon */
  .tcols{grid-template-columns:1fr;height:360px}
  .tcol:nth-child(2),.tcol:nth-child(3){display:none}
  :root{--logo-h-max:84px}
}
/* ============================================================
   Unterseiten (Methode · Produkte · Preise)
   ============================================================ */
.page-head{position:relative;padding:72px 0 56px;overflow:hidden;
  background:radial-gradient(900px 480px at 80% -20%, rgba(30,127,214,.08), transparent 60%),
             radial-gradient(700px 420px at 0% 10%, rgba(24,185,166,.07), transparent 60%)}
.page-head h1{font-size:clamp(2.4rem,5vw,3.8rem);max-width:20ch;margin:.3em 0 .4em}
.page-head .lede{font-size:1.12rem}
.crumb{font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);font-weight:700}

/* Funke-Karte (Methode) */
.spark-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:28px;
  box-shadow:var(--shadow-soft);padding:50px 54px;margin-top:46px;overflow:hidden}
.spark-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--grad)}
.spark-card h3{font-size:clamp(1.5rem,2.4vw,2rem);margin-bottom:.5em}
.spark-card p{color:var(--ink-2);max-width:72ch}
.spark-card p+p{margin-top:1em}
.spark-card .go{display:inline-flex;align-items:center;gap:8px;margin-top:22px;font-weight:600}

/* Erzähl-Text (Methode) */
.prose{max-width:70ch}
.prose p{color:var(--ink-2);font-size:1.04rem}
.prose p+p{margin-top:1.1em}
.prose strong{color:var(--ink)}

/* Produkt-Grid */
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:50px}
.prod{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r);
  padding:30px 30px 26px;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;
  transition:transform .25s ease,box-shadow .25s ease}
.prod:hover{transform:translateY(-5px);box-shadow:var(--shadow-deep)}
.prod .pk{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.prod h3{font-size:1.4rem;margin:.35em 0 .35em}
.prod p{font-size:.95rem;color:var(--ink-2);flex:1}
.prod .pl{margin-top:18px;font-weight:600;font-size:.92rem}
.prod.featured{grid-column:span 3;display:grid;grid-template-columns:1fr 1fr;gap:14px 48px;align-items:center;
  background:linear-gradient(135deg,#FFFFFF 60%, #F0F7F4)}
.prod.featured h3{font-size:1.9rem}
.prod.featured .pstat{display:inline-flex;align-items:center;gap:8px;font-size:.84rem;color:var(--green);font-weight:600;margin-top:14px}
.prod.featured .pstat::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 8px rgba(79,174,58,.7)}

/* Zusammenspiel */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:50px}
.duo .cell{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:32px 34px;box-shadow:var(--shadow-soft)}
.duo .cell .pk{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--mute)}
.duo .cell h3{font-size:1.3rem;margin:.4em 0 .35em}
.duo .cell p{font-size:.95rem;color:var(--ink-2)}

/* Preise */
.price-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;margin-top:50px}
.price{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:36px 36px 32px;box-shadow:var(--shadow-soft);display:flex;flex-direction:column}
.price .pk{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.price h3{font-size:1.45rem;margin:.35em 0 .2em}
.price .amount{font-family:var(--disp);font-weight:600;font-size:1.9rem;margin:.2em 0 .3em}
.price .amount small{font-size:.95rem;color:var(--mute);font-weight:500;font-family:var(--body)}
.price p{font-size:.94rem;color:var(--ink-2);flex:1}
.price ul{list-style:none;margin-top:16px;display:grid;gap:9px}
.price li{font-size:.92rem;color:var(--ink-2);display:flex;gap:10px;align-items:baseline}
.price li::before{content:"✓";font-weight:700;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.price-note{margin-top:34px;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--r);padding:24px 28px;font-size:.95rem;color:var(--ink-2)}

/* FAQ */
.faq{max-width:820px;margin-top:50px}
.faq details{background:#fff;border:1px solid var(--line);border-radius:16px;margin-bottom:14px;box-shadow:var(--shadow-soft);overflow:hidden}
.faq summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:20px;
  padding:22px 26px;font-family:var(--disp);font-weight:600;font-size:1.08rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;line-height:1;flex:0 0 auto;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;transition:rotate .25s ease}
.faq details[open] summary::after{rotate:45deg}
.faq .a{padding:0 26px 24px;color:var(--ink-2);font-size:.98rem}
.faq .a p+p{margin-top:.8em}

@media (max-width:1020px){
  .prod-grid{grid-template-columns:1fr}
  .prod.featured{grid-column:span 1;grid-template-columns:1fr}
  .duo{grid-template-columns:1fr}
  .price-grid{grid-template-columns:1fr}
  .spark-card{padding:32px 26px}
  .page-head{padding:48px 0 40px}
}

/* ============================================================
   Preise — Tier-Block mit Toggle (heller v4-Stil)
   ============================================================ */
.tier-head{text-align:center;max-width:760px;margin:0 auto}
.tier-head .eyebrow{justify-content:center}
.tier-head h2{margin-bottom:.4em}

/* Toggle-Pille */
.ptoggle{position:relative;display:inline-flex;margin-top:30px;padding:5px;
  border-radius:999px;background:var(--bg-soft);border:1px solid var(--line);box-shadow:var(--shadow-soft)}
/* schlanker Slider: Breite = aktiver Button (per JS gesetzt), gleitet smooth */
.ptoggle-slider{position:absolute;top:5px;bottom:5px;left:0;width:0;border-radius:999px;
  background:var(--grad);box-shadow:0 6px 20px -4px rgba(24,185,166,.5);
  transition:transform .4s cubic-bezier(.22,1,.36,1), width .4s cubic-bezier(.22,1,.36,1)}
.ptoggle-btn{position:relative;z-index:1;border:0;background:none;cursor:pointer;
  font-family:var(--body);font-weight:600;font-size:.98rem;color:var(--ink-2);
  padding:11px 24px;border-radius:999px;transition:color .35s ease,background .35s ease;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap}
/* Fallback: aktiver Button trägt selbst den Verlauf — nie weiß-auf-weiß, auch ohne JS-Slider */
.ptoggle-btn.is-active{color:#fff;background:var(--grad);box-shadow:0 6px 20px -4px rgba(24,185,166,.5)}
/* Sobald JS den gleitenden Slider gesetzt hat, übernimmt dieser; Button-bg wird transparent */
.ptoggle.slider-ready .ptoggle-btn,.ptoggle.slider-ready .ptoggle-btn.is-active{background:none;box-shadow:none}
.ptoggle:not(.slider-ready) .ptoggle-slider{opacity:0}
.ptoggle-save{font-size:.72rem;font-weight:700;letter-spacing:.04em;padding:3px 8px;border-radius:999px;
  background:rgba(79,174,58,.18);color:var(--green)}
.ptoggle-btn.is-active .ptoggle-save{background:rgba(255,255,255,.22);color:#fff}

/* Tier-Karten */
.ptier-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px;align-items:start}
.ptier{position:relative;background:var(--card);border:1px solid var(--line);border-radius:24px;
  padding:34px 30px 30px;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;
  transition:transform .28s ease, box-shadow .28s ease}
.ptier:hover{transform:translateY(-6px);box-shadow:var(--shadow-deep)}
.ptier.popular{border-color:transparent;box-shadow:var(--shadow-deep);transform:translateY(-10px)}
.ptier.popular:hover{transform:translateY(-16px)}
/* Verlaufs-Glow-Rahmen der Popular-Karte */
.ptier.popular::before{content:"";position:absolute;inset:-1.5px;border-radius:25px;z-index:-1;background:var(--grad)}
.ptier.popular::after{content:"";position:absolute;inset:-10px;border-radius:32px;z-index:-2;
  background:var(--grad);opacity:.30;filter:blur(22px)}
.ptier-flag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--grad);color:#fff;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:6px 16px;border-radius:999px;box-shadow:0 8px 20px -6px rgba(24,185,166,.6)}
.ptier .pk{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.ptier h3{font-size:1.4rem;margin:.3em 0 .2em}
.ptier-price{display:flex;align-items:baseline;gap:2px;margin:.3em 0 .1em}
.ptier-price .cur{font-family:var(--disp);font-weight:600;font-size:1.5rem;color:var(--ink)}
.ptier-price .num{font-family:var(--disp);font-weight:700;font-size:3.2rem;line-height:1;color:var(--ink);
  font-variant-numeric:tabular-nums}
.ptier-price .per{color:var(--mute);font-size:1rem;margin-left:4px}
.ptier-desc{color:var(--ink-2);font-size:.96rem;margin:.5em 0 0}
.ptier-cta{margin:22px 0 0;text-align:center;width:100%}
.ptier-feats{margin-top:24px;padding-top:22px;border-top:1px solid var(--line)}
.feat-head{font-weight:600;font-size:.92rem;display:block;margin-bottom:12px}
.ptier-feats ul{list-style:none;display:grid;gap:10px}
.ptier-feats li{font-size:.93rem;color:var(--ink-2);display:flex;gap:10px;align-items:baseline}
.ptier-feats li::before{content:"✓";font-weight:700;flex:0 0 auto;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.tier-foot{text-align:center;max-width:680px;margin:40px auto 0;font-size:.88rem;color:var(--mute)}

@media (max-width:1020px){
  .ptier-grid{grid-template-columns:1fr;gap:30px}
  .ptier.popular{transform:none}
  .ptier.popular:hover{transform:translateY(-4px)}
}

/* ============================================================
   Coverflow-Karussell — „Weitere Angebote" (FloW-Farbschema)
   ============================================================ */
.cflow{position:relative;margin-top:48px}
/* Grid-Stacking: alle Folien liegen in EINER Zelle übereinander → Bühne ist automatisch so hoch
   wie die größte Folie (kein JS-Messen nötig). align-items:stretch → alle Folien gleich hoch. */
.cf-stage{position:relative;display:grid;align-items:stretch;justify-items:center;
  width:100%;max-width:1000px;perspective:1800px;margin:0 auto}
.cf-slide{grid-area:1/1;width:min(980px,92vw);
  background:var(--card);border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow-soft);
  padding:38px 38px 42px;display:flex;flex-direction:column;justify-content:center;
  transition:transform .7s cubic-bezier(.4,1.25,.35,1), opacity .6s ease;
  will-change:transform,opacity}
.cf-slide-head{text-align:center;margin-bottom:30px}
.cf-slide-head .pk{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.cf-slide-head h3{font-size:clamp(1.7rem,2.6vw,2.2rem);margin:.25em 0 0}
.cf-slide-head .ptoggle{margin-top:20px}
.cf-tiers{display:grid;gap:20px;align-items:start}
.cf-tiers.cols-3{grid-template-columns:repeat(3,1fr)}
.cf-tiers.cols-2{grid-template-columns:repeat(2,1fr);max-width:680px;margin:0 auto}
.cf-tiers.single{grid-template-columns:1fr;max-width:480px;margin:0 auto}
/* Tier-Karten in der Folie: ruhiger (kein Hover-Lift, popular nur Glow+Flag, gleiche Höhe) */
.cf-tiers .ptier{transform:none!important;padding:30px 26px 26px}
.cf-tiers .ptier.popular{transform:none!important}
.cf-tiers .req .ptier-desc{margin-top:10px}
.cf-tiers .req-num{font-size:1.5rem}

/* Coverflow-Positionen je data-pos */
.cf-slide[data-pos="center"]{z-index:3;opacity:1;transform:translateX(0) scale(1) rotateY(0)}
.cf-slide[data-pos="left"]{z-index:2;opacity:.4;transform:translateX(-52%) scale(.82) rotateY(14deg);cursor:pointer}
.cf-slide[data-pos="right"]{z-index:2;opacity:.4;transform:translateX(52%) scale(.82) rotateY(-14deg);cursor:pointer}
.cf-slide[data-pos="hidden"]{z-index:1;opacity:0;transform:scale(.7);pointer-events:none}

.cf-arrow{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;
  border:1px solid var(--line);background:#fff;box-shadow:var(--shadow-soft);color:var(--ink);
  display:grid;place-items:center;cursor:pointer;transition:background .2s,box-shadow .2s,color .2s,border-color .2s;z-index:6}
.cf-prev{left:0}
.cf-next{right:0}
.cf-arrow:hover{color:#fff;border-color:transparent;background:var(--grad);
  box-shadow:0 12px 30px -6px rgba(24,185,166,.55)}
.cf-dots{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:30px}
.cf-dot{width:9px;height:9px;border-radius:50%;border:0;padding:0;cursor:pointer;background:var(--line);
  transition:background .25s,transform .25s}
.cf-dot.is-active{background:var(--grad);transform:scale(1.35)}

@media (max-width:1020px){
  /* Karussell als Flex-Reihe: Pfeile FLANKIEREN die Karte (kein Überlappen mit Text) */
  .cflow{padding:0 2px;display:flex;align-items:center;gap:5px}
  .cf-stage{min-height:0;max-width:none;flex:1 1 auto;min-width:0}
  .cf-slide{position:relative;left:auto;margin:0 auto;width:100%;min-width:0;max-width:100%;padding:30px 16px 34px}
  .cf-slide[data-pos="left"],.cf-slide[data-pos="right"],.cf-slide[data-pos="hidden"]{display:none}
  .cf-slide[data-pos="center"]{transform:none}
  /* #1 Fit: Tarif-Karte schrumpft mit (kein Abschneiden rechts) */
  .cf-tiers.cols-3,.cf-tiers.cols-2{grid-template-columns:1fr;max-width:420px;margin:0 auto}
  .cf-tiers .ptier{min-width:0}
  /* Preis-Umschalter: volle Breite, 3 gleiche Segmente (sonst lief er rechts raus).
     Ersparnis-Badges aus (stehen im Text darüber). */
  .cf-slide-head .ptoggle{display:flex;width:100%;max-width:100%;box-sizing:border-box;padding:4px;gap:2px}
  .cf-slide-head .ptoggle-btn{flex:1 1 0;min-width:0;padding:10px 4px;font-size:.82rem;justify-content:center;white-space:nowrap}
  .cf-slide-head .ptoggle-save{display:none}
  /* #2 Pfeile: eigene Spalte links/rechts statt absolut über der Karte, deutlich (Gradient) */
  .cf-arrow{position:static;transform:none;flex:0 0 auto;width:40px;height:40px;
    background:var(--grad);color:#fff;border-color:transparent;box-shadow:0 6px 18px -5px rgba(24,185,166,.55)}
  .cflow.in .cf-prev{animation:cfNudgeL 2.2s ease-in-out .35s 3}
  .cflow.in .cf-next{animation:cfNudgeR 2.2s ease-in-out .35s 3}
  @keyframes cfNudgeR{0%,60%,100%{transform:translateX(0)}80%{transform:translateX(5px)}}
  @keyframes cfNudgeL{0%,60%,100%{transform:translateX(0)}80%{transform:translateX(-5px)}}
}
@media (max-width:1020px) and (prefers-reduced-motion: reduce){
  .cf-prev,.cf-next{animation:none!important}
}
@media (prefers-reduced-motion: reduce){
  .cf-slide{transition:opacity .3s ease}
}

/* FAQ zentriert ausgerichtet */
.faq-section{text-align:center}
.faq-section .eyebrow{justify-content:center}
.faq-section .lede{margin-left:auto;margin-right:auto}
.faq{margin-left:auto;margin-right:auto;text-align:left}
.faq summary{text-align:left}

/* ============================================================
   Produkte-Seite — ausführliche Vorstellung (rein typografisch)
   ============================================================ */
.prod-list{display:flex;flex-direction:column;margin-top:40px}
.prodx{display:grid;grid-template-columns:.82fr 1.18fr;gap:54px;padding:46px 0;
  border-top:1px solid var(--line);align-items:start}
.prodx:first-child{border-top:0;padding-top:10px}
.prodx-head .pk{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.prodx-head h3{font-size:clamp(1.7rem,2.8vw,2.3rem);margin:.18em 0 .4em}
.prodx-head p{color:var(--ink-2);font-size:1.02rem;max-width:42ch}
.prodx-head .pl{display:inline-block;margin-top:18px;font-weight:600;font-size:.95rem}
.feats{list-style:none;display:grid;gap:15px;padding-top:8px}
.feats li{position:relative;padding-left:22px;font-size:1.02rem;color:var(--ink-2);line-height:1.55}
.feats li::before{content:"";position:absolute;left:0;top:.62em;width:11px;height:2px;border-radius:2px;background:var(--grad)}
.feats b{color:var(--ink);font-weight:600}
@media (max-width:1020px){
  .prodx{grid-template-columns:1fr;gap:24px;padding:38px 0}
  .prodx-head p{max-width:none}
}

/* Produkt-Karussell: .prodx als Inhalt einer Coverflow-Folie */
.cf-slide .prodx{border-top:0;padding:0;gap:48px}
.cf-slide .prodx-head h3{font-size:clamp(1.7rem,2.6vw,2.2rem)}
#pflow .cf-slide{padding:40px 44px}
@media (max-width:1020px){
  #pflow .cf-slide{padding:30px 20px}
  .cf-slide .prodx{gap:22px}
}
