/*
Theme Name: Suchy & Wisch
Theme URI: https://suchywisch.de
Author: Suchy & Wisch
Description: Individuelles Theme für Suchy & Wisch PV-Recruiting. Modernes One-Pager-Design (Petrol/Grün) mit passenden Rechtsseiten.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 8.0
License: GPL-2.0-or-later
Text Domain: suchywisch
*/

:root{
  --petrol:#0E2A24;
  --petrol-soft:#16382F;
  --green:#1FA567;
  --green-deep:#15824F;
  --green-glow:#52E0A0;
  --green-soft:#E3F2EA;
  --mist:#EEF3F0;
  --mist-2:#E2EAE6;
  --paper:#FCFDFC;
  --ink:#0F1F1B;
  --muted:#52635D;
  --line:rgba(15,31,27,.12);
  --line-dark:rgba(255,255,255,.14);
  --shadow:0 18px 50px -24px rgba(14,42,36,.5);
  --r:14px;
  --maxw:1180px;
  --display:'Sora',sans-serif;
  --body:'IBM Plex Sans',sans-serif;
  --mono:'IBM Plex Mono',monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:clip;overscroll-behavior:none}
body{
  font-family:var(--body);color:var(--ink);
  background:
    radial-gradient(900px 720px at 92% 0%, rgba(245,226,74,.07), transparent 56%),
    radial-gradient(1000px 900px at 2% 60%, rgba(245,226,74,.05), transparent 58%),
    radial-gradient(900px 820px at 100% 100%, rgba(245,226,74,.06), transparent 58%),
    var(--mist);
  line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
section[id]{scroll-margin-top:86px}
.eyebrow{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  font-weight:600;color:var(--green-deep);display:inline-flex;align-items:center;gap:.6em;
}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--green);display:inline-block}
.eyebrow.on-dark{color:var(--green-glow)}
h1,h2,h3{font-family:var(--display);font-weight:700;line-height:1.1;letter-spacing:-.02em}
h2{font-size:clamp(1.7rem,3.6vw,2.7rem);font-weight:700}
.sect{padding:96px 0}
.sub{color:var(--muted);font-size:1.06rem}

