@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@400;500&family=JetBrains+Mono:wght@400;500&display=swap');

:root{
  --bg:#ffffff; --ink:#0a0a0a; --g1:#5c5c5c; --g2:#9a9a9a; --g3:#e6e6e6;
  --surf:#f4f4f4; --line:rgba(10,10,10,.12); --line-2:rgba(10,10,10,.22);
  --inv-line:rgba(255,255,255,.16);
  --display:"Space Grotesk",sans-serif; --sans:"Inter",-apple-system,sans-serif; --mono:"JetBrains Mono",monospace;
  --e1:cubic-bezier(.22,1,.36,1); --e-pow:cubic-bezier(.16,1,.3,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;background:var(--bg);scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--ink);color:var(--bg)}
.wrap{max-width:1320px;margin:0 auto;padding:0 32px}
@media(max-width:680px){.wrap{padding:0 20px}}
.mono{font-family:var(--mono)}

/* faint column grid */
.grid-lines{position:fixed;inset:0;z-index:0;pointer-events:none;max-width:1320px;margin:0 auto;padding:0 32px;display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.grid-lines span{border-left:1px solid rgba(10,10,10,.04)}
.grid-lines span:last-child{border-right:1px solid rgba(10,10,10,.04)}
@media(max-width:680px){.grid-lines{display:none}}

/* invert cursor */
.cursor{position:fixed;top:0;left:0;width:12px;height:12px;border-radius:50%;background:#fff;mix-blend-mode:difference;z-index:9999;pointer-events:none;transform:translate(-50%,-50%);transition:width .3s var(--e1),height .3s var(--e1)}
.cursor.big{width:74px;height:74px}
@media(max-width:900px),(pointer:coarse){.cursor{display:none}}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:transform .5s var(--e1),background .4s,border-color .4s}
.nav.hide{transform:translateY(-103%)}
.nav.scr{background:rgba(255,255,255,.86);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav.open{background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;border-bottom:0}
.nav-in{height:72px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:20px}
.logo{font-family:var(--display);font-weight:600;font-size:20px;letter-spacing:-.03em;justify-self:start}
.logo sup{font-size:9px;vertical-align:super;font-weight:500;margin-left:1px}
.nav-links{display:flex;gap:32px;justify-self:center;list-style:none}
.nav-links a{font-family:var(--mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--g1);position:relative;transition:color .3s}
.nav-links a::after{content:'';position:absolute;left:0;bottom:-4px;width:100%;height:1px;background:var(--ink);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--e1)}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-right{justify-self:end;display:flex;align-items:center;gap:18px}
.nav-clock{font-family:var(--mono);font-size:12px;color:var(--g2)}
.nav-cta{font-family:var(--mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;padding:10px 18px;border:1px solid var(--ink);border-radius:100px;transition:background .35s,color .35s}
.nav-cta:hover{background:var(--ink);color:var(--bg)}
.burger{display:none;width:30px;height:30px;flex-direction:column;justify-content:center;gap:6px;background:none;border:0;cursor:pointer}
.burger span{display:block;width:24px;height:1.5px;background:var(--ink);transition:.3s}
@media(max-width:1024px){
  .nav-in{grid-template-columns:1fr auto}
  .nav-clock{display:none}
  .nav-cta{display:none}
  .logo{position:relative;z-index:120}
  .burger{display:flex;position:relative;z-index:120}
  /* Vollbild-Overlay */
  .nav-links{position:fixed;inset:0;width:100%;height:100dvh;z-index:110;background:var(--bg);flex-direction:column;align-items:flex-start;justify-content:center;gap:4px;padding:0 32px;overflow-y:auto;transform:translateY(-100%);opacity:0;visibility:hidden;transition:transform .55s var(--e-pow),opacity .35s ease,visibility .55s}
  .nav.open .nav-links{display:flex;transform:none;opacity:1;visibility:visible}
  .nav-links a{font-family:var(--display);font-weight:500;font-size:clamp(38px,10vw,76px);letter-spacing:-.03em;color:var(--ink);padding:8px 0}
  .nav-links a::after{display:none}
  /* Burger -> X */
  .nav.open .burger span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
  .nav.open .burger span:nth-child(2){opacity:0}
  .nav.open .burger span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
  body.menu-open{overflow:hidden}
}
@media(max-width:680px){
  .nav-links{padding:0 20px}
}

/* HERO */
.hero{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:140px 0 70px}
.hero-meta{display:flex;justify-content:space-between;gap:20px;font-family:var(--mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--g1);padding-bottom:30px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.hero-meta .av{display:inline-flex;align-items:center;gap:8px}
.hero-meta .av i{width:7px;height:7px;border-radius:50%;background:var(--ink);animation:blink 2s steps(1) infinite}
@keyframes blink{50%{opacity:.25}}
.hero h1{font-family:var(--display);font-weight:500;font-size:clamp(44px,9.5vw,168px);line-height:.92;letter-spacing:-.04em;margin:48px 0 0}
.hero h1 .l{display:block;overflow:hidden}
.hero h1 .l .i{display:block;transform:translateY(110%);transition:transform 1.05s var(--e-pow)}
.ready .hero h1 .l .i{transform:none}
.hero h1 .l:nth-child(2) .i{transition-delay:.08s}
.hero h1 em{font-style:normal;color:var(--g2)}
.hero-foot{margin-top:54px;display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;opacity:0;transform:translateY(16px);transition:.9s var(--e1) .5s}
.ready .hero-foot{opacity:1;transform:none}
.hero-foot p{max-width:42ch;font-size:18px;color:var(--g1);line-height:1.55}
.btn{display:inline-flex;align-items:center;gap:12px;font-family:var(--mono);font-size:13px;letter-spacing:.04em;text-transform:uppercase;padding:16px 26px;border-radius:100px;background:var(--ink);color:var(--bg);transition:transform .3s,opacity .3s}
.btn .x{transition:transform .4s var(--e1)}
.btn:hover .x{transform:translate(3px,-3px)}
.btn-ghost{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:13px;letter-spacing:.04em;text-transform:uppercase;position:relative}
.btn-ghost::after{content:'';position:absolute;left:0;bottom:-4px;width:100%;height:1px;background:var(--ink);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--e1)}
.btn-ghost:hover::after{transform:scaleX(1)}
.scrollcue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--g2);display:flex;flex-direction:column;align-items:center;gap:8px}
.scrollcue .ln{width:1px;height:30px;background:var(--line-2);overflow:hidden;position:relative}
.scrollcue .ln::after{content:'';position:absolute;top:-30px;left:0;width:1px;height:30px;background:var(--ink);animation:run 1.8s var(--e1) infinite}
@keyframes run{0%{top:-30px}60%,100%{top:30px}}
@media(max-width:680px){.scrollcue{display:none}}

