:root{
  --ink:#232122;
  --ink-2:#2A2829;
  --ink-3:#343132;
  --line:#413E3F;
  --paper:#F5F3F0;
  --muted:#A29D99;
  --dim:#8E8A85;
  --max:1200px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Archivo',-apple-system,'Segoe UI',system-ui,sans-serif;
  background:var(--ink);color:var(--paper);
  line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--paper);color:var(--ink)}
.mono{font-family:'IBM Plex Mono',ui-monospace,monospace}
.wrap{max-width:var(--max);margin:0 auto;padding:0 28px}
a{color:inherit}
img{max-width:100%;display:block}

/* Reveal */
.rv{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}
.rv.on{opacity:1;transform:none}
.rv-d1{transition-delay:.1s}.rv-d2{transition-delay:.2s}.rv-d3{transition-delay:.3s}
@media(prefers-reduced-motion:reduce){
  .rv{opacity:1;transform:none;transition:none}
  *{animation:none!important;transition:none!important}
}

.eyebrow{
  font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted);
  display:flex;align-items:center;gap:12px;margin-bottom:24px;
}
.eyebrow::before{content:"";width:36px;height:1px;background:var(--paper);flex:none}

/* Header */
header{
  position:fixed;top:0;left:0;right:0;z-index:60;
  background:rgba(35,33,34,.86);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px;gap:20px}
.brand{display:flex;align-items:center;gap:14px;text-decoration:none}
.brand-mark{width:42px;height:42px;background:var(--paper);color:var(--ink);display:grid;place-items:center;font-weight:900;font-size:13px;flex:none}
.brand-name{font-weight:700;font-size:15.5px;letter-spacing:-.01em;line-height:1.2}
.brand-name small{display:block;font-weight:400;font-size:10.5px;color:var(--muted);letter-spacing:.12em;text-transform:uppercase}
nav ul{display:flex;gap:26px;list-style:none;align-items:center}
nav a{text-decoration:none;font-size:14px;font-weight:500;color:var(--muted);transition:color .15s}
nav a:hover,nav a:focus-visible,nav a[aria-current="page"]{color:var(--paper)}
.nav-cta{background:var(--paper);color:var(--ink)!important;padding:10px 20px;font-weight:700;font-size:13.5px}
.nav-cta:hover{opacity:.85}
.burger{display:none;background:none;border:1px solid var(--line);width:44px;height:44px;cursor:pointer;font-size:20px;color:var(--paper)}
@media(max-width:1080px){
  nav ul{display:none}
  nav ul.open{display:flex;flex-direction:column;align-items:flex-start;position:absolute;top:74px;left:0;right:0;background:var(--ink);border-bottom:1px solid var(--line);padding:24px 28px;gap:18px}
  .burger{display:block}
}

/* Buttons */
.btn{display:inline-block;padding:15px 30px;font-weight:700;font-size:15px;text-decoration:none;border:1px solid var(--paper);transition:all .2s;letter-spacing:.01em}
.btn-solid{background:var(--paper);color:var(--ink)}
.btn-solid:hover{background:transparent;color:var(--paper)}
.btn-ghost{color:var(--paper)}
.btn-ghost:hover{background:var(--paper);color:var(--ink)}

/* Hero (Startseite, ruhig) */
.hero{position:relative;padding:190px 0 110px;border-bottom:1px solid var(--line);overflow:hidden}
#net{position:absolute;inset:0;width:100%;height:100%;opacity:.32;pointer-events:none}
.hero .wrap{position:relative;z-index:2}
.hero-tag{
  font-family:'IBM Plex Mono',monospace;font-size:12.5px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted);margin-bottom:28px;
  display:flex;align-items:center;gap:14px;
}
.hero-tag .dot{width:8px;height:8px;background:var(--paper);border-radius:50%;animation:pulse 2.4s infinite;flex:none}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.25}}
h1{font-size:clamp(38px,5.4vw,68px);font-weight:800;line-height:1.05;letter-spacing:-.03em;max-width:15em}
h1 .thin{font-weight:400;color:var(--muted)}
.lede{margin-top:28px;font-size:19px;color:var(--muted);max-width:38em;line-height:1.7}
.hero-ctas{margin-top:38px;display:flex;gap:16px;flex-wrap:wrap}
.hero-facts{margin-top:60px;display:flex;border-top:1px solid var(--line);flex-wrap:wrap}
.hero-facts div{padding:20px 28px 0 0;margin-right:28px;border-right:1px solid var(--line)}
.hero-facts div:last-child{border-right:none}
.hero-facts strong{display:block;font-size:15px;font-weight:700}
.hero-facts span{font-size:13px;color:var(--muted)}
@media(max-width:700px){
  .hero{padding:140px 0 70px}
  .hero-facts div{border-right:none;padding-right:0;margin-right:0;width:100%}
}

/* Unterseiten-Hero */
.page-hero{padding:170px 0 70px;border-bottom:1px solid var(--line)}
.page-hero h1{max-width:18em}
.page-hero .lede{max-width:44em}

/* Sections */
section{padding:100px 0}
h2{font-size:clamp(28px,3.8vw,46px);font-weight:800;letter-spacing:-.025em;line-height:1.08;max-width:18em}
.section-intro{margin-top:22px;font-size:17.5px;color:var(--muted);max-width:44em;line-height:1.75}
.border-b{border-bottom:1px solid var(--line)}