/* dark sections */
.dark-bg{
  position:relative;overflow:hidden;color:#fff;
  background:
    radial-gradient(900px 520px at 86% -12%, rgba(82,224,160,.13), transparent 60%),
    radial-gradient(580px 480px at 12% 4%, rgba(245,226,74,.16), transparent 62%),
    radial-gradient(620px 520px at 92% 104%, rgba(245,226,74,.14), transparent 60%),
    radial-gradient(760px 620px at -10% 112%, rgba(31,165,103,.16), transparent 60%),
    linear-gradient(158deg,#11302A,#0A211C 90%);
}
.dark-bg::after{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.55;
  background-image:
    repeating-linear-gradient(0deg,rgba(255,255,255,.028) 0 1px,transparent 1px 48px),
    repeating-linear-gradient(90deg,rgba(255,255,255,.028) 0 1px,transparent 1px 48px);
  -webkit-mask-image:radial-gradient(circle at 50% 38%, #000, transparent 82%);
  mask-image:radial-gradient(circle at 50% 38%, #000, transparent 82%);
}
.dark-bg > .wrap{position:relative;z-index:1}

/* buttons */
.btn{
  font-family:var(--body);font-weight:600;font-size:.98rem;
  display:inline-flex;align-items:center;gap:.55em;
  padding:15px 26px;border-radius:999px;cursor:pointer;border:0;line-height:1;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
}
.btn-primary{background:var(--green);color:#fff;box-shadow:0 10px 26px -10px rgba(31,165,103,.85)}
.btn-primary:hover{background:var(--green-deep);transform:translateY(-2px);box-shadow:0 16px 30px -12px rgba(31,165,103,.95)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn-ghost.on-dark{color:#fff;border-color:var(--line-dark)}
.btn-ghost.on-dark:hover{border-color:#fff}
.btn .arr{transition:transform .2s ease}
.btn:hover .arr{transform:translateX(3px)}

/* header */
header.site-header{
  position:sticky;top:0;z-index:50;background:rgba(238,243,240,.82);
  backdrop-filter:saturate(140%) blur(12px);border-bottom:1px solid transparent;
  transition:border-color .3s ease, background .3s ease;
}
header.site-header.scrolled{border-color:var(--line);background:rgba(238,243,240,.94)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--display);font-weight:700;letter-spacing:-.02em}
.brand .mark{
  width:38px;height:38px;border-radius:10px;flex:none;
  background:linear-gradient(135deg,var(--petrol),var(--petrol-soft));
  display:grid;place-items:center;position:relative;overflow:hidden;
}
.brand .mark span{font-family:var(--display);font-weight:700;color:var(--green-glow);font-size:.95rem;letter-spacing:-.04em;z-index:1}
.brand .mark::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 70% 20%,rgba(82,224,160,.4),transparent 60%)}
.brand b{font-size:1.05rem}
.brand small{display:block;font-family:var(--mono);font-weight:600;font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:1px}
.navlinks{display:flex;align-items:center;gap:30px}
.navlinks a{font-size:.94rem;font-weight:500;color:var(--ink);opacity:.82;transition:opacity .15s}
.navlinks a:hover{opacity:1}
.nav-cta{display:flex;align-items:center;gap:14px}
.burger{display:none;background:none;border:0;cursor:pointer;width:44px;height:44px;border-radius:0;position:relative}
.burger span{position:absolute;left:12px;width:20px;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s cubic-bezier(.5,.2,.2,1), opacity .2s ease}
.burger span:nth-child(1){top:16px}
.burger span:nth-child(2){top:22px}
.burger span:nth-child(3){top:28px}
.burger[aria-expanded="true"]{background:transparent;border-color:transparent}
.burger[aria-expanded="true"] span:nth-child(1){top:22px;transform:rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){top:22px;transform:rotate(-45deg)}

/* hero */
.hero{position:relative;padding:28px 0 80px;overflow:hidden}
.hero::before{content:"";position:absolute;top:-220px;right:-160px;width:620px;height:620px;background:radial-gradient(circle,rgba(31,165,103,.18),transparent 62%);z-index:0}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:56px;align-items:center;position:relative;z-index:1}
.hero h1{font-size:clamp(2.3rem,5.4vw,4rem);margin:22px 0 0;font-weight:800}
.hero h1 .hl{color:var(--green-deep)}
.hero .lead{font-size:clamp(1.12rem,2vw,1.32rem);font-weight:500;margin-top:20px;max-width:34ch}
.hero p.body{margin-top:18px;color:var(--muted);max-width:48ch;font-size:1.04rem}
.hero .cta-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px}
.trust{display:flex;align-items:center;gap:10px;margin-top:26px;font-size:.86rem;color:var(--muted)}
.trust .dots{display:flex}
.trust .dots i{width:9px;height:9px;border-radius:50%;background:var(--green);display:block;margin-left:-3px;border:2px solid var(--mist)}

/* hero visual (illustration + floating accents) */
.hero-visual{position:relative;align-self:center;width:100%}
.hv-frame{position:relative;width:100%;border-radius:24px;overflow:hidden;background:var(--paper);border:1px solid var(--line);box-shadow:var(--shadow)}
.hv-frame::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:radial-gradient(115% 70% at 82% 4%, rgba(82,224,160,.16), transparent 58%)}
.hv-frame img{width:100%;height:auto;display:block;position:relative}
.hv-badge{position:absolute;left:-18px;bottom:36px;z-index:2;background:var(--paper);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:14px;padding:12px 16px;font-weight:600;font-size:.92rem;display:flex;align-items:center;gap:10px}
.hv-dot{width:9px;height:9px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 rgba(82,224,160,.6);animation:pulse 2.4s infinite;flex:none}
.hv-stat{position:absolute;right:-16px;top:30px;z-index:2;background:linear-gradient(160deg,var(--petrol),#0B231D);color:#fff;border-radius:14px;padding:13px 18px;box-shadow:var(--shadow);text-align:center}
.hv-stat b{display:block;font-family:var(--display);font-weight:700;font-size:1.3rem;color:var(--green-glow);line-height:1.05}
.hv-stat span{font-family:var(--mono);font-size:.72rem;letter-spacing:.04em;color:rgba(255,255,255,.78)}
@media (max-width:920px){ .hero-visual{max-width:460px;margin:0 auto} }
@media (max-width:520px){
  .hv-badge{left:0;font-size:.84rem;padding:10px 13px}
  .hv-stat{right:0;top:16px;padding:11px 15px}
  .hv-stat b{font-size:1.12rem}
}

/* approach card (hero signature) */
.approach-card{
  border-radius:22px;padding:30px;color:#fff;box-shadow:var(--shadow);position:relative;overflow:hidden;
  background:
    radial-gradient(420px 300px at 110% -10%, rgba(82,224,160,.16), transparent 60%),
    linear-gradient(160deg,var(--petrol),#0B231D);
}
.approach-card::after{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:repeating-linear-gradient(0deg,rgba(255,255,255,.03) 0 1px,transparent 1px 40px),repeating-linear-gradient(90deg,rgba(255,255,255,.03) 0 1px,transparent 1px 40px);
  -webkit-mask-image:radial-gradient(circle at 60% 30%, #000, transparent 85%);mask-image:radial-gradient(circle at 60% 30%, #000, transparent 85%);
}
.ac-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;position:relative;z-index:1}
.ac-head .tag{font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--green-glow);display:inline-flex;align-items:center;gap:8px}
.ac-head .tag i{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 rgba(82,224,160,.6);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(82,224,160,.5)}70%{box-shadow:0 0 0 9px rgba(82,224,160,0)}100%{box-shadow:0 0 0 0 rgba(82,224,160,0)}}
.ac-head .step-of{font-family:var(--mono);font-size:.7rem;color:rgba(255,255,255,.5)}
.ac-steps{position:relative;list-style:none;z-index:1}
.ac-track,.ac-fill{position:absolute;left:6px;top:18px;bottom:18px;width:2px;border-radius:2px}
.ac-track{background:rgba(255,255,255,.13)}
.ac-fill{bottom:auto;height:0;background:var(--green-glow);box-shadow:0 0 10px var(--green-glow);transition:height 1.3s ease}
.ac-steps li{display:flex;gap:16px;align-items:flex-start;padding:11px 0;position:relative}
.ac-steps .dot{width:14px;height:14px;border-radius:50%;flex:none;margin-top:3px;background:rgba(255,255,255,.16);border:2px solid rgba(255,255,255,.28);transition:.4s;position:relative;z-index:2}
.ac-steps .dot.lit{background:var(--green-glow);border-color:var(--green-glow);box-shadow:0 0 14px var(--green-glow)}
.ac-steps b{display:block;font-family:var(--display);font-weight:600;font-size:1rem}
.ac-steps span{font-size:.85rem;color:rgba(255,255,255,.62)}
.ac-foot{margin-top:22px;padding-top:18px;border-top:1px solid rgba(255,255,255,.12);font-size:.9rem;color:rgba(255,255,255,.82);position:relative;z-index:1}
.ac-foot b{color:var(--green-glow);font-family:var(--display);font-weight:600}

/* roles strip */
.roles{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--paper)}
.roles .wrap{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:14px;padding-top:24px;padding-bottom:24px}
.roles .rl-label{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-right:6px}
.chip{display:inline-flex;align-items:center;gap:8px;background:var(--mist);border:1px solid var(--line);border-radius:999px;padding:9px 16px;font-weight:600;font-size:.9rem}
.chip i{width:7px;height:7px;border-radius:50%;background:var(--green);flex:none}

/* insight */
.insight .wrap{max-width:880px}
.insight h2{margin:18px 0 26px;color:#fff}
.insight h2 em{font-style:normal;color:var(--green-glow)}
.insight p{color:rgba(255,255,255,.84);font-size:1.1rem;max-width:64ch}
.insight p + p{margin-top:18px}
.insight .kicker{margin-top:30px;display:inline-block;font-family:var(--display);font-weight:600;font-size:1.15rem;color:#fff;border-left:3px solid var(--green);padding-left:16px}

/* process */
.process .head{max-width:640px;margin-bottom:54px}
.process .head h2{margin:16px 0 14px}
.process-top{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;margin-bottom:54px}
.process-top .head{max-width:560px;margin-bottom:0}
.process-illu{width:100%;max-width:440px;height:auto;justify-self:end}
@media (max-width:920px){
  .process-top{grid-template-columns:1fr;gap:24px}
  .process-illu{max-width:360px;margin:0 auto;justify-self:center}
}
.steps{display:grid;gap:18px}
.step{
  display:grid;grid-template-columns:auto 1fr auto;gap:26px;align-items:start;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  padding:28px 30px;position:relative;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
}
.step:hover{transform:translateX(4px);box-shadow:var(--shadow);border-color:transparent}
.step .no{font-family:var(--mono);font-weight:600;font-size:.82rem;color:var(--green-deep);width:46px;height:46px;border-radius:12px;background:var(--green-soft);display:grid;place-items:center;flex:none;border:1px solid var(--line)}
.step h3{font-size:1.22rem;margin-bottom:7px}
.step p{color:var(--muted);font-size:.99rem;max-width:62ch}
.step .note{display:inline-block;margin-top:10px;font-size:.84rem;color:var(--green-deep);background:var(--green-soft);padding:5px 11px;border-radius:8px}
.step .meta{font-family:var(--mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);white-space:nowrap;align-self:center}
.process .mid-cta{text-align:center;margin-top:46px;max-width:560px;margin-left:auto;margin-right:auto}
.process .mid-cta p{font-size:1.05rem;font-weight:500;margin-bottom:18px}

/* warum */
.warum .head{text-align:center;max-width:640px;margin:0 auto 50px}
.warum .head .eyebrow{justify-content:center}
.warum .head h2{color:#fff;margin-top:14px}
.warum .head p{color:rgba(255,255,255,.7);margin-top:12px}
.warum-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.wcard{background:rgba(255,255,255,.045);border:1px solid var(--line-dark);border-radius:var(--r);padding:26px;transition:transform .2s ease,background .2s ease}
.wcard:hover{transform:translateY(-4px);background:rgba(255,255,255,.07)}
.wcard .ic{width:46px;height:46px;border-radius:12px;background:rgba(82,224,160,.13);color:var(--green-glow);display:grid;place-items:center;margin-bottom:18px}
.wcard .ic svg{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.wcard h3{color:#fff;font-size:1.14rem;margin-bottom:8px}
.wcard p{color:rgba(255,255,255,.7);font-size:.92rem}

/* proof */
.proof .head{max-width:660px;margin-bottom:46px}
.proof .head h2{margin:14px 0}
.proof-sub{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:0 0 18px}
.profiles{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:54px}
.profile{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:24px}
.profile .ph-tag{font-family:var(--mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--green-deep);background:var(--green-soft);padding:4px 9px;border-radius:6px;display:inline-block}
.profile h4{font-family:var(--display);font-size:1.18rem;margin:14px 0 4px}
.profile .reg{font-size:.86rem;color:var(--muted);margin-bottom:14px}
.profile ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.profile li{font-size:.9rem;display:flex;gap:9px;align-items:flex-start}
.profile li::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--green);margin-top:8px;flex:none}
.profile .avail{margin-top:16px;padding-top:14px;border-top:1px dashed var(--line);font-size:.83rem;color:var(--ink);font-weight:600}
.quotes{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.quote{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:28px 30px;position:relative}
.quote .qtag{position:absolute;top:18px;right:20px;font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);background:var(--mist-2);padding:3px 8px;border-radius:6px}
.quote .mk{font-family:var(--display);font-size:3rem;line-height:.5;color:var(--green);height:24px}
.quote p{font-size:1.04rem;margin:8px 0 18px}
.quote .by{display:flex;align-items:center;gap:12px}
.quote .by .av{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--petrol),var(--petrol-soft));color:var(--green-glow);display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:.85rem;flex:none}
.quote .by b{display:block;font-size:.92rem}
.quote .by span{font-size:.82rem;color:var(--muted)}

/* about */
.about{background:var(--paper);border-top:1px solid var(--line)}
.about .head{max-width:560px}
.about .head h2{margin:14px 0}
.about .head p{color:var(--muted)}
.about-top{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;margin-bottom:48px}
.about-illu{width:100%;max-width:520px;height:auto;justify-self:end;margin-left:auto}
@media (max-width:920px){
  .about-top{grid-template-columns:1fr;gap:28px}
  .about-illu{order:-1;max-width:420px;margin:0 auto;justify-self:center}
}
.founders{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.founder{display:flex;gap:20px;align-items:flex-start;background:var(--mist);border:1px solid var(--line);border-radius:var(--r);padding:26px}
.founder .av{width:64px;height:64px;border-radius:16px;flex:none;background:linear-gradient(135deg,var(--petrol),var(--petrol-soft));color:var(--green-glow);display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:1.3rem}
.founder h3{font-size:1.18rem}
.founder .role{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--green-deep);margin:4px 0 10px}
.founder p{font-size:.93rem;color:var(--muted)}

/* faq */
.faq .head{max-width:600px;margin:0 auto 28px;text-align:center}
.faq .head .eyebrow{justify-content:center}
.faq .head h2{margin-top:14px}
.faq-illu{display:block;width:100%;max-width:248px;height:auto;margin:0 auto 36px}
.faq-list{max-width:820px;margin:0 auto}
.qa{border-bottom:1px solid var(--line)}
.qa button{width:100%;background:none;border:0;cursor:pointer;text-align:left;display:flex;justify-content:space-between;align-items:center;gap:20px;padding:24px 4px;font-family:var(--display);font-weight:600;font-size:1.12rem;color:var(--ink)}
.qa .ic{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--line);flex:none;display:grid;place-items:center;transition:.25s;position:relative}
.qa .ic::before,.qa .ic::after{content:"";position:absolute;background:var(--green-deep);border-radius:2px}
.qa .ic::before{width:13px;height:2px}
.qa .ic::after{width:2px;height:13px;transition:.25s}
.qa.open .ic{background:var(--green);border-color:var(--green)}
.qa.open .ic::before,.qa.open .ic::after{background:#fff}
.qa.open .ic::after{transform:scaleY(0)}
.qa .ans{max-height:0;overflow:hidden;transition:max-height .35s ease}
.qa .ans p{padding:0 4px 24px;color:var(--muted);max-width:70ch}

/* final cta */
.final{
  background:
    radial-gradient(1200px 720px at 50% -12%, rgba(82,224,160,.38), transparent 62%),
    radial-gradient(900px 650px at 90% 114%, rgba(31,165,103,.30), transparent 60%),
    radial-gradient(760px 540px at 6% 92%, rgba(82,224,160,.16), transparent 60%),
    linear-gradient(160deg,#1C5645 0%,#114035 34%,#0B2A23 66%,#05130F 100%);
}
.final .wrap{max-width:860px}
.final-card{
  position:relative;text-align:center;border-radius:28px;padding:60px 52px;
  background:
    radial-gradient(130% 120% at 50% -10%, rgba(82,224,160,.14), transparent 58%),
    linear-gradient(160deg, rgba(255,255,255,.06), rgba(255,255,255,.018));
  border:1px solid rgba(82,224,160,.22);
  box-shadow:0 36px 80px -34px rgba(0,0,0,.65), inset 0 1px 0 rgba(255,255,255,.06);
}
.final-card .eyebrow{justify-content:center}
.final h2{color:#fff;font-size:clamp(2rem,4.4vw,3.1rem);margin:16px 0 0}
.final h2 em{font-style:normal;color:#4FC892}
.final p{color:rgba(255,255,255,.92);font-size:1.12rem;max-width:52ch;margin:18px auto 26px}
.final-points{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin:0 auto 30px}
.final-points li{display:inline-flex;align-items:center;gap:9px;font-size:.92rem;font-weight:500;color:rgba(255,255,255,.9);background:rgba(255,255,255,.05);border:1px solid var(--line-dark);border-radius:999px;padding:9px 16px}
.final-points li i{font-style:normal;color:var(--petrol);background:var(--green-glow);width:19px;height:19px;border-radius:50%;display:grid;place-items:center;font-size:.7rem;font-weight:700;flex:none}
.final .cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.final .btn-ic{width:18px;height:18px;flex:none}
.final .micro{margin-top:24px;font-family:var(--mono);font-size:.8rem;color:rgba(255,255,255,.74);letter-spacing:.04em}
@media (max-width:720px){ .final-card{padding:40px 24px} }

/* footer */
footer.site-footer{background:var(--paper);color:var(--muted);padding:64px 0 30px;font-size:.92rem;border-top:1px solid var(--line)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:42px;border-bottom:1px solid var(--line)}
.foot-grid h5{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:16px;font-weight:600}
.foot-grid a{display:block;margin-bottom:10px;color:var(--ink);opacity:.82;transition:color .15s,opacity .15s}
.foot-grid a:hover{color:var(--green-deep);opacity:1}
.foot-grid .brand{color:var(--ink);margin-bottom:14px;opacity:1}
.foot-grid .brand small{color:var(--muted)}
.foot-about{font-size:.9rem;color:var(--muted);max-width:34ch}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;padding-top:24px;font-size:.82rem;color:var(--muted)}
.foot-bottom .legal{font-family:var(--mono)}

/* legal pages */
.legal-page{padding:118px 0 90px;background:var(--paper)}
.legal-page .wrap{max-width:820px}
.legal-page h1{font-size:clamp(2rem,4vw,2.8rem);margin-bottom:10px}
.legal-page .updated{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:42px;display:block}
.legal-page h2{font-size:1.32rem;margin:36px 0 12px}
.legal-page h3{font-size:1.06rem;margin:22px 0 8px}
.legal-page p,.legal-page li{color:var(--muted);font-size:1rem;margin-bottom:12px}
.legal-page ul{padding-left:20px;margin-bottom:14px}
.legal-page li{margin-bottom:7px}
.legal-page a{color:var(--green-deep);text-decoration:underline}
.legal-page strong{color:var(--ink);font-weight:600}
.legal-page .back{display:inline-flex;align-items:center;gap:8px;margin-top:40px;font-weight:600;color:var(--green-deep)}

/* ===== dynamic scroll reveals: direction + depth, staggered (data-rv set by JS) ===== */
.js .rv{
  opacity:0;will-change:opacity,transform;
  transition:opacity 1.2s cubic-bezier(.22,.61,.36,1),
             transform 1.45s cubic-bezier(.16,.72,.3,1);
}
.js .rv[data-rv="up"]{transform:translateY(58px)}
.js .rv[data-rv="left"]{transform:translateX(-92px)}
.js .rv[data-rv="right"]{transform:translateX(92px)}
.js .rv[data-rv="zoom-up"]{transform:translateY(48px) scale(.8)}
/* illustrations: pronounced + slow fade, rising in from the depth */
.js .rv[data-rv="zoom"]{
  transform:translateY(36px) scale(.58);
  transition:opacity 1.9s cubic-bezier(.4,0,.25,1),
             transform 1.9s cubic-bezier(.16,.72,.3,1);
}
.js .rv.in{opacity:1;transform:none}

/* hero PV background graphic */
.hero{ }
.hero-pvbg{
  position:absolute;right:-60px;bottom:-50px;width:680px;max-width:62%;
  z-index:0;pointer-events:none;color:var(--green-deep);opacity:.10;
}
.hero-pvbg svg{width:100%;height:auto;display:block}
.hero-grid{position:relative;z-index:1}

/* illu-pv scene as faint hero background */
.hero-illubg{
  position:absolute;left:0;right:0;bottom:0;z-index:0;pointer-events:none;opacity:.16;
  -webkit-mask-image:linear-gradient(to top,#000 26%,transparent 86%);
  mask-image:linear-gradient(to top,#000 26%,transparent 86%);
}
.hero-illubg img{width:100%;height:auto;display:block}
.hero-illu-bottom{display:none}

/* legibility of hero copy + buttons over the background illustration */
.hero-copy{position:relative;z-index:1}
/* soft, semi-transparent white wash behind the hero text (not fully white) */
.hero-copy::before{
  content:"";position:absolute;z-index:-1;pointer-events:none;
  left:-52px;right:-44px;top:-36px;bottom:24px;
  background:radial-gradient(78% 64% at 36% 42%,
    rgba(255,255,255,.88), rgba(255,255,255,.6) 48%, rgba(255,255,255,0) 82%);
  filter:blur(26px);
}
.hero .eyebrow,
.hero h1,
.hero .lead,
.hero p.body,
.hero .trust{
  text-shadow:0 1px 16px rgba(255,255,255,1), 0 0 6px rgba(255,255,255,.95);
}
/* darker, more readable secondary copy in the hero */
.hero p.body{color:#22322D}
.hero .trust{color:#22322D}
.hero .btn-primary{
  box-shadow:0 10px 26px -10px rgba(31,165,103,.9), 0 4px 26px 6px rgba(255,255,255,.7);
}
.hero .btn-ghost{
  background:rgba(255,255,255,.74);
  backdrop-filter:saturate(140%) blur(6px);
  box-shadow:0 4px 24px 6px rgba(255,255,255,.7);
}

/* faint panel texture behind the whole hero */
.hero::after{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background-image:
    linear-gradient(115deg, rgba(31,165,103,.05) 1px, transparent 1px),
    linear-gradient(115deg, rgba(31,165,103,.05) 1px, transparent 1px);
  background-size:46px 46px, 46px 46px;
  background-position:0 0, 23px 23px;
  -webkit-mask-image:radial-gradient(120% 90% at 80% 10%, #000 30%, transparent 75%);
  mask-image:radial-gradient(120% 90% at 80% 10%, #000 30%, transparent 75%);
}

/* PV scene (scroll-drawn line-art) */
.pv-scene{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.pv-scene .head{max-width:660px;margin-bottom:30px}
.pv-scene .head h2{margin:14px 0 12px}
.pv-scene .head .sub{color:var(--muted)}
.pv-scene .stage{position:relative;width:100%;margin:0 auto;max-width:1100px}
.pv-scene svg.scene{width:100%;height:auto;display:block;overflow:visible}

/* line styles */
.pv-scene .ln{fill:none;stroke:var(--ink);stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.pv-scene .ln.g{stroke:var(--green-deep)}
.pv-scene .ln.thin{stroke-width:1.8}
.pv-scene .panelfill{fill:rgba(31,165,103,.07)}
.pv-scene .sun{fill:none;stroke:var(--green);stroke-width:2.6}
.pv-scene .dash{stroke-dasharray:2 8}
.pv-scene .lbl{font-family:var(--mono);font-size:13px;letter-spacing:.04em;fill:var(--muted)}
.pv-scene .lbl.g{fill:var(--green-deep)}
.pv-scene .ground{stroke:var(--line);stroke-width:2}

/* draw + pop animations (progressive enhancement: hidden only when JS active) */
.js .pv-scene .draw{stroke-dasharray:1;stroke-dashoffset:1}
.pv-scene.in .draw{animation:pvDraw 1.5s cubic-bezier(.6,.05,.25,1) forwards}
@keyframes pvDraw{to{stroke-dashoffset:0}}
.js .pv-scene .pop{opacity:0;transform:translateY(12px)}
.pv-scene.in .pop{animation:pvPop .8s ease forwards}
@keyframes pvPop{to{opacity:1;transform:none}}
.pv-scene .rays{transform-box:fill-box;transform-origin:center;animation:pvSpin 70s linear infinite}
@keyframes pvSpin{to{transform:rotate(360deg)}}

@media (prefers-reduced-motion:reduce){
  .pv-scene .draw{stroke-dashoffset:0!important}
  .pv-scene .pop{opacity:1!important;transform:none!important}
  .pv-scene .rays{animation:none!important}
}
@media (max-width:720px){
  .hero-pvbg{display:none}
  .pv-scene .lbl{font-size:15px}
}

@media (max-width:920px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .approach-card{max-width:460px}
  .profiles{grid-template-columns:1fr}
  .warum-grid{grid-template-columns:1fr 1fr}
  .founders{grid-template-columns:1fr}
  .quotes{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:30px}
}
@media (max-width:720px){
  .sect{padding:70px 0}
  .nav-cta .btn{display:none}
  .burger{display:block;position:relative;z-index:61}
  /* Marke im Header etwas kleiner */
  .brand{gap:9px}
  .brand .mark{width:32px;height:32px;border-radius:9px}
  .brand .mark span{font-size:.82rem}
  .brand b{font-size:.92rem}
  .brand small{font-size:.54rem}
  /* Mobil-Menü als Drawer von rechts */
  .navlinks{
    display:flex;position:fixed;top:0;right:0;height:100dvh;width:min(82vw,330px);
    flex-direction:column;align-items:stretch;justify-content:flex-start;gap:3px;
    padding:90px 16px 28px;background:var(--paper);
    box-shadow:-24px 0 60px -28px rgba(14,42,36,.55);
    transform:translateX(100%);transition:transform .34s cubic-bezier(.4,0,.2,1);
    z-index:60;overflow-y:auto;
  }
  .navlinks.open{transform:translateX(0)}
  .navlinks a{padding:15px 16px;border-radius:12px;font-size:1.06rem;font-weight:600;opacity:1}
  .navlinks a:hover,.navlinks a:active{background:var(--green-soft);color:var(--green-deep)}
  .step{grid-template-columns:auto 1fr;gap:18px;padding:22px}
  .step .meta{display:none}
  .warum-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .rv,.js .rv{opacity:1!important;transform:none!important;filter:none!important;clip-path:none!important}
}

/* ===== STORY (scroll-driven character) ===== */
.story{position:relative;height:440vh;background:var(--mist)}
.story-sticky{position:sticky;top:0;height:100vh;display:flex;align-items:center;overflow:hidden}
.story-inner{display:grid;grid-template-columns:1.02fr .98fr;gap:48px;align-items:center;width:100%}

/* left copy */
.story-copy{position:relative;z-index:3;max-width:540px}
.story-steps{position:relative;min-height:300px;margin:20px 0 8px}
.story-step{position:absolute;inset:0;opacity:0;transform:translateY(22px);transition:opacity .5s ease,transform .5s ease;pointer-events:none}
.story[data-step="0"] .story-step[data-for="0"],
.story[data-step="1"] .story-step[data-for="1"],
.story[data-step="2"] .story-step[data-for="2"],
.story[data-step="3"] .story-step[data-for="3"]{opacity:1;transform:none;pointer-events:auto}
.st-no{font-family:var(--mono);font-size:.78rem;letter-spacing:.22em;color:var(--green-glow);display:block;margin-bottom:16px}
.story-step h2{color:#fff;font-size:clamp(1.9rem,3.6vw,3rem);line-height:1.08}
.story-step h2 em{font-style:normal;color:var(--green-glow)}
.story-step p{color:rgba(255,255,255,.82);margin-top:16px;max-width:44ch;font-size:1.06rem}

.story-progress{display:flex;align-items:center;gap:16px;margin:30px 0 26px}
.sp-track{flex:1;max-width:260px;height:4px;border-radius:4px;background:rgba(255,255,255,.15);overflow:hidden}
.sp-fill{display:block;height:100%;width:12%;background:var(--green-glow);border-radius:4px;box-shadow:0 0 10px var(--green-glow);transition:width .35s ease}
.sp-count{font-family:var(--mono);font-size:.78rem;color:rgba(255,255,255,.6)}
.sp-count b{color:#fff}
.story-cta{margin-top:4px}

/* right stage */
.story-stage{position:relative;height:80vh;min-height:540px}
.stage-glow{position:absolute;right:2%;bottom:2%;width:86%;height:84%;background:radial-gradient(circle at 58% 62%,rgba(31,165,103,.34),transparent 62%);filter:blur(8px);z-index:0}
.stage-ring{position:absolute;right:7%;bottom:5%;width:min(58vh,500px);aspect-ratio:1;border-radius:50%;border:1px dashed rgba(82,224,160,.28);z-index:0;animation:ringSpin 50s linear infinite}
@keyframes ringSpin{to{transform:rotate(360deg)}}

.figure{position:absolute;right:0;bottom:0;height:80vh;max-height:780px;width:auto;object-fit:contain;z-index:2;opacity:0;transform:translateY(18px) scale(.985);transition:opacity .55s ease,transform .55s ease;filter:drop-shadow(0 30px 44px rgba(0,0,0,.45))}
.story[data-step="0"] .fig-hero,
.story[data-step="1"] .fig-hero{opacity:1;transform:none}
.story[data-step="2"] .fig-install{opacity:1;transform:none}
.story[data-step="3"] .fig-thumbs{opacity:1;transform:none}

/* accents */
.acc{position:absolute;opacity:0;transition:opacity .45s ease;z-index:3;pointer-events:none}
.acc-scan{left:0;right:0;top:0;bottom:0;background:linear-gradient(0deg,transparent 44%,rgba(82,224,160,.16) 50%,transparent 56%)}
.story[data-step="0"] .acc-scan{opacity:1;animation:scanMove 2.8s ease-in-out infinite}
@keyframes scanMove{0%{transform:translateY(-32%)}50%{transform:translateY(32%)}100%{transform:translateY(-32%)}}
.acc-found{left:3%;top:10%;background:rgba(82,224,160,.14);border:1px solid rgba(82,224,160,.42);color:#fff;padding:9px 15px;border-radius:999px;font-family:var(--mono);font-size:.76rem;display:flex;align-items:center;gap:8px;backdrop-filter:blur(4px)}
.acc-found .tick{color:var(--green-glow)}
.story[data-step="0"] .acc-found{opacity:1}

.acc-checks{left:0;top:16%;display:flex;flex-direction:column;gap:12px}
.acc-checks .chk{background:rgba(255,255,255,.07);border:1px solid var(--line-dark);border-radius:11px;padding:10px 15px;color:#fff;font-weight:600;font-size:.92rem;display:flex;align-items:center;gap:10px;opacity:0;transform:translateX(-16px);backdrop-filter:blur(4px)}
.acc-checks .chk i{font-style:normal;color:var(--petrol);background:var(--green-glow);width:20px;height:20px;border-radius:50%;display:grid;place-items:center;font-size:.7rem;flex:none}
.story[data-step="1"] .acc-checks{opacity:1}
.story[data-step="1"] .acc-checks .chk{animation:accIn .5s ease forwards;animation-delay:var(--d)}
@keyframes accIn{to{opacity:1;transform:none}}

.acc-panels{left:1%;bottom:9%;width:240px;height:140px}
.acc-panels .pn{opacity:0;transform:translateY(10px)}
.story[data-step="2"] .acc-panels{opacity:1}
.story[data-step="2"] .acc-panels .pn{animation:accIn .5s ease forwards;animation-delay:var(--d)}

.acc-team{left:3%;bottom:20%;display:flex;align-items:center}
.acc-team .av{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-family:var(--display);font-weight:700;color:var(--green-glow);background:linear-gradient(135deg,var(--petrol-soft),#0b231d);border:2px solid var(--green-glow);opacity:0;transform:scale(.6)}
.acc-team .av2{margin-left:-14px}
.acc-team .tlabel{margin-left:12px;font-family:var(--mono);font-size:.76rem;color:#fff;opacity:0}
.story[data-step="3"] .acc-team .av{animation:accPop .5s ease forwards}
.story[data-step="3"] .acc-team .av2{animation-delay:.12s}
.story[data-step="3"] .acc-team .tlabel{animation:accIn .5s ease forwards;animation-delay:.24s}
@keyframes accPop{to{opacity:1;transform:none}}

@media (max-width:860px){
  .story{height:auto}
  .story-sticky{position:static;height:auto;padding:84px 0}
  .story-inner{grid-template-columns:1fr;gap:30px}
  .story-stage{order:-1;height:auto;min-height:0}
  .figure{position:relative;height:auto;max-height:none;width:76%;margin:0 auto;display:none;transform:none}
  .fig-hero{display:block;opacity:1}
  .story-steps{position:static;min-height:0}
  .story-step{position:relative;opacity:1;transform:none;pointer-events:auto;padding:18px 0;border-top:1px solid var(--line-dark)}
  .story-step:first-child{border-top:0}
  .acc,.stage-glow,.stage-ring{display:none}
  .story-progress{display:none}
}
@media (prefers-reduced-motion:reduce){
  .acc-scan,.stage-ring{animation:none!important}
  .figure{transition:none!important}
}

/* ===== RIDER: traveling character across hero → process ===== */
.rider{
  position:fixed;top:0;right:0;bottom:0;width:min(40vw,560px);
  z-index:6;pointer-events:none;opacity:0;visibility:hidden;
  transition:opacity .5s ease,visibility .5s ease;
}
.rider.active{opacity:1;visibility:visible}
.rider-inner{position:relative;width:100%;height:100%}
.rider::before{
  content:"";position:absolute;right:-4%;bottom:0;width:96%;height:74%;
  background:radial-gradient(circle at 58% 72%,rgba(31,165,103,.18),transparent 64%);
  opacity:0;transition:opacity .5s ease;
}
.rider.on-dark::before{opacity:1}
.rider .figure{
  position:absolute;left:50%;bottom:0;height:84vh;max-height:780px;width:auto;object-fit:contain;
  transform:translateX(-50%) translateY(14px);opacity:0;
  transition:opacity .55s ease,transform .55s ease;
  filter:drop-shadow(0 24px 40px rgba(14,42,36,.3));
}
.rider .figure.show{opacity:1;transform:translateX(-50%) translateY(0)}
.rider-cap{
  position:absolute;left:6%;top:22%;font-family:var(--mono);font-size:.74rem;letter-spacing:.04em;
  color:#fff;background:rgba(14,42,36,.55);border:1px solid rgba(82,224,160,.4);
  padding:8px 14px;border-radius:999px;backdrop-filter:blur(6px);white-space:nowrap;
  opacity:0;transform:translateY(6px);transition:opacity .4s ease,transform .4s ease;
}
.rider-cap.show{opacity:1;transform:none}

/* band layout: keep content on the left, free room on the right for the rider */
@media (min-width:981px){
  .band > .wrap{padding-right:min(38vw,520px)}
  .roles.band > .wrap{padding-right:min(30vw,420px)}
  .insight.band > .wrap{max-width:var(--maxw)}
  .hero.band .hero-grid{display:block}
  .hero.band .hero-copy{max-width:600px}
  .hero.band .hero-pvbg{display:none}
}
@media (max-width:980px){
  .rider{display:none}
}

/* ===== HERO DRAMA: clumsy drops panel (scroll-scrubbed frames) + panel over headline ===== */
.hero-drama{position:fixed;inset:0;pointer-events:none;z-index:5;opacity:1;transition:opacity .4s ease}
.hero-drama.done{opacity:0;visibility:hidden}
.drama-canvas{position:absolute;right:1%;bottom:0;width:min(42vw,540px);height:92vh}
.drama-panel{position:absolute;right:15vw;top:32vh;width:min(16vw,175px);opacity:0;will-change:transform,opacity;transform-origin:center center;filter:drop-shadow(0 16px 22px rgba(14,42,36,.35))}
@media (max-width:860px){ .hero-drama{display:none} }

/* ===== SECTION BACKGROUND MOTIFS (subtle line-art behind content) ===== */
.insight,.process,.warum,.proof,.about,.faq,.final{position:relative;overflow:hidden}
.process > .wrap,.proof > .wrap,.about > .wrap,.faq > .wrap{position:relative;z-index:1}
.sbg{position:absolute;z-index:0;pointer-events:none}
.sbg svg{width:100%;height:auto;display:block}
/* light sections → green tint · dark sections → light tint */
.bg-flow,.bg-doc,.bg-link,.bg-q{color:var(--green-deep)}
.bg-search,.bg-radar,.bg-sun{color:#fff}
.bg-search{top:-44px;right:-46px;width:min(52%,640px);opacity:.16}
.bg-flow{bottom:-44px;left:-44px;width:min(48%,600px);opacity:.13}
.bg-radar{top:-72px;right:-72px;width:min(48%,540px);opacity:.16}
.bg-doc{top:8px;right:-24px;width:min(38%,460px);opacity:.12}
.bg-link{bottom:-44px;right:-20px;width:min(38%,420px);opacity:.12}
.bg-q{top:-34px;left:-34px;width:min(40%,400px);opacity:.13}
.bg-sun{top:-96px;left:50%;transform:translateX(-50%);width:min(82%,760px);opacity:.18}
@media (max-width:720px){ .sbg{display:none} }

/* ===== glow accents (where it fits) ===== */
.eyebrow.on-dark{text-shadow:0 0 16px rgba(82,224,160,.55)}
.insight h2 em,
.final h2 em{text-shadow:0 0 30px rgba(82,224,160,.6), 0 0 11px rgba(82,224,160,.45)}
.hero h1 .hl{text-shadow:0 0 22px rgba(31,165,103,.24)}
/* kicker: bewusst KEIN Glow (User-Wunsch) – schlichte grüne Kante aus .insight .kicker oben */
.wcard .ic{box-shadow:0 0 26px -6px rgba(82,224,160,.4)}
.final-points li i{box-shadow:0 0 12px rgba(82,224,160,.6)}
/* soft green bloom behind dark-section headings */
.insight::before,
.warum::before{
  content:"";position:absolute;z-index:0;pointer-events:none;border-radius:50%;
  background:radial-gradient(closest-side, rgba(82,224,160,.22), transparent 72%);
  filter:blur(26px);
}
.insight::before{left:26%;top:2%;width:min(680px,72%);height:360px;transform:translateX(-50%)}
.warum::before{left:50%;top:-26px;width:min(760px,82%);height:300px;transform:translateX(-50%)}
@media (max-width:720px){ .insight::before{left:50%} }

/* ===== ILLUSTRATION BAND (stylized PV scene) ===== */
.illu-band{background:var(--paper);padding:92px 0 64px;border-top:1px solid var(--line);overflow:hidden}
.illu-head{max-width:680px;margin:0 auto 30px;text-align:center}
.illu-head .eyebrow{justify-content:center}
.illu-head h2{margin:14px 0 12px}
.illu-head .sub{margin:0 auto}
.illu-img{width:100%;max-width:1040px;height:auto;margin:0 auto;display:block}
@media (max-width:720px){ .illu-band{padding:64px 0 40px} }

/* ============================================================
   WISSEN (Magazin/Ratgeber-Rubrik) – Hub + Artikel
   ============================================================ */

/* ---- Hub ---- */
.wissen-hero{padding:84px 0 72px}
.wissen-hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(680px 420px at 80% 4%, rgba(82,224,160,.40), transparent 66%),
    radial-gradient(560px 460px at 10% 104%, rgba(31,165,103,.34), transparent 62%),
    radial-gradient(900px 520px at 50% -30%, rgba(82,224,160,.18), transparent 70%);
}
.wissen-hero>.wrap{position:relative;z-index:2}
.wissen-hero h1{font-size:clamp(2.1rem,4.6vw,3.3rem);font-weight:800;margin:18px 0 0;color:#fff}
.wissen-hero .lead{font-size:clamp(1.06rem,1.8vw,1.24rem);font-weight:500;margin-top:18px;max-width:60ch;color:rgba(255,255,255,.9)}
.wissen-body{padding:64px 24px 96px}
.wissen-intro{max-width:760px;margin:0 auto 56px;color:var(--muted);font-size:1.06rem}
.wissen-intro p{margin-bottom:1em}
.wissen-group{margin-bottom:64px}
.wissen-group-head{margin-bottom:26px}
.wissen-group-head h2{font-size:clamp(1.5rem,2.8vw,2rem)}
.wissen-group-head p{color:var(--muted);margin-top:6px;font-size:1.02rem}

/* ---- Card grid (Hub + verwandte Artikel) ---- */
.wq-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px}
.wq-card{
  display:flex;flex-direction:column;background:var(--paper);
  border:1px solid var(--line);border-radius:var(--r);padding:26px 24px 22px;
  box-shadow:0 1px 0 rgba(15,31,27,.03);
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.wq-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
.wq-tag{
  font-family:var(--mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;
  font-weight:600;color:var(--green-deep);background:var(--green-soft);
  align-self:flex-start;padding:4px 10px;border-radius:999px;margin-bottom:14px;
}
.wq-card h3{font-size:1.18rem;line-height:1.22;margin-bottom:10px}
.wq-card p{color:var(--muted);font-size:.96rem;flex:1;margin-bottom:16px}
.wq-more{font-family:var(--body);font-weight:600;font-size:.92rem;color:var(--green-deep)}
.wq-card:hover .wq-more{color:var(--green)}

/* ---- Artikel ---- */
.wq-article{padding:0 0 96px}
.wq-narrow{max-width:760px}
.wq-crumbs{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:.82rem;color:var(--muted);padding:28px 0 0}
.wq-crumbs a{color:var(--muted);transition:color .15s}
.wq-crumbs a:hover{color:var(--green-deep)}
.wq-crumbs .cur{color:var(--ink)}
.wq-head{padding:26px 0 8px;border-bottom:1px solid var(--line);margin-bottom:34px}
.wq-head h1{font-size:clamp(1.9rem,4vw,2.8rem);font-weight:800;margin:14px 0 16px}
.wq-meta{display:flex;gap:10px;font-family:var(--mono);font-size:.76rem;letter-spacing:.04em;color:var(--muted);text-transform:uppercase;margin-bottom:8px}

.wq-body{font-size:1.08rem;line-height:1.72;color:#1b2a26}
.wq-body h2{font-size:clamp(1.4rem,2.6vw,1.85rem);margin:42px 0 14px}
.wq-body h3{font-size:1.22rem;margin:30px 0 10px;font-weight:600}
.wq-body p{margin-bottom:1.15em}
.wq-body ul,.wq-body ol{margin:0 0 1.15em 1.3em}
.wq-body li{margin-bottom:.5em}
.wq-body strong{color:var(--ink);font-weight:600}
.wq-body a{color:var(--green-deep);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px;transition:color .15s}
.wq-body a:hover{color:var(--green)}
.wq-body .wq-stat{
  background:var(--green-soft);border-left:3px solid var(--green);border-radius:0 10px 10px 0;
  padding:16px 20px;margin:24px 0;font-size:1.02rem;color:var(--petrol);line-height:1.5;
}
.wq-body .wq-stat strong{font-family:var(--display);font-size:1.5rem;color:var(--green-deep);display:inline-block;margin-right:.35em;letter-spacing:-.02em}
.wq-body .wq-pull{
  border:0;margin:30px 0;padding:6px 0 6px 24px;border-left:3px solid var(--green);
  font-family:var(--display);font-size:clamp(1.2rem,2.4vw,1.55rem);font-weight:600;line-height:1.32;
  color:var(--petrol);letter-spacing:-.01em;
}

/* ---- FAQ (nutzt den vorhandenen .qa-Toggle aus main.js) ---- */
.wq-faq{margin:54px 0 8px}
.wq-faq>h2{font-size:clamp(1.4rem,2.6vw,1.85rem);margin-bottom:18px}
.wq-faq .qa{border:1px solid var(--line);border-radius:12px;background:var(--paper);margin-bottom:12px;overflow:hidden}
.wq-faq .qa button{
  width:100%;text-align:left;background:none;border:0;cursor:pointer;
  font-family:var(--display);font-weight:600;font-size:1.04rem;color:var(--ink);
  padding:18px 22px;display:flex;align-items:center;justify-content:space-between;gap:16px;line-height:1.35;
}
.wq-faq .qa .ic{
  flex:none;width:28px;height:28px;border-radius:50%;border:1.5px solid var(--line);
  display:grid;place-items:center;position:relative;transition:.25s;
}
.wq-faq .qa .ic::before,.wq-faq .qa .ic::after{
  content:"";position:absolute;top:auto;left:auto;background:var(--green-deep);border-radius:2px;
}
.wq-faq .qa .ic::before{width:12px;height:2px}
.wq-faq .qa .ic::after{width:2px;height:12px;transition:transform .25s ease}
.wq-faq .qa.open .ic{background:var(--green);border-color:var(--green)}
.wq-faq .qa.open .ic::before,.wq-faq .qa.open .ic::after{background:#fff}
.wq-faq .qa.open .ic::after{transform:scaleY(0)}
.wq-faq .qa .ans{max-height:0;overflow:hidden;transition:max-height .3s ease}
.wq-faq .qa .ans p{padding:0 22px 18px;color:var(--muted);font-size:1rem;line-height:1.6}

/* ---- CTA-Box (Artikel + Hub) ---- */
.wq-cta{border-radius:18px;padding:48px 40px;margin:60px 0 0;text-align:center}
.wq-cta-inner{position:relative;z-index:1;max-width:620px;margin:0 auto}
.wq-cta .eyebrow{justify-content:center}
.wq-cta h2{color:#fff;font-size:clamp(1.5rem,3vw,2.1rem);margin:14px 0 12px}
.wq-cta h2 em{color:var(--green-glow);font-style:normal}
.wq-cta p{color:rgba(255,255,255,.88);margin:0 auto 24px;font-size:1.04rem}
.wq-cta .cta-row{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}

/* ---- Verwandte Artikel ---- */
.wq-related{margin-top:64px}
.wq-related>h2{font-size:clamp(1.4rem,2.6vw,1.85rem);margin-bottom:20px}
.wq-back{margin-top:26px}
.wq-back a{font-weight:600;color:var(--green-deep)}
.wq-back a:hover{color:var(--green)}

@media (max-width:720px){
  .wissen-hero{padding:60px 0 52px}
  .wissen-body{padding:48px 20px 72px}
  .wq-cta{padding:38px 24px}
  .wq-body{font-size:1.04rem}
}

/* ---- FAQ-Sammelseite ---- */
/* Hero zweispaltig: Text + Illustration als helle Karte auf dem dunklen Banner */
.faq-hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
.faq-hero-copy{min-width:0}
.faq-hero-illu{
  justify-self:end;width:100%;max-width:380px;
  display:flex;align-items:center;justify-content:center;
}
.faq-hero-illu img{width:100%;max-width:360px;height:auto;display:block}
.faq-page .wissen-body{position:relative;z-index:0}
.faq-bg{
  position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);
  width:100vw;z-index:-1;pointer-events:none;opacity:.2;
  background-repeat:repeat-y;background-position:top center;background-size:min(1500px,118%) auto;
}
.faq-pick{max-width:860px;margin:0 auto 56px}
.faq-lead-2{color:var(--muted);font-size:1.06rem;margin-bottom:10px}
.faq-dd{max-width:860px;margin:0 auto;border:1px solid var(--line);border-radius:14px;background:var(--paper);overflow:hidden}
.faq-dd>summary{
  list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:18px 22px;font-family:var(--display);font-weight:600;font-size:1.05rem;color:var(--ink);
}
.faq-dd>summary::-webkit-details-marker{display:none}
.faq-dd>summary .dd-ic{flex:none;width:12px;height:12px;border-right:2px solid var(--green-deep);border-bottom:2px solid var(--green-deep);transform:rotate(45deg);transition:transform .25s ease;margin-top:-4px}
.faq-dd[open]>summary .dd-ic{transform:rotate(-135deg);margin-top:2px}
.faq-dd[open]>summary{border-bottom:1px solid var(--line)}
.faq-dd-list{display:flex;flex-direction:column;padding:8px 0}
.faq-dd-list a{
  font-family:var(--body);font-size:.96rem;font-weight:500;color:var(--petrol);
  padding:11px 22px;border-left:3px solid transparent;transition:background .15s, border-color .15s, color .15s;
}
.faq-dd-list a:hover{background:var(--green-soft);border-left-color:var(--green);color:var(--green-deep)}
.faq-group{max-width:860px;margin:0 auto 48px}
.faq-group-head{display:flex;align-items:center;flex-wrap:wrap;gap:10px 14px;margin-bottom:16px}
.faq-group-head h2{font-size:clamp(1.35rem,2.4vw,1.7rem);margin:0}
.faq-group-head .wq-tag{margin-bottom:0}
.faq-src{font-family:var(--body);font-weight:600;font-size:.9rem;color:var(--green-deep);margin-left:auto}
.faq-src:hover{color:var(--green)}
.faq-page .wq-cta{max-width:860px;margin-left:auto;margin-right:auto}
@media (max-width:820px){
  .faq-hero-grid{grid-template-columns:1fr;gap:18px}
  .faq-hero-illu{max-width:300px;justify-self:start;order:2}
  .faq-hero-illu img{max-width:250px}
}

/* Über-uns-Seite */
.ueber-hero{
  position:relative;overflow:hidden;padding:80px 0 64px;color:var(--ink);
  background:
    radial-gradient(700px 460px at 84% 4%, rgba(31,107,79,.16), transparent 62%),
    radial-gradient(540px 440px at 7% 96%, rgba(245,226,74,.09), transparent 58%),
    radial-gradient(620px 520px at 4% 108%, rgba(20,77,70,.12), transparent 60%),
    linear-gradient(160deg,#EAF3EC 0%,#DCEBE0 58%,#D2E6D8 100%);
}
.ueber-hero h1{font-size:clamp(2.1rem,4.6vw,3.3rem);font-weight:800;margin:18px 0 0}
.ueber-hero h1 .hl{color:var(--green-deep)}
.ueber-hero .lead{font-size:clamp(1.06rem,1.8vw,1.24rem);font-weight:500;margin-top:18px;max-width:58ch;color:#3a4a44}
.founders-sect{padding:50px 0 10px;background:var(--paper);position:relative;overflow:hidden}
.founders-sect > .wrap > .eyebrow{display:inline-flex;margin-bottom:22px}
.ueber-page .about{padding-top:60px;border-top:0}
.ueber-cta-wrap{padding-bottom:90px}

/* CTA: E-Mail-Zeile unter den Buttons (dunkle CTA-Boxen) */
.cta-mail{margin-top:40px;font-size:.95rem;color:rgba(255,255,255,.9);display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;line-height:1.4}
.cta-mail::before{content:"";width:17px;height:17px;flex:none;background-color:rgba(255,255,255,.7);-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='5' width='18' height='14' rx='2'/><path d='m3 7 9 6 9-6'/></svg>") center/contain no-repeat;mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='5' width='18' height='14' rx='2'/><path d='m3 7 9 6 9-6'/></svg>") center/contain no-repeat}
.cta-mail a{color:#fff;font-weight:600;text-decoration:underline;text-underline-offset:3px;text-decoration-color:rgba(255,255,255,.45)}
.cta-mail a:hover{text-decoration-color:#fff}
/* spezifischer als .wq-cta p / .final p, damit der Abstand wirklich greift */
.wq-cta .cta-mail,.final .cta-mail{margin-top:40px}

/* ===== KONTAKTSEITE ===== */
.kontakt-hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.kontakt-hero-copy{min-width:0}
.kontakt-hero-illu{justify-self:end;width:100%;max-width:360px;display:flex;align-items:center;justify-content:center}
.kontakt-hero-illu img{width:100%;max-width:340px;height:auto;display:block}
@media (max-width:820px){
  .kontakt-hero-grid{grid-template-columns:1fr;gap:16px}
  .kontakt-hero-illu{max-width:260px;order:2;justify-self:start}
  .kontakt-hero-illu img{max-width:230px}
}
.kontakt-body{padding:64px 24px 92px}
.kontakt-grid{display:grid;grid-template-columns:0.8fr 1.2fr;gap:32px;max-width:1140px;margin:0 auto;align-items:start}
.kontakt-card{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:34px}
.kontakt-card h2{font-size:clamp(1.35rem,2.4vw,1.7rem);margin-bottom:6px}
.kontakt-sub{color:var(--muted);margin-bottom:22px;font-size:1rem}
.kontakt-sub a{color:var(--green-deep);text-decoration:underline;text-underline-offset:2px}
.kontakt-line{display:flex;align-items:center;gap:16px;padding:16px 0;border-top:1px solid var(--line)}
.kontakt-line:first-of-type{border-top:0;padding-top:4px}
.kc-ic{width:46px;height:46px;border-radius:12px;flex:none;background:var(--green-soft);color:var(--green-deep);display:grid;place-items:center}
.kc-ic svg{width:22px;height:22px}
.kontakt-line small{display:block;font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.kontakt-line b{font-size:1.12rem;color:var(--ink)}
.kontakt-line:hover b{color:var(--green-deep)}
.kontakt-meta{font-size:.86rem;color:var(--muted);margin:18px 0 22px}
.kontakt-card .btn{width:100%;justify-content:center}
.vorlage .mailtpl{
  white-space:pre-line;font-family:var(--mono);font-size:.82rem;line-height:1.7;color:#2a3a35;
  background:var(--mist);border:1px solid var(--line);border-radius:12px;padding:20px 22px;margin-bottom:16px;
}
.copy-btn{cursor:pointer;width:100%;justify-content:center}
.copy-btn.copied{background:var(--green);color:#fff;border-color:var(--green)}
@media (max-width:760px){ .kontakt-grid{grid-template-columns:1fr} }

/* #problem: konkrete Hilfe "So kommen Sie an diese Fachkräfte" */
.insight-help{margin-top:36px;padding-top:30px;border-top:1px solid var(--line-dark);max-width:640px}
.ih-label{display:block;font-family:var(--mono);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--green-glow);margin-bottom:16px}
.ih-list{list-style:none;margin:0 0 24px;display:grid;gap:11px}
.ih-list li{position:relative;padding-left:30px;color:rgba(255,255,255,.88);font-size:1.02rem;line-height:1.5}
.ih-list li::before{content:"";position:absolute;left:4px;top:4px;width:8px;height:13px;border:solid var(--green-glow);border-width:0 2px 2px 0;transform:rotate(45deg)}
.insight-help .cta-row{display:flex;flex-wrap:wrap;gap:14px}

/* Hauch Gelb auch im Startseiten-Hero (heller Bereich) */
.hero{background:
  radial-gradient(640px 460px at 6% 12%, rgba(245,226,74,.10), transparent 60%),
  radial-gradient(600px 500px at 96% 90%, rgba(245,226,74,.07), transparent 62%)}

/* Rollen-Pills mobil sauberer anordnen */
@media (max-width:600px){
  .roles .wrap{gap:8px 10px;padding-top:20px;padding-bottom:20px}
  .roles .rl-label{flex-basis:100%;text-align:center;margin:0 0 6px}
  .chip{font-size:.82rem;padding:7px 13px}
}

/* Artikel-Inhaltsverzeichnis (einklappbar) – v.a. fürs Scrollen auf Mobil */
.wq-toc{margin:6px 0 30px;border:1px solid var(--line);border-radius:12px;background:var(--paper);overflow:hidden}
.wq-toc>summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;font-family:var(--display);font-weight:600;font-size:.98rem;color:var(--ink)}
.wq-toc>summary::-webkit-details-marker{display:none}
.wq-toc>summary .dd-ic{flex:none;width:11px;height:11px;border-right:2px solid var(--green-deep);border-bottom:2px solid var(--green-deep);transform:rotate(45deg);transition:transform .25s ease;margin-top:-4px}
.wq-toc[open]>summary .dd-ic{transform:rotate(-135deg);margin-top:2px}
.wq-toc[open]>summary{border-bottom:1px solid var(--line)}
.wq-toc-list{display:flex;flex-direction:column;padding:6px 0 10px}
.wq-toc-list a{padding:9px 18px;font-size:.93rem;font-weight:500;color:var(--petrol);border-left:3px solid transparent;transition:background .15s,border-color .15s,color .15s}
.wq-toc-list a:hover{background:var(--green-soft);border-left-color:var(--green);color:var(--green-deep)}

.wq-body h2[id]{scroll-margin-top:92px}

/* ===== Mobil-Feinschliff (Batch) ===== */
@media (max-width:720px){
  .hero .cta-row{justify-content:center}
  .hero .trust{justify-content:center;text-align:center}
}
@media (max-width:600px){
  .process-illu{max-width:228px}
}

/* Wissen-Hub: Sprung-Chips zu den Über-Themen (v.a. mobil, damit man nicht ewig scrollt) */
.wissen-jump{display:flex;flex-wrap:wrap;gap:10px;max-width:760px;margin:0 auto 40px}
.wissen-jump a{
  font-family:var(--body);font-size:.9rem;font-weight:600;color:var(--green-deep);
  background:var(--green-soft);border:1px solid transparent;border-radius:999px;padding:9px 16px;
  transition:background .15s,color .15s,transform .15s;
}
.wissen-jump a:hover{background:var(--green);color:#fff;transform:translateY(-1px)}
.wissen-group{scroll-margin-top:90px}
@media (min-width:781px){ .wissen-jump{display:none} }  /* nur mobil/tablet, Desktop hat die Karten direkt im Blick */

/* Mobil-Menü: abdunkelnder Backdrop hinter dem Drawer */
.nav-backdrop{position:fixed;inset:0;background:rgba(10,22,18,.5);opacity:0;visibility:hidden;transition:opacity .3s ease, visibility .3s ease;z-index:48}
/* bei offenem Menü Header-Hintergrund weg, damit die Abdunklung auch den Header-Bereich erfasst */
body.menu-open .site-header{background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;border-bottom-color:transparent}
.nav-backdrop.show{opacity:1;visibility:visible}
@media (min-width:721px){ .nav-backdrop{display:none} }
body.menu-open{overflow:hidden}

/* Problem-Hilfe-Buttons ("So gehen wir dabei vor" / "Mehr im Wissen-Bereich") mobil zentriert */
@media (max-width:720px){ .insight-help .cta-row{justify-content:center} }

/* Mobil: Hero-PV-Illustration als dezenter Hintergrund nach OBEN (statt unten) */
@media (max-width:720px){
  .hero-illubg{
    top:0;bottom:auto;opacity:.42;
    -webkit-mask-image:linear-gradient(to bottom,#000 30%,transparent 90%);
    mask-image:linear-gradient(to bottom,#000 30%,transparent 90%);
  }
  .hero-illubg img{width:142%;max-width:none;margin-left:-21%}
  /* Trust-Zeile + Pünktchen mobil raus; dafür Ansatz-Karte etwas höher */
  .hero .trust{display:none}
  .approach-card{padding:42px 26px}
  .approach-card .ac-steps li{padding:15px 0}
  /* zweite Bild-Instanz unten (Originalposition) – nur Mobil */
  .hero-illu-bottom{
    display:block;position:absolute;left:0;right:0;bottom:0;z-index:0;pointer-events:none;opacity:.16;
    -webkit-mask-image:linear-gradient(to top,#000 26%,transparent 86%);
    mask-image:linear-gradient(to top,#000 26%,transparent 86%);
  }
  .hero-illu-bottom img{width:100%;height:auto;display:block}
}