/* section heading */
.sec{position:relative;z-index:1;padding:130px 0}
.sec-head{display:flex;justify-content:space-between;align-items:baseline;gap:20px;padding-bottom:34px;border-bottom:1px solid var(--ink);margin-bottom:0}
.sec-head .t{font-family:var(--display);font-weight:500;font-size:clamp(26px,3vw,40px);letter-spacing:-.03em}
.sec-head .n{font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:var(--g1)}

/* INDEX LIST (services) — hover invert */
.idx-row{position:relative;display:grid;grid-template-columns:80px 1fr 1.1fr 50px;align-items:center;gap:24px;padding:30px 22px;border-bottom:1px solid var(--line);overflow:hidden;cursor:pointer;color:var(--ink);transition:color .45s var(--e1)}
.idx-row::before{content:'';position:absolute;inset:0;background:var(--ink);transform:scaleY(0);transform-origin:bottom;transition:transform .5s var(--e-pow);z-index:-1}
.idx-row:hover::before{transform:scaleY(1)}
.idx-row:hover{color:var(--bg)}
.idx-row .num{font-family:var(--mono);font-size:13px;color:var(--g1);transition:color .45s}
.idx-row:hover .num{color:var(--g2)}
.idx-row .h{font-family:var(--display);font-weight:500;font-size:clamp(24px,3.2vw,42px);letter-spacing:-.03em;transition:transform .5s var(--e1)}
.idx-row:hover .h{transform:translateX(12px)}
.idx-row .d{font-size:15px;color:var(--g1);transition:color .45s}
.idx-row:hover .d{color:var(--g3)}
.idx-row .ar{justify-self:end;font-size:20px;transform:translateX(-6px);opacity:0;transition:.5s var(--e1)}
.idx-row:hover .ar{opacity:1;transform:translateX(0)}
@media(max-width:760px){.idx-row{grid-template-columns:44px 1fr;gap:12px;padding:22px 0}.idx-row .d,.idx-row .ar{display:none}}