/* Stats */
.stats{padding:90px 0;border-bottom:1px solid var(--line)}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px}
.stat{border-top:1px solid var(--paper);padding-top:26px}
.stat .val{font-size:clamp(48px,5.6vw,76px);font-weight:800;letter-spacing:-.04em;line-height:1}
.stat .val sup{font-size:.42em;font-weight:700;vertical-align:super}
.stat .lbl{margin-top:14px;font-size:15px;color:var(--muted);line-height:1.6}
.stat .lbl strong{color:var(--paper)}
.stats-note{margin-top:40px;font-size:12.5px;color:var(--dim);line-height:1.6;max-width:64em}
@media(max-width:820px){.stats-grid{grid-template-columns:1fr;gap:36px}}

/* Leistungs-Liste (Startseite) */
.l-list{margin-top:60px;list-style:none}
.l-item{border-top:1px solid var(--line);text-decoration:none;display:grid;grid-template-columns:110px 1fr auto;gap:32px;align-items:center;padding:36px 0;transition:padding .25s ease,background .25s ease}
.l-item:last-child{border-bottom:1px solid var(--line)}
.l-item .idx{font-family:'IBM Plex Mono',monospace;font-size:14px;color:var(--dim);letter-spacing:.1em}
.l-item h3{font-size:clamp(21px,2.6vw,30px);font-weight:800;letter-spacing:-.02em}
.l-item p{margin-top:8px;font-size:15px;color:var(--muted);max-width:46em;line-height:1.65}
.l-item .arr{font-size:26px;color:var(--dim);transition:transform .25s ease,color .25s ease}
.l-item:hover{background:var(--ink-2);padding-left:20px;padding-right:20px}
.l-item:hover .arr{transform:translateX(8px);color:var(--paper)}
@media(max-width:760px){.l-item{grid-template-columns:1fr;gap:8px}.l-item .arr{display:none}}

/* Karten-Raster */
.grid-cards{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line)}
.gc{background:var(--ink-2);padding:30px 28px;transition:background .2s}
.gc:hover{background:var(--ink-3)}
.gc h4{font-size:16px;font-weight:700}
.gc p{margin-top:8px;font-size:14px;color:var(--muted);line-height:1.65}
@media(max-width:600px){.grid-cards{grid-template-columns:1fr}}

/* Prozess-Liste */
.prozess{list-style:none;counter-reset:step}
.prozess li{counter-increment:step;display:grid;grid-template-columns:70px 1fr;gap:22px;padding:22px 0;border-top:1px solid var(--line);align-items:baseline}
.prozess li:last-child{border-bottom:1px solid var(--line)}
.prozess li::before{content:"0" counter(step);font-family:'IBM Plex Mono',monospace;font-size:20px;font-weight:500;color:var(--dim)}
.prozess li strong{display:block;font-size:16.5px;font-weight:700;color:var(--paper)}
.prozess li span{font-size:14.5px;color:var(--muted);line-height:1.65}
.block-title{font-family:'IBM Plex Mono',monospace;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:24px}

/* Zweispalter */
.two-col{display:grid;grid-template-columns:1fr 1.05fr;gap:60px;align-items:start}
.two-col .sticky{position:sticky;top:110px}
.two-col p{margin-top:18px;font-size:16.5px;color:var(--muted);line-height:1.75}
.two-col p strong{color:var(--paper)}
.two-col .btn{margin-top:34px}
@media(max-width:940px){.two-col{grid-template-columns:1fr;gap:44px}.two-col .sticky{position:static}}