/* WORK grid */
.work-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:6px}
.work-cell{position:relative;aspect-ratio:16/11;overflow:hidden;background:var(--surf);display:block}
.work-cell .ph{position:absolute;inset:0;background:linear-gradient(135deg,#ececec,#d6d6d6);transition:transform .8s var(--e1),filter .6s;filter:grayscale(1)}
.work-cell:hover .ph{transform:scale(1.06)}
.work-cell .gl{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--display);font-weight:600;font-size:64px;color:rgba(10,10,10,.07)}
.work-cell .cap{position:absolute;left:0;right:0;bottom:0;padding:22px 24px;display:flex;justify-content:space-between;align-items:flex-end;gap:14px;background:linear-gradient(transparent,rgba(255,255,255,.9));}
.work-cell .cap h3{font-family:var(--display);font-weight:500;font-size:22px;letter-spacing:-.02em}
.work-cell .cap .m{font-family:var(--mono);font-size:11px;color:var(--g1);text-transform:uppercase}
@media(max-width:760px){.work-grid{grid-template-columns:1fr}}

/* INVERT section (manifesto / cta) */
.invert{position:relative;z-index:1;background:var(--ink);color:var(--bg)}
.invert ::selection{background:var(--bg);color:var(--ink)}
.manifesto{padding:160px 0}
.manifesto .lab{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--g2);margin-bottom:40px}
.manifesto p{font-family:var(--display);font-weight:400;font-size:clamp(26px,4vw,58px);line-height:1.16;letter-spacing:-.03em;max-width:20ch}
.manifesto em{font-style:normal;color:var(--g2)}

/* STATS */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:0}
.stat{background:var(--bg);padding:40px 28px}
.stat .n{font-family:var(--display);font-weight:500;font-size:clamp(40px,5vw,72px);letter-spacing:-.03em;line-height:1}
.stat .l{font-family:var(--mono);font-size:12px;text-transform:uppercase;color:var(--g1);margin-top:14px}
@media(max-width:760px){.stats{grid-template-columns:1fr 1fr}}

/* MARQUEE */
.marq{position:relative;z-index:1;padding:40px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;white-space:nowrap}
.marq-tr{display:inline-flex;align-items:center;animation:marq 30s linear infinite}
.marq-tr span{font-family:var(--display);font-weight:500;font-size:clamp(30px,5vw,64px);letter-spacing:-.03em;padding:0 30px}
.marq-tr i{width:10px;height:10px;border-radius:50%;background:var(--ink);display:inline-block}
@keyframes marq{to{transform:translateX(-50%)}}

/* CTA big */
.cta{padding:150px 0;text-align:center}
.cta h2{font-family:var(--display);font-weight:500;font-size:clamp(40px,8vw,124px);line-height:.95;letter-spacing:-.04em}
.cta .sub{color:var(--g2);margin:26px auto 44px;max-width:44ch;font-size:18px}
.cta .btn{background:var(--bg);color:var(--ink)}

/* FOOTER */
.footer{position:relative;z-index:1;background:var(--ink);color:var(--bg);padding:70px 0 40px}
.footer .big{font-family:var(--display);font-weight:600;font-size:clamp(64px,18vw,300px);line-height:.82;letter-spacing:-.05em}
.footer-cols{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:24px;margin-top:60px;padding-top:36px;border-top:1px solid var(--inv-line)}
.footer-cols h4{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--g2);margin-bottom:16px}
.footer-cols a,.footer-cols p{display:block;font-size:14px;color:rgba(255,255,255,.7);line-height:2;transition:color .3s}
.footer-cols a:hover{color:var(--bg)}
.footer-bot{display:flex;justify-content:space-between;gap:20px;margin-top:54px;font-family:var(--mono);font-size:11px;color:var(--g2);text-transform:uppercase;flex-wrap:wrap}
@media(max-width:760px){.footer-cols{grid-template-columns:1fr 1fr;gap:30px 20px}}

/* PAGE HERO (subpages) */
.page-hero{position:relative;z-index:1;padding:170px 0 70px}
.page-hero .ey{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--g1);margin-bottom:28px}
.page-hero h1{font-family:var(--display);font-weight:500;font-size:clamp(44px,9vw,140px);line-height:.92;letter-spacing:-.04em}
.page-hero .sub{margin-top:28px;max-width:52ch;font-size:19px;color:var(--g1);line-height:1.55}

/* prose / detail blocks */
.lead{font-family:var(--display);font-weight:400;font-size:clamp(26px,3.6vw,46px);line-height:1.2;letter-spacing:-.03em;max-width:24ch}
.det{display:grid;grid-template-columns:1fr 1fr;gap:60px;padding:70px 0;border-bottom:1px solid var(--line);align-items:start}
.det .dn{font-family:var(--mono);font-size:12px;color:var(--g1);margin-bottom:18px}
.det h2{font-family:var(--display);font-weight:500;font-size:clamp(28px,4vw,52px);letter-spacing:-.03em;line-height:1}
.det .dd{margin-top:18px;color:var(--g1);font-size:16px;line-height:1.6;max-width:42ch}
.det ul{list-style:none;display:grid;gap:12px}
.det li{display:flex;gap:14px;align-items:baseline;font-size:16px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.det li::before{content:'';width:6px;height:6px;background:var(--ink);flex:none;transform:translateY(-2px)}
@media(max-width:760px){.det{grid-template-columns:1fr;gap:26px;padding:48px 0}}

/* values */
.vals{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.val{background:var(--bg);padding:40px 32px;min-height:230px;display:flex;flex-direction:column}
.val .vn{font-family:var(--display);font-weight:600;font-size:40px}
.val h3{font-size:18px;font-weight:500;margin:auto 0 8px;font-family:var(--display)}
.val p{font-size:15px;color:var(--g1);line-height:1.55}
@media(max-width:760px){.vals{grid-template-columns:1fr}}

/* FORM */
.cgrid{display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:start}
.field{margin-bottom:22px}
.field label{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--g1);margin-bottom:9px}
.field input,.field textarea,.field select{width:100%;background:var(--surf);border:1px solid var(--line);border-radius:10px;padding:14px 16px;font-family:inherit;font-size:16px;color:var(--ink);transition:border-color .3s}
.field textarea{min-height:130px;resize:vertical}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--ink)}
.btn-sub{font-family:var(--mono);font-size:13px;letter-spacing:.04em;text-transform:uppercase;padding:16px 30px;border-radius:100px;background:var(--ink);color:var(--bg);border:0;cursor:pointer;transition:opacity .3s}
.btn-sub:hover{opacity:.82}
.fnote{font-size:13px;color:var(--g2);margin-top:14px}
.irow{padding:18px 0;border-bottom:1px solid var(--line)}
.irow .k{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--g1);margin-bottom:6px}
.irow .v{font-family:var(--display);font-size:22px;letter-spacing:-.02em}
@media(max-width:760px){.cgrid{grid-template-columns:1fr;gap:40px}}

/* legal */
.legal{max-width:760px;margin:0 auto;padding:0 32px 110px;position:relative;z-index:1;font-size:16px;line-height:1.7;color:var(--g1)}
.legal h2{font-family:var(--display);font-weight:500;font-size:24px;color:var(--ink);margin:38px 0 12px}
.legal a{color:var(--ink);border-bottom:1px solid var(--ink)}
.legal address{font-style:normal}

/* reveals */
.js [data-rev]{opacity:0;transform:translateY(30px);transition:opacity 1s var(--e1),transform 1s var(--e1)}
.js [data-rev].in{opacity:1;transform:none}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
  .hero h1 .l .i{transform:none}.hero-foot,[data-rev]{opacity:1!important;transform:none!important}
}

/* CLIENTS */
.clients{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--ink);border-left:1px solid var(--line)}
.client{border-right:1px solid var(--line);border-bottom:1px solid var(--line);min-height:150px;display:flex;align-items:center;justify-content:center;padding:24px;text-align:center;font-family:var(--display);font-weight:500;font-size:21px;letter-spacing:-.02em;color:var(--g2);transition:color .4s,background .4s}
.client:hover{background:var(--ink);color:var(--bg)}
@media(max-width:760px){.clients{grid-template-columns:1fr}}

/* PRELOADER */
body.loading{overflow:hidden;height:100vh}
.loader{position:fixed;inset:0;z-index:9999;background:var(--ink);color:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;transition:transform .85s var(--e-pow)}
.loader.done{transform:translateY(-101%)}
.loader .lw{font-family:var(--display);font-weight:600;font-size:clamp(40px,8vw,92px);letter-spacing:-.04em;opacity:0;transform:translateY(14px);animation:lwin .8s var(--e1) .05s forwards}
.loader .lw sup{font-size:.3em;vertical-align:super}
@keyframes lwin{to{opacity:1;transform:none}}
.loader .lc{position:absolute;bottom:30px;right:34px;font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--g2)}
.loader .lbar{position:absolute;left:0;bottom:0;width:100%;height:2px;background:rgba(255,255,255,.14)}
.loader .lc-bar{display:block;height:100%;width:100%;background:var(--bg);transform:scaleX(0);transform-origin:left}
@media(max-width:680px){.loader .lc{right:20px;bottom:22px}}
@media(prefers-reduced-motion:reduce){.loader .lw{animation:none;opacity:1;transform:none}}