/* Heller Abschnitt */
.light{background:var(--paper);color:var(--ink)}
.light .eyebrow{color:#77726E}
.light .eyebrow::before{background:var(--ink)}
.light h2,.light h3{color:var(--ink)}
.light p{color:#55514F}
.light .btn{border-color:var(--ink);color:var(--ink)}
.light .btn:hover{background:var(--ink);color:var(--paper)}
.light .pledge li{border-color:#D5D1CC;color:#3B3839}
.light .pledge .mono{color:#8A8580}

.pledge{list-style:none}
.pledge li{padding:19px 0;border-top:1px solid var(--line);display:grid;grid-template-columns:max-content 1fr;gap:20px;align-items:baseline;font-size:15.5px;color:var(--paper)}
.pledge .p-txt{min-width:0}
.pledge li:last-child{border-bottom:1px solid var(--line)}
.pledge .mono{font-size:12px;color:var(--dim);white-space:nowrap;letter-spacing:.08em}

/* Region */
.orte{display:flex;flex-wrap:wrap;gap:10px}
.ort{font-family:'IBM Plex Mono',monospace;font-size:12.5px;letter-spacing:.05em;border:1px solid var(--line);padding:9px 16px;color:var(--muted);transition:all .2s}
.ort:hover{border-color:var(--paper);color:var(--paper)}
.ort.hq{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.note-box{margin-top:28px;padding:24px 28px;background:var(--ink-2);border:1px solid var(--line);font-size:15px;line-height:1.7;color:var(--muted)}
.note-box strong{color:var(--paper)}

/* Zielgruppen / 3er */
.tri{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.tri>div{background:var(--ink-2);padding:34px 30px;transition:background .2s}
.tri>div:hover{background:var(--ink-3)}
.tri h3{font-size:18px;font-weight:800}
.tri p{margin-top:10px;font-size:14.5px;color:var(--muted);line-height:1.65}
@media(max-width:820px){.tri{grid-template-columns:1fr}}

/* Person */
.person-grid{display:grid;grid-template-columns:290px 1fr;gap:64px;align-items:start}
.portrait{aspect-ratio:4/5;background:var(--ink-2);border:1px solid var(--line);display:grid;place-items:center;color:var(--dim);font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.08em;text-align:center;padding:20px}
blockquote.big{font-size:clamp(20px,2.5vw,28px);font-weight:500;line-height:1.5;letter-spacing:-.015em}
.attribution{margin-top:22px;font-size:15px;color:var(--muted)}
.attribution strong{color:var(--paper)}
.bio{margin-top:30px;font-size:16px;color:var(--muted);line-height:1.75;border-top:1px solid var(--line);padding-top:26px}
.werte{margin-top:26px;display:flex;gap:12px;flex-wrap:wrap}
.wert{font-family:'IBM Plex Mono',monospace;font-size:11.5px;letter-spacing:.1em;border:1px solid var(--line);padding:8px 15px;text-transform:uppercase;color:var(--muted)}
@media(max-width:880px){.person-grid{grid-template-columns:1fr;gap:40px}.portrait{max-width:320px}}

/* Blog */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.posts.two{grid-template-columns:1fr 1fr}
.post{background:var(--ink-2);padding:34px 30px;text-decoration:none;display:flex;flex-direction:column;transition:background .2s}
.post:hover{background:var(--ink-3)}
.post .meta{font-family:'IBM Plex Mono',monospace;font-size:11.5px;color:var(--dim);letter-spacing:.1em;text-transform:uppercase}
.post h3{margin-top:16px;font-size:18px;font-weight:800;line-height:1.35;letter-spacing:-.01em}
.post p{margin-top:12px;font-size:14px;color:var(--muted);line-height:1.65;flex:1}
.post .more{margin-top:20px;font-size:14px;font-weight:700}
.post .tag{display:inline-block;margin-top:14px}
@media(max-width:820px){.posts,.posts.two{grid-template-columns:1fr}}

/* Artikel */
.article{padding:170px 0 90px}
.article .meta-row{font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--dim);letter-spacing:.1em;text-transform:uppercase;margin-bottom:26px;display:flex;gap:18px;flex-wrap:wrap}
.article h1{font-size:clamp(30px,4.4vw,52px);max-width:20em}
.article .lede{font-size:19px;margin-top:24px}
.article-body{max-width:760px;margin-top:56px}
.article-body h2{font-size:clamp(22px,2.6vw,30px);margin-top:56px;margin-bottom:18px}
.article-body h3{font-size:19px;font-weight:700;margin-top:36px;margin-bottom:12px}
.article-body p{margin-bottom:20px;color:#C9C5C1;font-size:16.5px;line-height:1.8}
.article-body p strong{color:var(--paper)}
.article-body ul,.article-body ol{margin:0 0 22px 22px;color:#C9C5C1}
.article-body li{margin-bottom:10px;font-size:16px;line-height:1.7}
.article-body .hinweis{border-left:2px solid var(--paper);padding:18px 24px;background:var(--ink-2);margin:30px 0;font-size:15px;color:var(--muted)}
.article-cta{margin-top:64px;padding:38px;background:var(--ink-2);border:1px solid var(--line)}
.article-cta h3{font-size:20px;font-weight:800}
.article-cta p{margin-top:10px;color:var(--muted);font-size:15px}
.article-cta .btn{margin-top:22px}

/* Kontakt */
.k-details{list-style:none;font-size:16px}
.k-details li{padding:19px 0;border-top:1px solid var(--line)}
.k-details li:last-child{border-bottom:1px solid var(--line)}
.k-details .mono{display:block;font-size:11.5px;color:var(--dim);letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px}
.k-details a{color:var(--paper);text-decoration:none;border-bottom:1px solid var(--line)}
.k-details a:hover{border-color:var(--paper)}

/* Rechtstexte */
.legal{padding:170px 0 90px}
.legal h1{font-size:clamp(30px,4vw,48px)}
.legal-body{max-width:760px;margin-top:44px}
.legal-body h2{font-size:21px;margin-top:44px;margin-bottom:12px}
.legal-body h3{font-size:17px;font-weight:700;margin-top:26px;margin-bottom:8px}
.legal-body p,.legal-body li{color:var(--muted);font-size:15px;line-height:1.75;margin-bottom:14px}
.legal-body ul{margin-left:20px}

footer{border-top:1px solid var(--line);padding:44px 0 36px;font-size:13.5px;color:var(--dim)}
.foot-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:40px;margin-bottom:36px}
.foot-grid h4{font-size:13px;color:var(--paper);font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:14px}
.foot-grid ul{list-style:none}
.foot-grid li{margin-bottom:9px}
footer a{color:var(--muted);text-decoration:none}
footer a:hover{color:var(--paper)}
.foot-bottom{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:26px}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr;gap:26px}}

:focus-visible{outline:2px solid var(--paper);outline-offset:3px}
.light :focus-visible{outline-color:var(--ink)}

/* ---------- Logo ---------- */
.brand-logo{width:42px;height:42px;flex:none;border:1px solid var(--line)}

/* ---------- Schwebender CTA (FAB) ---------- */
.fab{
  position:fixed;right:22px;bottom:22px;z-index:70;
  display:flex;align-items:center;gap:10px;
  background:var(--paper);color:var(--ink);text-decoration:none;
  font-weight:700;font-size:14px;padding:14px 22px;
  border:1px solid var(--paper);box-shadow:0 8px 30px rgba(0,0,0,.45);
  opacity:0;transform:translateY(16px);pointer-events:none;
  transition:opacity .3s ease,transform .3s ease;
}
.fab.show{opacity:1;transform:none;pointer-events:auto}
.fab:hover{background:var(--ink);color:var(--paper)}
.fab-dot{width:8px;height:8px;background:currentColor;border-radius:50%;animation:pulse 2.2s infinite}
body.no-fab .fab{display:none}
@media(max-width:600px){
  .fab{right:14px;bottom:14px;padding:13px 18px;font-size:13px}
}
@media(prefers-reduced-motion:reduce){.fab{transition:none}}

/* ---------- Digital-Check (Quiz) ---------- */
.q-progress{height:3px;background:var(--line);margin-bottom:26px}
.q-bar{height:100%;background:var(--paper);width:0;transition:width .35s ease}
.q-step{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);margin-bottom:18px}
.q-question{font-size:clamp(22px,3vw,32px);line-height:1.25;margin-bottom:34px}
.q-options{display:grid;gap:12px}
.q-opt{
  text-align:left;background:var(--ink-2);color:var(--paper);
  border:1px solid var(--line);padding:20px 24px;font-size:16px;
  font-family:inherit;cursor:pointer;line-height:1.5;
  transition:background .15s,border-color .15s,transform .15s;
}
.q-opt:hover,.q-opt:focus-visible{background:var(--ink-3);border-color:var(--paper);transform:translateX(4px)}
.q-score{height:10px;background:var(--line);margin-top:26px;max-width:420px}
.q-score-bar{height:100%;background:var(--paper);width:0;transition:width 1s cubic-bezier(.22,1,.36,1)}
.q-score-label{margin-top:10px;font-size:13px;color:var(--muted);letter-spacing:.08em}

/* ---------- Eingebettetes Quiz ---------- */
.quiz-shell{margin-top:48px;max-width:820px}
.quiz-box,.quiz-result{background:var(--ink-2);border:1px solid var(--line);padding:38px 36px}
.quiz-shell .q-question{font-size:clamp(19px,2.4vw,25px);font-weight:800;line-height:1.3;margin:0 0 28px;letter-spacing:-.01em}
.light .quiz-box,.light .quiz-result{background:var(--paper);border-color:#D5D1CC}
@media(max-width:600px){.quiz-box,.quiz-result{padding:26px 20px}}

/* ---------- Angebote ---------- */
.angebote-grid .gc{display:flex;flex-direction:column}
.angebote-grid .gc .num{font-size:11px;letter-spacing:.12em;color:var(--dim)}
.angebote-grid .gc h4{margin-top:12px;font-size:17px}
.angebote-grid .gc p{flex:1}
.gc-link{display:inline-block;margin-top:16px;font-size:14px;font-weight:700;color:var(--paper);text-decoration:none;border-bottom:1px solid var(--line)}
.gc-link:hover{border-color:var(--paper)}
.gc-cta{background:var(--paper)!important;color:var(--ink)}
.gc-cta h4{color:var(--ink)}
.gc-cta p{color:#55514F}
.gc-cta .num{color:#8A8580}
.gc-cta .gc-link{color:var(--ink);border-color:#C9C5C0}
.gc-cta .gc-link:hover{border-color:var(--ink)}

/* ---------- Tablet-Feinschliff (768–1080px) ---------- */
@media(min-width:768px) and (max-width:1080px){
  .wrap{padding:0 36px}
  .hero{padding:150px 0 80px}
  h1{font-size:clamp(36px,6vw,54px)}
  .two-col{gap:48px}
  .posts{grid-template-columns:1fr 1fr}
  .tri{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:1fr 1fr 1fr;gap:32px}
}
@media(min-width:768px) and (max-width:1080px){
  .angebote-grid{grid-template-columns:1fr 1fr}
}

/* ---------- Echtes Logo & Porträt ---------- */
.brand-logo{height:44px;width:auto;border:none;display:block}
@media(max-width:600px){.brand-logo{height:38px}}
.portrait-img{
  width:100%;max-width:290px;height:auto;aspect-ratio:4/5;object-fit:cover;
  border:1px solid var(--line);display:block;justify-self:start;
  box-shadow:16px 16px 0 0 var(--ink-3);filter:grayscale(12%);
}
@media(max-width:880px){.portrait-img{max-width:240px}}

/* ================= WOW-FEINSCHLIFF ================= */

/* Scroll-Fortschritt */
#progress{display:none}

/* Kompakter Header beim Scrollen */
header{transition:background .25s ease}
header .nav{transition:height .25s ease}
header.compact .nav{height:60px}
header.compact .brand-logo{height:34px}
.brand-logo{transition:height .25s ease}

/* Display-Headline mit Outline-Typo (Startseite/Kontakt) */
h1.display{
  font-size:clamp(46px,7vw,96px);font-weight:900;line-height:.98;
  letter-spacing:-.035em;text-transform:uppercase;max-width:none;
}
h1.display .outline{color:transparent;-webkit-text-stroke:1.5px var(--paper)}
.hero-sub{
  margin-top:22px;font-family:'IBM Plex Mono',monospace;font-size:13px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--muted);
}
@media(max-width:600px){h1.display .outline{-webkit-text-stroke-width:1.2px}}

/* Hero-Netzwerk etwas präsenter */
#net{opacity:.42}

/* Buttons: Pfeil-Mikrointeraktion */
.btn-solid::after{content:"→";display:inline-block;margin-left:10px;transition:transform .2s ease}
.btn-solid:hover::after{transform:translateX(5px)}

/* Karten heben sich beim Hover leicht */
.gc,.post,.tri>div{transition:background .2s,transform .2s ease}
.gc:hover,.post:hover,.tri>div:hover{transform:translateY(-3px)}

/* Links: animierte Unterstreichung */
.gc-link,.article-body a,.bio a{
  background:linear-gradient(currentColor,currentColor) no-repeat 0 100%/0 1px;
  transition:background-size .25s ease;border-bottom:none;text-decoration:none;
  padding-bottom:2px;
}
.gc-link:hover,.article-body a:hover,.bio a:hover{background-size:100% 1px}

/* Zitat mit übergroßem Anführungszeichen */
blockquote.big{position:relative;padding-top:8px}
blockquote.big::before{
  content:"„";position:absolute;top:-52px;left:-10px;
  font-size:150px;font-weight:900;color:var(--paper);opacity:.10;
  line-height:1;pointer-events:none;
}

/* Zahlen der Prozess-Schritte bekommen beim Hover Kontrast */
.prozess li{transition:padding-left .2s ease}
.prozess li:hover{padding-left:6px}
.prozess li:hover::before{color:var(--paper)}

@media(prefers-reduced-motion:reduce){
  .gc:hover,.post:hover,.tri>div:hover{transform:none}
  .btn-solid::after{transition:none}
  header .nav,.brand-logo{transition:none}
}

/* ================= V2: MAGAZIN-LAYOUT STATT FOLIEN ================= */

/* Breiteres Raster, mehr Luft, dezenter Tiefen-Glow statt flacher Fläche */
:root{--max:1320px}
body{
  background:
    radial-gradient(1000px 620px at 88% -140px, #2F2C2D 0%, transparent 60%),
    radial-gradient(760px 540px at -12% 42%, #2C2A2B 0%, transparent 55%),
    var(--ink);
}
section{padding:84px 0}
.border-b{border-bottom:none}

/* Riesige Kapitelnummern statt Trennlinien (Magazin-Charakter) */
main{counter-reset:sec}
main>section{position:relative;overflow:hidden}
main>section::after{
  counter-increment:sec;content:"0" counter(sec);
  position:absolute;top:28px;right:2vw;z-index:0;
  font-family:'Archivo',sans-serif;font-weight:900;line-height:1;
  font-size:clamp(90px,13vw,200px);letter-spacing:-.04em;
  color:transparent;-webkit-text-stroke:1px var(--line);
  opacity:.5;pointer-events:none;user-select:none;
}
main>section.hero::after,main>section.page-hero::after{content:none}
main>section .wrap{position:relative;z-index:1}
main>section.light::after{-webkit-text-stroke-color:#D5D1CC}
@media(max-width:760px){main>section::after{font-size:88px;opacity:.35}}
article.article::after,section.legal::after{content:none!important}


/* Marquee */
.marquee{position:relative;z-index:2;border-top:1px solid var(--line);overflow:hidden;padding:18px 0;white-space:nowrap;margin-top:64px}
.marquee-track{display:inline-block;animation:mq 36s linear infinite}
.marquee span{font-family:'IBM Plex Mono',monospace;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-right:56px}
.marquee span::after{content:"—";margin-left:56px;color:var(--dim)}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.marquee-track{animation:none}}

/* Förder-Badge */
.badge-inline{
  display:inline-block;font-family:'IBM Plex Mono',monospace;font-size:11px;
  letter-spacing:.08em;text-transform:uppercase;font-weight:500;
  border:1px solid var(--paper);padding:4px 10px;margin-left:6px;
  color:var(--paper);white-space:nowrap;
;white-space:normal}
.light .badge-inline,.eyebrow .badge-inline{border-color:currentColor;color:inherit}

/* Branchen-Teaser als Links */
.tri-link{text-decoration:none;display:block}
.tri-link .gc-link{margin-top:16px;display:inline-block;color:var(--paper)}

/* Case-Karten mit großer Kennzahl */
.cases-grid .gc{position:relative;padding-bottom:86px}
.cases-grid .gc p{font-size:14.5px;line-height:1.7}
.cases-grid .gc p strong{color:var(--paper)}
.case-num{
  position:absolute;right:26px;bottom:20px;
  font-weight:900;font-size:clamp(34px,4vw,52px);letter-spacing:-.03em;
  color:transparent;-webkit-text-stroke:1.2px var(--paper);line-height:1;
}
.case-num small{font-size:.32em;-webkit-text-stroke:0;color:var(--muted);font-weight:600;letter-spacing:0}

/* ================= FEHLTRITT-BAROMETER ================= */
.baro{
  margin-top:52px;display:grid;grid-template-columns:.9fr 1.5fr;gap:1px;
  background:var(--line);border:1px solid var(--line);
}
.baro-controls{background:var(--ink-2);padding:38px 34px;display:flex;flex-direction:column;gap:34px;justify-content:center}
.baro-slider{display:block}
.baro-label{display:flex;justify-content:space-between;align-items:baseline;font-weight:700;font-size:15.5px;margin-bottom:12px}
.baro-val{font-family:'IBM Plex Mono',monospace;font-weight:500;font-size:13px;color:var(--muted)}
.baro-hint{display:block;margin-top:10px;font-size:12.5px;color:var(--dim);line-height:1.5}
.baro-slider input[type=range]{
  -webkit-appearance:none;appearance:none;width:100%;height:2px;
  background:var(--line);outline:none;cursor:pointer;
}
.baro-slider input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;width:22px;height:22px;
  background:var(--paper);border:none;border-radius:50%;cursor:grab;
  transition:transform .15s;
}
.baro-slider input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15)}
.baro-slider input[type=range]::-moz-range-thumb{width:22px;height:22px;background:var(--paper);border:none;border-radius:50%;cursor:grab}
.baro-stage{background:var(--ink);position:relative;min-height:380px}
#baro-canvas{width:100%;height:100%;position:absolute;inset:0;display:block}
/* Readout-Leiste: Diagnose führt, Kosten sind Beleg (nicht Held) */
.baro-readout{
  position:absolute;left:0;right:0;bottom:0;
  display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;
  padding:20px 24px 18px;
  background:linear-gradient(to top, rgba(20,18,19,.92) 0%, rgba(20,18,19,.72) 60%, rgba(20,18,19,0) 100%);
}
.baro-verdict{max-width:66%}
.baro-diag-tag{
  display:block;font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--dim);margin-bottom:5px;
}
.baro-diag-text{
  display:block;font-weight:800;font-size:17px;line-height:1.28;letter-spacing:-.01em;
  color:var(--paper);
}
.baro-verdict[data-state="ok"] .baro-diag-text{color:#7FBF8E}
.baro-verdict[data-state="warn"] .baro-diag-text{color:#E7B96B}
.baro-verdict[data-state="bad"] .baro-diag-text{color:#D66E68}
@media(max-width:900px){
  .baro{grid-template-columns:1fr}
  .baro-stage{min-height:300px}
}

/* Buchungs-Box (Kontakt) */
.booking-box{background:var(--ink-2);border:1px solid var(--line);padding:36px 34px}

/* ================= FEINSCHLIFF: ABSTÄNDE, PORTRÄT, BAROMETER ================= */

/* Kompaktere vertikale Rhythmik (riesige Abstände reduziert) */
section{padding:88px 0}
.page-hero{padding:150px 0 56px}
.hero{padding:160px 0 0}
@media(max-width:700px){section{padding:64px 0}.page-hero{padding:120px 0 44px}}
main>section::after{top:18px;font-size:clamp(80px,10vw,150px)}
.l-list,.tri,.grid-cards{margin-top:44px!important}
.two-col{gap:56px}


/* Logo: transparent, dezent skaliert */
.brand-logo{height:40px}
header.compact .brand-logo{height:32px}

/* Barometer: Legende + Erklärtext */
.baro-stage{min-height:420px}
.baro-legend{
  display:flex;gap:28px;flex-wrap:wrap;margin-top:18px;
  font-family:'IBM Plex Mono',monospace;font-size:11.5px;letter-spacing:.06em;
  color:var(--muted);
}
.baro-legend i{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:8px;vertical-align:baseline}
.dot-red{background:#D66E68}
.dot-core{background:var(--paper)}
.dot-green{background:#7FBF8E}
.baro-explain{
  margin-top:18px;padding:20px 26px;background:var(--ink-2);
  border-left:2px solid var(--paper);max-width:820px;
}
.baro-explain p{font-size:15px;color:var(--muted);line-height:1.7}
.baro-explain strong{color:var(--paper)}
@media(max-width:900px){.baro-stage{min-height:440px}.baro-legend{gap:14px;flex-direction:column}}

/* ================= V2.1: SIMULATION, BEWEISE, MOBILE ================= */

/* Barometer: Presets & Kosten-Zähler */
.baro-presets{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:6px}
.preset{
  font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.06em;
  background:none;border:1px solid var(--line);color:var(--muted);
  padding:7px 14px;cursor:pointer;transition:all .2s;
}
.preset:hover{border-color:var(--paper);color:var(--paper)}
.preset.active{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.baro-cost{
  text-align:right;display:flex;flex-direction:column;gap:3px;flex:none;
}
.baro-cost-num{font-size:13px;letter-spacing:.02em;color:var(--muted)}
.baro-cost-num b{font-weight:700;color:var(--paper);font-variant-numeric:tabular-nums}
.baro-cost-label{font-size:10px;letter-spacing:.08em;color:var(--dim);text-transform:none}

/* Journey-Stepper */
.journey{display:flex;align-items:stretch;gap:0;margin-top:48px}
.j-step{
  flex:1;background:var(--ink-2);border:1px solid var(--line);cursor:pointer;
  padding:26px 22px;text-align:left;display:flex;flex-direction:column;gap:8px;
  transition:all .2s;color:var(--paper);
}
.j-step:hover{transform:translateY(-3px)}
.j-step.active{border-color:var(--paper);background:var(--ink-3)}
.j-num{font-size:10.5px;letter-spacing:.16em;color:var(--dim)}
.j-step.active .j-num{color:var(--paper)}
.j-title{font-size:19px;font-weight:800}
.j-meta{font-size:10.5px;letter-spacing:.1em;color:var(--muted)}
.j-line{width:34px;align-self:center;border-top:1px dashed var(--line)}
.j-panel{margin-top:22px;padding:22px 26px;background:var(--ink-2);border-left:2px solid var(--paper);max-width:820px}
.j-panel p{font-size:15.5px;color:var(--muted);line-height:1.7}
.j-panel a{color:var(--paper)}

/* Stats: Quelle + Case-Link */
.stat-src{font-size:10.5px;letter-spacing:.14em;color:var(--dim);margin-top:14px}
.stat-link{
  display:inline-block;margin-top:10px;font-size:13.5px;font-weight:700;
  color:var(--paper);text-decoration:none;
  background:linear-gradient(currentColor,currentColor) no-repeat 0 100%/0 1px;
  transition:background-size .25s;padding-bottom:2px;
}
.stat-link:hover{background-size:100% 1px}

/* Vorher/Nachher-Prozesslandschaft */
.wandel{
  position:relative;margin-top:52px;border:1px solid var(--line);
  background:var(--ink-2);overflow:hidden;user-select:none;
}
.w-pane{position:relative;padding:34px 20px 20px}
.w-pane svg{width:100%;height:auto;display:block}
.w-before{
  position:absolute;inset:0;background:var(--ink-2);overflow:hidden;
  padding:34px 20px 20px;clip-path:inset(0 50% 0 0);
}
.w-tag{
  position:absolute;top:12px;font-size:10.5px;letter-spacing:.16em;color:var(--muted);
  border:1px solid var(--line);padding:4px 10px;background:var(--ink);
}
.w-after .w-tag{right:14px}
.w-before .w-tag{left:14px}
.w-handle{
  position:absolute;top:0;bottom:0;left:50%;width:2px;background:var(--paper);
  pointer-events:none;z-index:3;
}
.w-handle::after{
  content:"◂ ▸";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  background:var(--paper);color:var(--ink);font-size:11px;letter-spacing:2px;
  padding:8px 10px;border-radius:20px;white-space:nowrap;font-weight:700;
}
#wandel-slider{
  position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:ew-resize;z-index:4;
  -webkit-appearance:none;appearance:none;margin:0;
}

/* Quiz: taktiles Feedback + Themen-Auswertung + Benchmark + FARB-FIX */
.q-opt.sel{background:var(--paper)!important;color:var(--ink)!important;border-color:var(--paper)!important}
.r-row{display:grid;grid-template-columns:1fr 130px auto;gap:14px;align-items:center;padding:9px 0;border-bottom:1px solid var(--line)}
.r-lbl{font-size:14px;color:var(--paper)}
.r-track{height:5px;background:var(--ink-3);position:relative;overflow:hidden}
.r-fill{position:absolute;inset:0 auto 0 0;transition:width .8s ease}
.r-fill.gut{background:#7FBF8E}.r-fill.mittel{background:#C9A96A}.r-fill.kritisch{background:#D66E68}
.r-tag{font-size:9.5px;letter-spacing:.12em}
.r-tag.gut{color:#7FBF8E}.r-tag.mittel{color:#C9A96A}.r-tag.kritisch{color:#D66E68}
.r-bench{margin-top:18px;font-size:14px;color:var(--muted);font-style:italic}
/* Bugfix: Quiz-Farben fest verdrahten – nie wieder weiß auf weiß, egal in welchem Kontext */
.quiz-box,.quiz-result{background:var(--ink-2)!important;color:var(--paper)!important}
.quiz-box h3,.quiz-result h3,.q-question,.r-title{color:var(--paper)!important}
.light .quiz-box,.light .quiz-result{background:var(--ink-2)!important}
.q-opt{background:var(--ink-3);color:var(--paper);border:1px solid var(--line)}

/* ================= MOBILE-PASS ================= */
h1.display{overflow-wrap:break-word;-webkit-hyphens:manual;hyphens:manual;word-break:normal}
@media(max-width:760px){
  main>section::after{content:none}                /* Kapitelnummern mobil aus */
  section{padding:56px 0}
  .page-hero{padding:110px 0 36px}
  h1.display{font-size:clamp(34px,10.5vw,52px)}
  h2{font-size:clamp(24px,6.5vw,32px)}
  .lede{font-size:16px}
  .pledge li{grid-template-columns:1fr;gap:7px;padding:16px 0}   /* Label über Text gestapelt */
  .pledge .mono{font-size:10px}
  .journey{flex-direction:column;gap:10px}
  .j-line{display:none}
  .baro-stage{min-height:340px}
  .baro-readout{flex-direction:column;align-items:flex-start;gap:10px;padding:16px 20px 16px}
  .baro-verdict{max-width:100%}
  .baro-diag-text{font-size:15.5px}
  .baro-cost{text-align:left}
  .hero-facts{grid-template-columns:1fr;gap:14px}
  .marquee{margin-top:40px}
  .r-row{grid-template-columns:1fr;gap:6px}
  .r-track{width:100%}
  .stats-grid{grid-template-columns:1fr}
  .two-col{gap:36px}
  .wandel .w-tag{top:8px}
}

/* ================= INTERAKTIVE MINI-ELEMENTE (Leistungsseiten 01/02/03) ================= */
.miniviz{padding:0 0 88px}
main>section.miniviz::after{content:none;counter-increment:none}
.mv{
  display:grid;grid-template-columns:.85fr 1.4fr;gap:1px;
  background:var(--line);border:1px solid var(--line);
}
.mv-panel{background:var(--ink-2);padding:34px 32px;display:flex;flex-direction:column;gap:16px;justify-content:center}
.mv-eyebrow{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.mv-h{font-size:22px;line-height:1.25;letter-spacing:-.01em;margin:0}
.mv-sub{font-size:14.5px;color:var(--muted);line-height:1.6;margin:0}
.mv-slider{display:block;margin-top:2px}
.mv-lab{display:flex;justify-content:space-between;align-items:baseline;font-weight:700;font-size:14.5px;margin-bottom:12px}
.mv-val{font-family:'IBM Plex Mono',monospace;font-weight:500;font-size:13px;color:var(--muted)}
.mv input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:2px;background:var(--line);outline:none;cursor:pointer}
.mv input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:22px;height:22px;background:var(--paper);border:none;border-radius:50%;cursor:grab;transition:transform .15s}
.mv input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15)}
.mv input[type=range]::-moz-range-thumb{width:22px;height:22px;background:var(--paper);border:none;border-radius:50%;cursor:grab}
.mv-chips{display:flex;flex-wrap:wrap;gap:8px}
.mv-chip{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.02em;background:none;border:1px solid var(--line);color:var(--muted);padding:8px 13px;cursor:pointer;transition:all .18s}
.mv-chip:hover{border-color:var(--paper);color:var(--paper)}
.mv-chip.sel{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.mv-chip.on{border-color:#7FBF8E;color:#7FBF8E}
.mv-chip.on::before{content:"\2713 "}
.mv-readout{display:flex;flex-direction:column;gap:5px;margin-top:6px;padding-top:16px;border-top:1px solid var(--line)}
.mv-verdict{font-weight:800;font-size:15px;line-height:1.3;color:var(--paper)}
.mv-verdict[data-state="ok"]{color:#7FBF8E}
.mv-verdict[data-state="warn"]{color:#E7B96B}
.mv-verdict[data-state="bad"]{color:#D66E68}
.mv-metric{font-size:12px;letter-spacing:.04em;color:var(--dim)}
.mv-stage{background:var(--ink);position:relative;min-height:320px}
.mv-stage canvas{position:absolute;inset:0;width:100%;height:100%;display:block}
@media(max-width:820px){
  .mv{grid-template-columns:1fr}
  .mv-stage{min-height:250px;order:-1}
  .mv-h{font-size:19px}
  .mv-panel{padding:28px 24px}
}

/* 404: Schnell-Navigation */
.notfound-nav{margin-top:52px;padding-top:26px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:10px 26px;align-items:baseline}
.notfound-nav .mono{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--dim);width:100%;margin-bottom:6px}
.notfound-nav a{color:var(--muted);text-decoration:none;font-size:15px;border-bottom:1px solid transparent;transition:color .15s,border-color .15s}
.notfound-nav a:hover{color:var(--paper);border-color:var(--paper)}

/* ================= DATENADER (vertikaler Scroll-Fluss) ================= */
.spine{
  position:fixed;top:0;bottom:0;left:9px;width:2px;z-index:5;pointer-events:none;
  background:repeating-linear-gradient(180deg, var(--line) 0 6px, transparent 6px 13px);
  animation:spineflow 3.2s linear infinite;opacity:.7;
}
.spine-fill{
  position:absolute;top:0;left:0;width:100%;height:0;
  background:linear-gradient(180deg,#D66E68 0%,#E7B96B 42%,#7FBF8E 100%);
  background-size:100% 100vh;background-repeat:no-repeat;background-position:top;
  transition:height .12s linear;
}
.spine-pulse{
  position:absolute;bottom:-3px;left:50%;width:7px;height:7px;border-radius:50%;
  background:var(--paper);transform:translateX(-50%);box-shadow:0 0 10px 2px rgba(245,243,240,.35);
}
@keyframes spineflow{to{background-position:0 13px}}
@media(max-width:380px){.spine{display:none}}
@media(prefers-reduced-motion:reduce){.spine{animation:none}.spine-fill{transition:none}}

/* ================= MOBILE-HÄRTUNG (Touch, Silbentrennung, Umbrüche) ================= */
/* Regler: vertikales Scrollen bleibt möglich, horizontal steuert den Slider (kein Blockieren/Springen) */
#wandel-slider,.mv input[type=range],.baro-slider input[type=range]{touch-action:pan-y}
/* Fingerflächen der sichtbaren Thumbs vergrößern (WCAG-Ziele) */
.mv input[type=range]::-webkit-slider-thumb{width:26px;height:26px}
.mv input[type=range]::-moz-range-thumb{width:26px;height:26px}
.baro-slider input[type=range]::-webkit-slider-thumb{width:26px;height:26px}
.baro-slider input[type=range]::-moz-range-thumb{width:26px;height:26px}
/* Lange deutsche Komposita sauber trennen/umbrechen */
p,li,.bio,blockquote,.mv-sub,.baro-hint{-webkit-hyphens:auto;hyphens:auto}
h1,h2,h3,.display,.mv-h,.baro-verdict{overflow-wrap:break-word;hyphens:manual}

/* ================= QUIZ: Reifegrad-Radar + PDF ================= */
.r-radar-wrap{margin:24px 0 6px;display:flex;justify-content:center}
.r-radar{width:100%;max-width:340px;height:auto;display:block}
.r-pdf{margin-top:28px;padding-top:22px;border-top:1px solid var(--line)}
.r-pdf-lbl{display:block;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);margin-bottom:12px}
.r-pdf-row{display:flex;gap:10px;flex-wrap:wrap}
.r-pdf-mail{flex:1 1 240px;min-height:44px;background:var(--ink-2);border:1px solid var(--line);color:var(--paper);padding:10px 14px;font:inherit;font-size:15px}
.r-pdf-mail::placeholder{color:var(--dim)}
.r-pdf-mail:focus{outline:2px solid var(--muted);outline-offset:1px}
.r-pdf-btn{min-height:44px;white-space:nowrap}
.r-pdf-hint{display:block;margin-top:10px;font-size:12px;color:var(--muted);min-height:1em}
@media(max-width:520px){.r-pdf-btn{width:100%}}

/* ================= SCROLLYTELLING: Licht-Pfad durch die Prozess-Schritte ================= */
.prozess{position:relative}
.prozess::before{content:'';position:absolute;left:34px;top:14px;bottom:14px;width:2px;background:var(--line)}
.prozess-fill{position:absolute;left:34px;top:14px;width:2px;height:0;background:#7FBF8E;box-shadow:0 0 8px rgba(127,191,142,.5);transition:height .45s ease}
.prozess li{position:relative}
.prozess li::after{content:'';position:absolute;left:31px;top:30px;width:8px;height:8px;border-radius:50%;background:var(--line);transition:background .35s,box-shadow .35s;z-index:1}
.prozess li.on::after{background:#7FBF8E;box-shadow:0 0 10px 2px rgba(127,191,142,.4)}
.prozess li::before{transition:color .35s}
.prozess li.on::before{color:var(--paper)}
.prozess li strong{transition:color .35s}
.prozess li:not(.on) strong{color:var(--muted)}
@media(prefers-reduced-motion:reduce){.prozess-fill{transition:none}.prozess li::after,.prozess li::before,.prozess li strong{transition:none}}

/* Kleiner Responsive-Feinschliff: Quiz-Detailzeile bei sehr schmalen Screens sauber stapeln */
@media(max-width:520px){
  .r-row{grid-template-columns:1fr auto;gap:6px 12px}
  .r-row .r-track{grid-column:1 / -1;order:3}
}

/* Wandel: Hinweis-Puls am Griff (stoppt nach erster Interaktion) */
.w-hint .w-handle{animation:wpulse 1.5s ease-in-out infinite}
@keyframes wpulse{0%,100%{box-shadow:0 0 0 0 rgba(245,243,240,.4)}50%{box-shadow:0 0 0 12px rgba(245,243,240,0)}}
@media(prefers-reduced-motion:reduce){.w-hint .w-handle{animation:none}}