/* Preloader: Tipp-Cursor für die Kontakt-Variante */
.loader .lw{min-height:1.1em;text-align:center}
.loader[data-variant="type"] .lw::after{content:'';display:inline-block;width:.05em;height:.92em;background:var(--bg);margin-left:.04em;vertical-align:-.06em;animation:caret .75s steps(1) infinite}
@keyframes caret{50%{opacity:0}}

/* SLOTS — Verknappung */
.slots-sec{position:relative;z-index:1;padding:130px 0;text-align:center}
.pill{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;padding:10px 18px;border:1px solid var(--ink);border-radius:100px;margin-bottom:32px}
.slots-h{font-family:var(--display);font-weight:500;font-size:clamp(28px,4.6vw,58px);line-height:1.04;letter-spacing:-.03em;max-width:16ch;margin:0 auto 54px}
.slots-h em{font-style:normal;text-decoration:underline;text-underline-offset:7px;text-decoration-thickness:1px}
.slots{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.slot{position:relative;aspect-ratio:3/4;border:1px solid var(--line);border-radius:16px;padding:26px;display:flex;flex-direction:column;overflow:hidden;background:var(--bg);text-align:left}
.slot .sn{position:relative;z-index:1;font-family:var(--display);font-weight:500;font-size:clamp(22px,2.3vw,32px);line-height:1.04;letter-spacing:-.02em;color:var(--g2)}
.slot .tag{position:relative;z-index:1;margin-top:auto;align-self:flex-start;font-family:var(--mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;padding:7px 12px;border:1px solid var(--line-2);border-radius:100px;color:var(--g1)}
.slot.booked::before{content:'';position:absolute;inset:0;z-index:0;background:linear-gradient(to top right,transparent calc(50% - .5px),var(--line-2) calc(50%),transparent calc(50% + .5px))}
.slot.open{background:var(--ink);border-color:var(--ink);color:var(--bg);transition:transform .5s var(--e1)}
.slot.open .sn{color:var(--bg)}
.slot.open .tag{border-color:rgba(255,255,255,.4);color:var(--bg);display:inline-flex;align-items:center;gap:8px}
.slot.open .tag i{width:7px;height:7px;border-radius:50%;background:var(--bg);animation:blink 1.6s steps(1) infinite}
.slot.open:hover{transform:translateY(-6px)}
@media(max-width:900px){.slots{grid-template-columns:1fr 1fr 1fr}}
@media(max-width:560px){.slots{grid-template-columns:1fr 1fr}}

/* SLOTS v2 — Belegungs-Balken (eigenständig) */
.slots-sec{text-align:center}
.occ{display:flex;gap:10px;max-width:720px;margin:10px auto 22px}
.occ span{flex:1;height:12px;border-radius:100px;border:1px solid var(--ink);background:transparent}
.occ span.taken{background:var(--ink)}
.occ-cap{font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--g1);margin-bottom:32px}
.occ-cta{font-size:14px}

/* Kunden als Logo-Wand */
.client{min-height:150px;padding:24px 18px;overflow-wrap:anywhere;word-break:break-word;hyphens:auto}
.client .client-logo{max-width:72%;max-height:48px;width:auto;height:auto;filter:grayscale(1);opacity:.55;transition:opacity .4s,filter .4s}
.client:hover{background:var(--bg);color:var(--g2)}
.client:hover .client-logo{opacity:1;filter:grayscale(0)}

/* Spam-Honeypot (unsichtbar) */
.hp{position:absolute!important;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;opacity:0}

@media(max-width:680px){
  .manifesto,.cta{padding-left:20px;padding-right:20px}
}

.big sup {
  font-size: 0.3em;        /* größer — vorher 0.22 */
  vertical-align: super;
  position: relative;      /* nötig, damit top wirkt */
  top: -0.15em;            /* negativ = nach oben; mehr negativ = höher */
}


