/* ============================================================
   Webforging — style.css
   Style 5 · „Molten Forge Cinema" · token-driven, library-frei (außer Flagship-Stack)
   Lädt nach design-tokens.css. Alle Werte aus Tokens.
   ============================================================ */

/* ===== Fonts (self-hosted, kein CDN) ===== */
@font-face{font-family:"Space Grotesk";src:url("/assets/fonts/display-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap;}
@font-face{font-family:"Space Grotesk";src:url("/assets/fonts/display-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap;}
@font-face{font-family:"Manrope";src:url("/assets/fonts/body-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap;}
@font-face{font-family:"Manrope";src:url("/assets/fonts/body-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap;}
@font-face{font-family:"JetBrains Mono";src:url("/assets/fonts/jetbrainsmono-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap;}

/* ===== Reset ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{min-height:100dvh;background:var(--color-bg);color:var(--color-text);
  font-family:var(--font-body);font-size:var(--text-base);line-height:var(--leading-body);
  font-weight:400;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:clip}
img,svg,video{display:block;max-width:100%}
img,video{height:auto}
a{color:inherit;text-decoration:none}
button,input,textarea,select{font:inherit;color:inherit}
ul,ol{list-style:none}
:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px;border-radius:var(--radius-sm)}

/* ===== Skip-Link ===== */
.skip-link{position:absolute;left:var(--space-4);top:-100px;z-index:var(--z-overlay);
  background:var(--color-primary);color:var(--color-on-primary);padding:var(--space-3) var(--space-4);
  border-radius:var(--radius-md);font-family:var(--font-mono);font-size:var(--text-sm);transition:top var(--dur-fast) var(--ease-out)}
.skip-link:focus{top:var(--space-4)}

/* ===== Atmosphäre: Grain + Vignette (fixe Overlays, Deko) ===== */
.fx-grain,.fx-vignette{position:fixed;inset:0;pointer-events:none;z-index:1}
.fx-grain{opacity:.028;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.fx-vignette{background:radial-gradient(130% 110% at 50% 0%,transparent 62%,rgba(37,50,42,0.06) 100%)}

/* ===== Layout ===== */
.container{width:100%;max-width:var(--container-max);margin-inline:auto;padding-inline:var(--container-gutter)}
.section{position:relative;padding-block:var(--section-padding);z-index:2}
.section--tight{padding-block:var(--space-16)}
main{position:relative;z-index:2}

/* ===== Typografie ===== */
.eyebrow{font-family:var(--font-mono);font-size:calc(var(--text-xs) * 2);text-transform:uppercase;
  letter-spacing:var(--tracking-wide);color:var(--color-accent);display:inline-flex;align-items:center;gap:var(--space-2)}
.eyebrow::before{content:"";width:18px;height:1px;background:var(--color-primary)}
.hero .eyebrow::before{display:none}   /* Hero-Eyebrow ohne Deko-Strich davor */
.hero .eyebrow{white-space:nowrap}     /* Hero-Eyebrow immer in einer Zeile */
.display{font-family:var(--font-display);font-weight:700;line-height:var(--leading-tight);
  letter-spacing:var(--tracking-tight);font-size:var(--text-display)}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:var(--leading-snug);letter-spacing:var(--tracking-tight)}
h2{font-size:var(--text-3xl)}
h3{font-size:var(--text-xl)}
h4{font-size:var(--text-lg)}
p{max-width:65ch}
.lead{font-size:var(--text-lg);color:var(--color-text-muted);max-width:60ch}
.heat{color:var(--color-accent)}
/* Hero-Akzentwort „verkaufen": erscheint weiß, wird nach dem Reveal per Pinselstrich (l→r) gelb (JS).
   No-JS / reduced-motion: direkt im Endzustand (gelb). */
.paint{color:var(--color-text)}
html.no-js .paint{color:var(--color-accent)}
@media (prefers-reduced-motion:reduce){.paint{color:var(--color-accent)}}
.muted{color:var(--color-text-muted)}
.section-head{max-width:760px;margin-bottom:var(--space-12);display:flex;flex-direction:column;gap:var(--space-4)}
/* Typewriter-Überschrift: "Webforging" (Deep-Green) + Wechselteil (orange), volle Größe, gleiche Zeile.
   Unsichtbarer Platzhalter (längster Satz) reserviert die Höhe → .lead bleibt fix, kein Springen.
   Der komplette Satz ist immer im Layout (Rest transparent) → Wörter springen beim Tippen nicht zwischen den Zeilen. */
.section-head--wide{max-width:none}
.type-h{position:relative}   /* erbt die normale H2-Größe (= #plat-h, --text-3xl); Umbruch erlaubt */
.type-h__sizer{visibility:hidden}
.type-h__live{position:absolute;inset:0}
.type-h__static{color:var(--color-text)}
.type-h__typed{color:var(--color-primary)}
.type-h__rest{color:transparent}
.type-h__caret{display:inline;border-left:.08em solid var(--color-primary);margin-left:.01em;
  animation:typeCaret 1s steps(1) infinite}
@keyframes typeCaret{0%,49%{opacity:1}50%,100%{opacity:0}}
@media (prefers-reduced-motion:reduce){.type-h__caret{animation:none}}

/* Adjazenz Text → CTA (Pflicht CLAUDE.md) — Nav-CTA ausgenommen (folgt auf <ul> im Header) */
:is(p,.lead,h2,h3,h4,ul,ol,dl,blockquote)+:is(.btn,.btn-row):not(.nav-cta){margin-top:var(--space-6)}

/* ===== Icons ===== */
.icon{width:1.25em;height:1.25em;fill:none;stroke:currentColor;stroke-width:1.75;
  stroke-linecap:round;stroke-linejoin:round;display:inline-block;vertical-align:middle;flex:none}
.icon-filled{fill:currentColor;stroke:none}
.icon-sm{width:1em;height:1em}
.icon-lg{width:1.75em;height:1.75em}
.icon-xl{width:2.5em;height:2.5em}

/* ===== Buttons ===== */
.btn-row{display:flex;flex-wrap:wrap;gap:var(--space-4)}
.btn{--btn-bg:var(--color-primary);--btn-fg:var(--color-on-primary);
  display:inline-flex;align-items:center;gap:var(--space-2);justify-content:center;
  min-height:48px;padding:var(--space-3) var(--space-6);
  font-family:var(--font-mono);font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.08em;
  background:var(--btn-bg);color:var(--btn-fg);border:1px solid var(--btn-bg);border-radius:var(--radius-md);
  cursor:pointer;will-change:transform;transition:transform var(--dur-fast) var(--ease-forge),box-shadow var(--dur-base) var(--ease-out),background var(--dur-fast) var(--ease-out)}
.btn:hover{box-shadow:var(--glow-molten);transform:translateY(-2px)}
.btn--ghost{--btn-bg:transparent;--btn-fg:var(--color-text);border-color:var(--color-line-strong)}
.btn--ghost:hover{--btn-fg:var(--color-text);border-color:var(--color-steel);box-shadow:none;background:rgba(110,143,170,.08)}
.btn .icon{width:1.1em;height:1.1em;transition:transform var(--dur-base) var(--ease-out)}
.btn:hover .icon{transform:translateX(3px)}

/* ===== Panels / Molten-Glass ===== */
.panel{background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-lg);
  padding:var(--space-8);position:relative;overflow:hidden}
.panel--glass{background:linear-gradient(180deg,var(--color-surface-2),var(--color-surface))}
.panel--ideal{background:var(--color-green-deep);border-color:transparent}
.panel--ideal .svc-split__label{color:var(--color-primary)}
.panel--ideal .list-check li{color:rgba(243,240,231,.92)}
.panel--ideal .list-check .icon{color:var(--color-primary)}
.panel__num{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-primary);letter-spacing:.1em}

/* ===== Header / Nav ===== */
.site-header{position:fixed;inset:0 0 auto 0;z-index:var(--z-nav);
  display:flex;align-items:center;justify-content:space-between;gap:var(--space-6);
  padding:var(--space-4) var(--container-gutter);
  background:linear-gradient(180deg,rgba(243,240,231,.72),rgba(243,240,231,0));
  transition:background var(--dur-base) var(--ease-out),border-color var(--dur-base) var(--ease-out),border-radius var(--dur-base) var(--ease-out);
  border-bottom:1px solid transparent}
.site-header.is-scrolled{background:rgba(243,240,231,.9);border-bottom-color:var(--color-line);backdrop-filter:blur(8px);
  border-bottom-left-radius:16px;border-bottom-right-radius:16px}
.scroll-progress{position:fixed;top:0;left:0;height:2px;width:100%;transform:scaleX(0);transform-origin:0 50%;background:var(--grad-molten);z-index:var(--z-overlay);will-change:transform}
@media (prefers-reduced-motion:reduce){.scroll-progress{display:none}}
.brand{display:inline-flex;align-items:center;gap:var(--space-3);font-family:var(--font-display);
  font-weight:700;font-size:var(--text-lg);letter-spacing:-.01em;z-index:2}
.brand__mark{width:30px;height:30px;flex:none}
/* Logo-Lockup (Amboss + Wortmarke) als CSS-Maske → erbt die Schriftfarbe, gestochen scharf */
.brand__logo{display:block;height:30px;width:132px;flex:none;background-color:var(--color-text);
  -webkit-mask:url(/assets/img/logo-full.png) left center/contain no-repeat;
  mask:url(/assets/img/logo-full.png) left center/contain no-repeat}
.site-header .brand__logo{height:38px;width:167px}   /* Header-Logo ~25% größer */
@media (max-width:768px){.brand__logo{height:26px;width:114px}.site-header .brand__logo{height:33px;width:145px}}
.nav{display:flex;align-items:center;gap:var(--space-6)}
.nav-links{display:flex;align-items:center;gap:var(--space-6)}
.nav-links a{font-size:var(--text-sm);color:var(--color-text-muted);position:relative;padding-block:var(--space-2);
  transition:color var(--dur-fast) var(--ease-out)}
.nav-links a:hover,.nav-links a.active{color:var(--color-text)}
.nav-links a.active::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:2px;background:var(--color-primary)}
/* E-Commerce Dropdown (Desktop) */
.nav-group{position:relative}
.nav-group__panel{position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(8px);
  min-width:460px;display:grid;grid-template-columns:1fr 1fr;gap:var(--space-1);padding:var(--space-4);
  background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);
  opacity:0;pointer-events:none;transition:opacity var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out);z-index:var(--z-nav)}
.nav-group__panel::before{content:"";position:absolute;top:-16px;left:0;right:0;height:16px}
.nav-group:hover .nav-group__panel,.nav-group:focus-within .nav-group__panel{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.nav-group__panel a{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);
  color:var(--color-text-muted)}
.nav-group__panel a:hover{background:var(--color-surface-2);color:var(--color-text)}
.nav-group__panel img{width:20px;height:20px}
.nav-group__panel .icon{width:20px;height:20px;color:var(--color-text-muted)}
.nav-group__panel .full{grid-column:1 / -1;border-top:1px solid var(--color-line);margin-top:var(--space-2);padding-top:var(--space-4);color:var(--color-primary)}
.nav-cta{display:inline-flex}
.hamburger{display:none;width:48px;height:48px;align-items:center;justify-content:center;
  background:transparent;border:1px solid var(--color-line-strong);border-radius:var(--radius-md);cursor:pointer;z-index:2}
.hamburger .icon{width:22px;height:22px}

/* Mobile-Menü Overlay (DNA: Full-Screen, große Typo, Mono-Index) */
.mobile-menu{position:fixed;inset:0;z-index:calc(var(--z-nav) - 1);display:flex;flex-direction:column;justify-content:flex-start;overflow-y:auto;
  padding:calc(var(--space-16) + var(--space-8)) var(--container-gutter) var(--space-12);
  background:var(--color-bg);background-image:var(--grad-ember-veil);
  clip-path:inset(0 0 100% 0);visibility:hidden;transition:clip-path var(--dur-slow) var(--ease-emphasized),visibility var(--dur-slow)}
.mobile-menu.is-open{clip-path:inset(0 0 0 0);visibility:visible}
.mobile-menu ol{display:flex;flex-direction:column;gap:var(--space-4)}
.mobile-menu li{opacity:0;transform:translateY(20px);transition:opacity var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out)}
.mobile-menu.is-open li{opacity:1;transform:none}
.mobile-menu.is-open li:nth-child(1){transition-delay:.08s}
.mobile-menu.is-open li:nth-child(2){transition-delay:.13s}
.mobile-menu.is-open li:nth-child(3){transition-delay:.18s}
.mobile-menu.is-open li:nth-child(4){transition-delay:.23s}
.mobile-menu.is-open li:nth-child(5){transition-delay:.28s}
.mobile-menu.is-open li:nth-child(6){transition-delay:.33s}
.mobile-menu ol a{display:flex;align-items:baseline;gap:var(--space-4);font-family:var(--font-display);font-weight:600;
  font-size:clamp(2rem,8vw,3rem);color:var(--color-text);letter-spacing:var(--tracking-tight)}
.mobile-menu ol a .ix{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-primary);font-weight:400}
.mobile-menu ol a:hover{color:var(--color-accent)}
.mobile-menu .mm-cta{margin-top:var(--space-12);justify-content:center;font-size:var(--text-base)}
/* Trust-Footer im Menue: Kontakt, Social, Rechtsform */
.mm-foot{margin-top:var(--space-12);padding-top:var(--space-8);border-top:1px solid var(--color-line)}
.mm-foot__contact{display:flex;flex-direction:column;gap:var(--space-3)}
.mm-foot__link,.mm-foot__meta{display:inline-flex;align-items:center;gap:var(--space-3);font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-text-muted)}
.mm-foot__link{color:var(--color-text);font-weight:500}
.mm-foot__link .icon,.mm-foot__meta .icon{width:18px;height:18px;color:var(--color-primary);flex:none}
.mm-foot__social{display:flex;gap:var(--space-3);margin-top:var(--space-6)}
.mm-foot__social a{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border:1px solid var(--color-line-strong);border-radius:var(--radius-md);color:var(--color-text-muted);transition:color var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out)}
.mm-foot__social a:hover{color:var(--color-on-primary);background:var(--color-primary);border-color:var(--color-primary)}
.mm-foot__social .icon{width:20px;height:20px}
.mm-foot__legal{margin-top:var(--space-6);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-muted);letter-spacing:.04em}
/* Mobile-Menü: E-Commerce-Untergruppe — klar als aufklappbar erkennbar */
.mm-grouptoggle{display:flex;align-items:baseline;gap:var(--space-4);width:100%;padding:0;background:none;border:none;cursor:pointer;text-align:left;
  font-family:var(--font-display);font-weight:600;font-size:clamp(2rem,8vw,3rem);color:var(--color-text);letter-spacing:var(--tracking-tight)}
.mm-grouptoggle .ix{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-primary);font-weight:400}
.mm-grouptoggle .mm-label{flex:1}
.mm-chevbtn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;flex:none;align-self:center;
  border:1px solid var(--color-line-strong);border-radius:50%;background:var(--color-surface);color:var(--color-primary);
  transition:transform var(--dur-base) var(--ease-out),background var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out)}
.mm-chevbtn .icon{width:20px;height:20px}
.mm-grouptoggle:hover .mm-chevbtn{border-color:var(--color-primary)}
.mm-group.is-open .mm-chevbtn{transform:rotate(180deg);background:var(--color-primary);border-color:var(--color-primary);color:var(--color-on-primary)}
.mm-hint{display:block;margin-top:var(--space-3);padding-left:calc(var(--text-sm) + var(--space-4));font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-accent);letter-spacing:.04em}
.mm-group.is-open .mm-hint{display:none}
.mm-sub{display:grid;grid-template-rows:0fr;transition:grid-template-rows var(--dur-base) var(--ease-emphasized)}
.mm-group.is-open .mm-sub{grid-template-rows:1fr}
.mm-sub__inner{overflow:hidden;display:flex;flex-direction:column;gap:var(--space-4);padding-left:calc(var(--text-sm) + var(--space-4))}
.mm-group.is-open .mm-sub__inner{padding-top:var(--space-4)}
.mobile-menu .mm-sub a{display:inline-flex;align-items:center;gap:var(--space-3);font-family:var(--font-body);font-weight:500;font-size:var(--text-lg);color:var(--color-text-muted)}
.mobile-menu .mm-sub a img{width:22px;height:22px;flex:none}
.mm-sub__dot{width:22px;height:22px;flex:none;display:inline-flex;align-items:center;justify-content:center}
.mm-sub__dot::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--color-primary)}
.mobile-menu .mm-sub a:hover{color:var(--color-accent)}
@media (prefers-reduced-motion:reduce){.mm-sub{transition:none}}
body.menu-open{overflow:hidden}

/* ===== Custom Cursor + HUD ===== */
.cursor{position:fixed;top:0;left:0;z-index:var(--z-cursor);pointer-events:none;
  transform:translate3d(var(--mx,-100px),var(--my,-100px),0);will-change:transform}
.cursor__ring{position:absolute;width:30px;height:30px;margin:-15px;border:1px solid var(--color-green);border-radius:var(--radius-sm);box-shadow:var(--glow-green);
  transition:width var(--dur-fast) var(--ease-out),height var(--dur-fast) var(--ease-out),margin var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out),transform var(--dur-base) var(--ease-out)}
.cursor__dot{position:absolute;width:5px;height:5px;margin:-2.5px;border-radius:50%;background:var(--color-green);
  transition:width var(--dur-fast) var(--ease-out),height var(--dur-fast) var(--ease-out),margin var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out)}
.cursor.is-hot .cursor__ring{width:44px;height:44px;margin:-22px;border-color:var(--color-accent);transform:rotate(45deg)}
.cursor.is-hot .cursor__dot{width:8px;height:8px;margin:-4px;background:var(--color-accent)}
html.cursor-active,html.cursor-active *{cursor:none}
.cursor.is-text .cursor__ring{width:2px;height:26px;margin:-13px -1px;border:none;background:var(--color-green);border-radius:1px;box-shadow:none;transform:none}
.cursor.is-text .cursor__dot{opacity:0}
.spark{position:fixed;top:0;left:0;width:3px;height:3px;border-radius:50%;background:var(--color-accent);
  z-index:var(--z-cursor);pointer-events:none;box-shadow:0 0 6px var(--color-primary)}
@media (hover:none),(pointer:coarse){.cursor{display:none}}

/* ===== Hero ===== */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;padding-top:clamp(var(--space-24),12vh,var(--space-32));padding-bottom:var(--space-8);overflow:hidden}
@media (min-width:769px){.hero{min-height:max(100svh, 560px)}}
/* Seitenweiter, fixierter Blueprint-Hintergrund (Homepage) — bleibt beim Scrollen statisch */
.page-bg{position:fixed;inset:0;z-index:-1;pointer-events:none}
.hero__poster{position:absolute;inset:0;width:100%;height:100%;
  background:
    radial-gradient(50% 48% at 72% 58%, rgba(255,106,0,.16), transparent 70%),
    radial-gradient(55% 60% at 14% 18%, rgba(76,107,60,.12), transparent 70%),
    var(--color-bg)}
.hero__canvas{position:absolute;inset:0;width:100%;height:100%;opacity:0;transition:opacity var(--dur-cinematic) var(--ease-out)}
.hero__canvas.is-ready{opacity:1}
.hero__scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(243,240,231,.86) 0%,rgba(243,240,231,.45) 42%,transparent 75%)}
.hero .container{position:relative;z-index:2;margin-block:auto;width:100%}
/* Homepage: Sections ohne eigenen Hintergrund → der fixierte Blueprint scheint durch */
.home .final{background:transparent}
.home .final::before{display:none}
.home .site-footer{background:transparent}
.hero__grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.6fr);gap:var(--space-12);align-items:center}
.hero__title{font-family:var(--font-display);font-weight:700;font-size:min(var(--text-hero),9.5vh);line-height:var(--leading-tight);
  letter-spacing:var(--tracking-tight);margin-top:var(--space-6);max-width:14ch}
/* Hero-H1: cursor-reaktive Buchstaben (Heben + langsames Einfaerben nahe dem Cursor) */
.hero__word{display:inline-block}
.hero__char{display:inline-block;will-change:transform;transition:color .6s var(--ease-out),transform .18s var(--ease-out)}
.hero__char--accent{color:var(--color-accent)}
.hero__char.is-lit{color:var(--color-accent)}
.hero__char--accent.is-lit{color:var(--heat-amber)}
.hero__sub{margin-top:var(--space-6);font-size:var(--text-lg);color:var(--color-text);max-width:46ch}
.hero__cta{margin-top:var(--space-8)}
.hero__proof{margin-top:var(--space-8);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-muted);
  display:flex;flex-wrap:wrap;gap:var(--space-4);text-transform:uppercase;letter-spacing:.06em}
.hero__proof b{color:var(--color-accent);font-weight:400}
.hero__hud{align-self:end;font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-steel);
  display:flex;flex-direction:column;gap:var(--space-2);border-left:1px solid var(--color-line);padding-left:var(--space-4)}
.hero__hud span:first-child{color:var(--color-accent)}
.scroll-hint{align-self:center;margin-top:var(--space-8);z-index:2;
  font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--color-text-muted);
  display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}
.scroll-hint .icon{animation:bob 1.8s var(--ease-out) infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

/* ===== Leistungs-Duo (versetzter Split) ===== */
.duo{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6);perspective:1100px}
.duo__card{display:flex;flex-direction:column;gap:var(--space-4);min-height:340px;justify-content:flex-end;
  border:1px solid transparent;border-radius:var(--radius-lg);padding:var(--space-12);position:relative;
  background:var(--color-green-deep);color:#F3F0E7;transform-style:preserve-3d;will-change:transform;
  transition:transform .45s var(--ease-out),box-shadow var(--dur-base) var(--ease-out),border-color var(--dur-base) var(--ease-out)}
.duo__card.is-tilting{transition:box-shadow var(--dur-base) var(--ease-out),border-color var(--dur-base) var(--ease-out)}
.duo__card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-lg)}
.duo__icon{width:52px;height:52px;color:var(--color-primary);transform:translateZ(45px);transition:transform var(--dur-base) var(--ease-out)}
.duo__card:hover .duo__icon{transform:translateZ(55px) scale(1.08)}
.duo__card h3{color:#F3F0E7;transform:translateZ(28px)}
.duo__card p{color:rgba(243,240,231,.74);transform:translateZ(16px)}
.duo__card .btn--ghost{--btn-fg:#F3F0E7;border-color:rgba(243,240,231,.28);transform:translateZ(34px)}
.duo__card .btn--ghost:hover{--btn-fg:var(--color-on-primary);background:var(--color-primary);border-color:var(--color-primary);transform:translateZ(40px)}
/* Hover: Hintergrund-Symbole fahren herein + Beschreibung wechselt zu Capability-Chips */
.duo__bg{position:absolute;inset:0;overflow:hidden;border-radius:inherit;pointer-events:none}
.duo__sym{position:absolute;color:#F3F0E7;opacity:0;transition:opacity .55s var(--ease-out),transform .7s var(--ease-out)}
.duo__sym--1{width:108px;height:108px;top:-12px;right:-16px;transform:translate(14px,-14px) rotate(-12deg) scale(.82)}
.duo__sym--2{width:60px;height:60px;top:46%;right:20px;transform:translate(0,22px) rotate(10deg) scale(.78)}
.duo__card:hover .duo__sym--1{opacity:.15;transform:translate(0,0) rotate(-7deg) scale(1)}
.duo__card:hover .duo__sym--2{opacity:.11;transform:translate(0,0) rotate(7deg) scale(1);transition-delay:.1s}
.duo__textswap{display:grid;transform-style:preserve-3d}
.duo__textswap>*{grid-area:1/1;align-self:start;margin:0}
.duo__textswap .muted{transition:opacity var(--dur-base) var(--ease-out)}
.duo__extra{display:flex;flex-wrap:wrap;gap:var(--space-2);list-style:none;padding:0;opacity:0;transform:translateY(10px) translateZ(16px);transition:opacity var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out);pointer-events:none}
.duo__extra li{font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;line-height:1;color:rgba(243,240,231,.92);background:rgba(243,240,231,.09);border:1px solid rgba(243,240,231,.2);padding:7px 11px;border-radius:var(--radius-md)}
.duo__card:hover .duo__textswap .muted{opacity:0}
.duo__card:hover .duo__extra{opacity:1;transform:translateY(0) translateZ(16px);transition-delay:.05s}
/* E-Commerce-Card: vier Plattform-CTAs mit Logo blenden bei Hover/Fokus ein (statt Beschreibung) */
.duo__plats{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2);opacity:0;transform:translateY(10px) translateZ(16px);pointer-events:none;transition:opacity var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out)}
.duo__card--ecom:focus-within .duo__textswap .muted{opacity:0}
.duo__card--ecom:hover .duo__plats,.duo__card--ecom:focus-within .duo__plats{opacity:1;transform:translateY(0) translateZ(16px);pointer-events:auto;transition-delay:.04s}
.duo__plat{display:flex;align-items:center;gap:var(--space-2);min-width:0;min-height:42px;font-family:var(--font-mono);font-size:0.6875rem;line-height:1.15;color:#F3F0E7;text-decoration:none;background:rgba(243,240,231,.06);border:1px solid rgba(243,240,231,.2);border-radius:var(--radius-md);padding:6px 8px;transition:border-color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out)}
.duo__plat:hover{border-color:var(--color-primary);background:rgba(243,240,231,.12);transform:translateY(-2px)}
.duo__platlogo{display:inline-flex;align-items:center;justify-content:center;flex:none;width:24px;height:24px;border-radius:var(--radius-sm);background:#F3F0E7;padding:4px}
.duo__platlogo img{width:100%;height:100%;object-fit:contain;display:block}
@media(prefers-reduced-motion:reduce){.duo__sym,.duo__extra,.duo__plats,.duo__plat,.duo__textswap .muted{transition:none}.duo__sym{transform:none}}
@media(max-width:980px){.duo{grid-template-columns:1fr;gap:var(--space-8);perspective:none}.duo__card{transform:none!important}
  .duo__card--ecom .duo__textswap{display:block}.duo__card--ecom .duo__textswap .muted{opacity:1;margin-bottom:var(--space-4)}
  .duo__card--ecom .duo__plats{opacity:1;transform:none;pointer-events:auto}}

/* ===== Plattform-Wand ===== */
.logo-wall{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-3)}
@media(min-width:880px){.logo-wall{grid-template-columns:repeat(5,1fr)}}
.logo-tile{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);
  min-height:140px;padding:var(--space-6);background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-md);
  color:var(--color-text-muted);text-align:center;transition:color var(--dur-base) var(--ease-out),border-color var(--dur-base) var(--ease-out),background var(--dur-base) var(--ease-out)}
.logo-tile img{width:42px;height:42px;transition:transform var(--dur-base) var(--ease-out)}
.logo-tile span{font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:.04em}
.logo-tile:hover{color:var(--color-text);border-color:var(--color-primary);background:var(--color-surface-2);box-shadow:var(--glow-molten)}
.logo-tile:hover img{transform:scale(1.06)}
.logo-tile--text span{font-size:var(--text-lg);font-family:var(--font-display);color:var(--color-text)}
.logo-tile--more{border-style:dashed}
.logo-tile--more span{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-text-muted);text-align:center;line-height:1.3}

/* ===== Positionierung (Pain→Antwort, asymmetrisch) ===== */
.stance{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6)}
.stance__card{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-8);background:var(--color-green-deep);border:1px solid transparent;border-radius:var(--radius-lg);transition:border-color var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out)}
.stance__card:hover{border-color:var(--color-primary);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.stance__badge{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-md);background:rgba(243,240,231,.08);border:1px solid rgba(243,240,231,.16)}
.stance__badge .icon{width:24px;height:24px;color:var(--color-primary)}
.stance__q{font-family:var(--font-display);font-size:var(--text-xl);color:#F3F0E7}
.stance__a{color:rgba(243,240,231,.72);line-height:var(--leading-body)}
.stance__a b{color:#F3F0E7;font-weight:600}
@media(max-width:860px){.stance{grid-template-columns:1fr}}

/* ===== Prozess / Migrations-Timeline (sticky) ===== */
.steps{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-16)}
.steps__sticky{position:sticky;top:0;height:fit-content;align-self:start;padding-top:var(--space-24)}
.steps__list{display:flex;flex-direction:column;gap:var(--space-4)}
.step{border:1px solid var(--color-line);border-radius:var(--radius-lg);padding:var(--space-8);background:var(--color-surface);
  display:flex;flex-direction:column;gap:var(--space-3)}
.step__n{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-primary);letter-spacing:.1em}
.step h3{font-size:var(--text-lg)}

/* ===== Portfolio (horizontale Strecke) ===== */
.pf{position:relative}
.pf__viewport{overflow-x:auto;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;scrollbar-width:none;overscroll-behavior-x:contain}
.pf__viewport::-webkit-scrollbar{display:none}
.pf__track{display:flex;gap:var(--space-6);padding-block:var(--space-4);padding-inline-end:0}
/* Abstand nach der letzten Card: echter Flex-Spacer (End-Padding/Margin zaehlen nicht zur Scroll-Breite);
   negativer Start-Margin neutralisiert den gap, damit der Abstand exakt dem linken Gutter entspricht. */
.pf__track::after{content:"";flex:0 0 var(--container-gutter);margin-inline-start:calc(-1 * var(--space-6))}
.pf__card{flex:0 0 min(86vw,460px);scroll-snap-align:center;display:flex;flex-direction:column;background:var(--color-surface);border:1px solid var(--color-line);
  border-radius:var(--radius-lg);overflow:hidden;text-decoration:none;color:inherit;
  transition:border-color var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-emphasized),box-shadow var(--dur-base) var(--ease-emphasized)}
.pf__card:hover{border-color:var(--color-line-strong);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.pf__card .pf__body{flex:1}
.pf__cta{margin-top:auto;display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-accent)}
.pf__cta .icon{width:16px;height:16px;transition:transform var(--dur-fast) var(--ease-out)}
.pf__card:hover .pf__cta .icon{transform:translateX(4px)}
.pf__media{aspect-ratio:4/3;width:100%;position:relative;overflow:hidden;background:var(--color-surface-2)}
.pf__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.pf__media .tag{position:absolute;top:var(--space-4);left:var(--space-4);font-family:var(--font-mono);font-size:var(--text-xs);
  text-transform:uppercase;letter-spacing:.08em;color:#F3F0E7;background:rgba(37,50,42,.82);padding:4px 8px;border-radius:var(--radius-sm)}
.pf__media .ph{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-muted)}
.pf__body{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-2)}
.pf__body .meta{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-steel);text-transform:uppercase;letter-spacing:.06em}

/* ===== FAQ (sticky Index + offene Q&A) ===== */
.faq{display:grid;grid-template-columns:minmax(0,.5fr) minmax(0,1fr);gap:var(--space-16)}
.faq__index{position:sticky;top:96px;align-self:start;display:flex;flex-direction:column;gap:var(--space-3)}
.faq__index .eyebrow{margin-bottom:var(--space-2)}
.faq__index a{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-text-muted);transition:color var(--dur-fast)}
.faq__index a:hover{color:var(--color-accent)}
.faq__index--static a{pointer-events:none;cursor:default}   /* Kontaktseite: FAQ-Liste nicht anklickbar, kein Sprung-Scroll */
.faq__list{display:flex;flex-direction:column}
.faq__item{padding-block:var(--space-8);border-top:1px solid var(--color-line)}
.faq__item:last-child{border-bottom:1px solid var(--color-line)}
.faq__item h4{font-size:var(--text-lg);margin-bottom:var(--space-3);display:flex;gap:var(--space-3)}
.faq__item h4::before{content:"Q";font-family:var(--font-mono);color:var(--color-primary);font-size:var(--text-base)}
.faq__item p{color:var(--color-text-muted)}
.faq__tabs{display:flex;flex-direction:column;gap:var(--space-1);margin-top:var(--space-2)}
.faq-tab{text-align:left;font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-text-muted);background:none;border:none;border-left:2px solid transparent;padding:var(--space-3) var(--space-4);cursor:pointer;border-radius:0 var(--radius-md) var(--radius-md) 0;transition:color var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out)}
.faq-tab:hover{color:var(--color-text)}
.faq-tab.is-active{color:var(--color-text);border-left-color:var(--color-primary);background:var(--color-surface)}
html:not(.no-js) .faq-group:not(.is-active){display:none}
.faq-group__title{font-family:var(--font-display);font-size:var(--text-2xl);color:var(--color-text);display:flex;align-items:center;gap:var(--space-3);padding-bottom:var(--space-4);border-bottom:2px solid var(--color-primary)}
.faq-group__title .icon{width:26px;height:26px;color:var(--color-primary);flex:none}
.faq-group .faq__item:first-of-type{border-top:0}

/* ===== Final-CTA (randabfallender Molten-Moment) ===== */
.final{position:relative;text-align:center;padding-block:var(--space-32);overflow:hidden;background:var(--color-surface)}
.final::before{content:"";position:absolute;inset:0;background:var(--grad-ember-veil)}
.final::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--grad-molten)}
.final .container{position:relative;display:flex;flex-direction:column;align-items:center;gap:var(--space-6)}
.final h2{font-size:var(--text-display)}

/* ===== Forms ===== */
.form{display:grid;gap:var(--space-6);max-width:640px}
.field{display:flex;flex-direction:column;gap:var(--space-2)}
.field label{font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted)}
.field input,.field textarea,.field select{background:var(--color-surface);border:1px solid var(--color-line-strong);
  border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);min-height:48px;color:var(--color-text);transition:border-color var(--dur-fast)}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--color-primary);outline:none}
.field--check{flex-direction:row;align-items:flex-start;gap:var(--space-3)}
.field--check input{min-height:auto;width:20px;height:20px;margin-top:3px;flex:none}
.field--check label{text-transform:none;letter-spacing:0;font-family:var(--font-body);font-size:var(--text-sm);color:var(--color-text-muted)}
.field--check a{color:var(--color-accent);text-decoration:underline}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.contact-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:var(--space-16);align-items:start}
.contact-ways{display:flex;flex-direction:column;gap:var(--space-6)}
.contact-ways a{display:inline-flex;align-items:center;gap:var(--space-3);color:var(--color-text)}
.contact-ways .icon{color:var(--color-primary)}

/* ===== Generische Section-Bausteine ===== */
.grid-feat{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-6)}
.feat{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-8);border:1px solid var(--color-line);
  border-radius:var(--radius-lg);background:var(--color-surface);transition:border-color var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out)}
.feat:hover{border-color:var(--color-primary);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.feat__badge{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-md);background:var(--color-surface-2);border:1px solid var(--color-line);flex:none}
.feat .icon{color:var(--color-primary);width:24px;height:24px}
.feat h3{font-size:var(--text-lg)}
.feat p{color:var(--color-text-muted);font-size:var(--text-base);line-height:var(--leading-body)}
/* Dark-Akzent-Card: tiefes Oliv als Rhythmus-Brecher im Feature-Grid */
.feat--dark{background:var(--color-green-deep);border-color:transparent;color:#F3F0E7}
.feat--dark h3{color:#F3F0E7}
.feat--dark p{color:rgba(243,240,231,.74)}
.feat--dark .feat__badge{background:rgba(243,240,231,.08);border-color:rgba(243,240,231,.18)}
.feat--dark .icon{color:var(--heat-amber)}
.feat--dark:hover{border-color:transparent;transform:translateY(-4px);box-shadow:var(--glow-green),var(--shadow-md)}
/* Vorteile-Slideshow: einzeilig, full-bleed, horizontal scroll (scroll-snap, library-frei) */
.feat-viewport{overflow-x:auto;overflow-y:hidden;touch-action:pan-x;scroll-snap-type:x proximity;scroll-padding-left:max(var(--container-gutter),calc((100% - var(--container-max)) / 2 + var(--container-gutter)));scrollbar-width:none;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;padding-block:var(--space-2) var(--space-4)}
.feat-viewport::-webkit-scrollbar{display:none}
.feat-row{display:flex;gap:var(--space-6);padding-left:max(var(--container-gutter),calc((100% - var(--container-max)) / 2 + var(--container-gutter)));padding-right:0}
/* Trailing-Spacer: echtes Flex-Element (padding-right wird in Flex-Scroll-Containern ignoriert) → letzte Kachel klebt nicht am Rand */
.feat-row::after{content:"";flex:none;width:max(var(--container-gutter),calc((100vw - var(--container-max)) / 2 + var(--container-gutter) - var(--space-6)))}
.profiles:not(.profiles--grid)::after{content:"";flex:none;width:max(var(--container-gutter),calc((100vw - var(--container-max)) / 2 + var(--container-gutter) - var(--space-8)))}
.feat-row>.feat{flex:0 0 clamp(258px,26vw,300px);scroll-snap-align:start}
/* Leistungen: Bullets + ruhiges Bild, weich in die Seite eingebettet */
.leistungen-split{display:grid;grid-template-columns:1.1fr .9fr;gap:var(--space-16);align-items:center}
.leistungen-split__media{display:flex;align-items:center;justify-content:center}
.leistungen-split__media img{display:block;width:100%;max-width:440px;height:auto}
@media(max-width:860px){.leistungen-split{grid-template-columns:1fr;gap:var(--space-8)}.leistungen-split__media img{max-width:340px;margin-inline:auto}}
/* Migrations-CTA (Deep-Green-Akzentblock, sticht hervor) */
.mig-cta{display:grid;grid-template-columns:1.15fr .85fr;gap:var(--space-12);align-items:center;background:var(--color-green-deep);color:#F3F0E7;border-radius:var(--radius-lg);padding:clamp(var(--space-8),5vw,var(--space-16));overflow:hidden}
.mig-cta__body{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-4)}
.mig-cta .eyebrow{color:var(--color-primary)}
.mig-cta h2{color:#F3F0E7;font-size:var(--text-2xl);line-height:var(--leading-snug)}
.mig-cta__lead{color:rgba(243,240,231,.78);font-size:var(--text-lg);max-width:46ch}
.mig-cta__points{display:flex;flex-wrap:wrap;gap:var(--space-2) var(--space-6)}
.mig-cta__points li{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-mono);font-size:var(--text-sm);color:rgba(243,240,231,.92)}
.mig-cta__points .icon{width:18px;height:18px;color:var(--color-primary);flex:none}
.mig-cta__visual{display:flex;align-items:center;justify-content:center}
.mig-cta__svg{width:100%;max-width:260px;height:auto}
@media(max-width:820px){.mig-cta{grid-template-columns:1fr;gap:var(--space-8)}.mig-cta__visual{order:-1;justify-content:flex-start}.mig-cta__svg{max-width:200px}}
/* Plattform-Seiten: kompakter Migrations-Band (Deep-Green, „von -> zu") */
.mig-band{position:relative;display:grid;grid-template-columns:1.3fr .9fr;gap:clamp(var(--space-6),4vw,var(--space-12));align-items:center;background:var(--color-green-deep);color:#F3F0E7;border-radius:var(--radius-lg);padding:clamp(var(--space-6),3.5vw,var(--space-12));overflow:hidden}
.mig-band::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:var(--grad-molten)}
.mig-band::after{content:"";position:absolute;inset:0;background:var(--grad-ember-veil);pointer-events:none}
.mig-band__main{position:relative;z-index:1}
.mig-band__eyebrow{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:var(--tracking-wide);font-size:var(--text-xs);color:var(--color-primary)}
.mig-band__h{font-size:var(--text-xl);line-height:var(--leading-snug);letter-spacing:var(--tracking-tight);color:#F3F0E7;margin-top:var(--space-3);text-wrap:balance}
.mig-band__lead{font-size:var(--text-base);line-height:var(--leading-body);color:rgba(243,240,231,.78);margin-top:var(--space-3);max-width:54ch}
.mig-band__side{position:relative;z-index:1;display:flex;flex-direction:column;gap:var(--space-5);align-items:flex-start}
.mig-band__flow{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2)}
.mig-band__from{font-family:var(--font-mono);font-size:var(--text-sm);color:rgba(243,240,231,.62)}
.mig-band__arrow{width:18px;height:18px;color:var(--heat-amber);flex:none}
.mig-band__to{display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-mono);font-size:var(--text-sm);color:#F3F0E7;background:rgba(243,240,231,.08);border:1px solid rgba(243,240,231,.18);border-radius:var(--radius-md);padding:6px 10px}
.mig-band__to img{width:18px;height:18px}
@media(max-width:820px){.mig-band{grid-template-columns:1fr;gap:var(--space-6)}}
/* Sekundaerer Ghost-CTA auf Deep-Green-Baendern: hell statt dunkel */
.mig-band .btn--ghost,.mig-cta .btn--ghost{--btn-fg:#F3F0E7;border-color:rgba(243,240,231,.32)}
.mig-band .btn--ghost:hover,.mig-cta .btn--ghost:hover{--btn-fg:#F3F0E7;border-color:rgba(243,240,231,.6);background:rgba(243,240,231,.08)}

/* Migrationen: animierte Roadmap (vertikale Timeline, Deep-Green-Nodes, Fortschrittslinie scrubbt via motion.js) */
.roadmap{position:relative;display:flex;flex-direction:column;gap:var(--space-5)}
.roadmap__rail{position:absolute;left:27px;top:6px;bottom:28px;width:2px;background:var(--color-line);z-index:0}
.roadmap__progress{position:absolute;left:0;right:0;top:0;height:0;background:linear-gradient(180deg,var(--color-green-deep),var(--color-green))}
.roadmap__progress::after{content:"";position:absolute;left:50%;bottom:-3px;width:9px;height:9px;border-radius:50%;background:var(--heat-amber);transform:translateX(-50%);box-shadow:0 0 12px 2px rgba(255,181,52,.5);opacity:0}
.roadmap.is-drawing .roadmap__progress::after{opacity:1}
@media (prefers-reduced-motion:reduce){.roadmap__progress{height:100%}.roadmap__progress::after{display:none}}
html.no-js .roadmap__progress{height:100%}
html.no-js .roadmap__progress::after{display:none}
.roadmap__step{position:relative;display:grid;grid-template-columns:56px 1fr;gap:var(--space-5);align-items:start}
.roadmap__node{position:relative;z-index:1;width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--color-green-deep);border:2px solid var(--color-green-deep);transition:background var(--dur-base) var(--ease-out),border-color var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out),transform .45s var(--ease-out)}
.roadmap__num{font-family:var(--font-mono);font-size:var(--text-base);color:var(--heat-amber);transition:color var(--dur-base) var(--ease-out)}
.roadmap__step.is-future .roadmap__node,.roadmap__step.is-passed .roadmap__node{transform:scale(.78)}
.roadmap__step.is-passed .roadmap__node,.roadmap__step.is-focus .roadmap__node{background:var(--color-primary);border-color:var(--color-primary)}
.roadmap__step.is-passed .roadmap__num,.roadmap__step.is-focus .roadmap__num{color:var(--color-on-primary)}
.roadmap__step.is-focus .roadmap__node{transform:scale(1.24);box-shadow:var(--glow-molten)}
.roadmap__card{background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-lg);padding:var(--space-6);transition:transform .45s var(--ease-out),opacity .45s var(--ease-out),border-color var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out)}
.roadmap__card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md)}
.roadmap__step.is-future .roadmap__card,.roadmap__step.is-passed .roadmap__card{transform:scale(.94);opacity:.72}
.roadmap__step.is-focus .roadmap__card{transform:scale(1.05);border-color:var(--color-line-strong);box-shadow:var(--shadow-lg)}
.roadmap__head{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3)}
.roadmap__ico{display:inline-flex;width:34px;height:34px;align-items:center;justify-content:center;border-radius:var(--radius-md);background:var(--color-surface-2);border:1px solid var(--color-line);flex:none}
.roadmap__ico .icon{width:18px;height:18px;color:var(--color-primary)}
.roadmap__tag{font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--color-accent)}
.roadmap__card h3{font-size:var(--text-lg)}
.roadmap__card>p{color:var(--color-text-muted);margin-top:var(--space-2);line-height:var(--leading-body)}
.roadmap__bullets{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-line);display:flex;flex-direction:column;gap:var(--space-2)}
.roadmap__bullets li{display:flex;align-items:flex-start;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.45}
.roadmap__bullets .icon{width:15px;height:15px;color:var(--color-primary);flex:none;margin-top:3px}
@media(max-width:560px){.roadmap__step{grid-template-columns:44px 1fr;gap:var(--space-4)}.roadmap__node{width:44px;height:44px}.roadmap__rail{left:21px;top:6px;bottom:22px}.roadmap__num{font-size:var(--text-sm)}.roadmap__card{padding:var(--space-5)}}

/* Migrationen: typische Wechsel (von -> zu mit Logos) */
.mig-pairs{display:grid;grid-template-columns:repeat(auto-fit,minmax(258px,1fr));gap:var(--space-4)}
.mig-pair{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-lg);font-family:var(--font-mono);font-size:var(--text-sm);transition:border-color var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out)}
.mig-pair:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.mig-pair__side{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--color-text-muted)}
.mig-pair__side img{width:22px;height:22px}
.mig-pair__side--to{color:var(--color-text);font-weight:500}
.mig-pair__arrow{width:18px;height:18px;color:var(--color-primary);flex:none}
.list-check{display:flex;flex-direction:column;gap:var(--space-3)}
.list-check li{display:flex;gap:var(--space-3);align-items:flex-start}
.list-check .icon{color:var(--color-primary);margin-top:3px;flex:none}

/* ============================================================
   App-Entwicklung — Signature „Wir verwirklichen deine Idee"
   Deep-Green-Drench + Glut-Funke (Marken-Mark), Ember-Glow
   ============================================================ */
.idea{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(var(--space-8),5vw,var(--space-16));align-items:center;background:var(--color-green-deep);color:#F3F0E7;border-radius:var(--radius-lg);padding:clamp(var(--space-12),6vw,var(--space-24)) clamp(var(--space-8),5vw,var(--space-16));overflow:hidden}
.idea::after{content:"";position:absolute;inset:0;background:var(--grad-ember-veil);pointer-events:none}
.idea__body{position:relative;z-index:1;display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-5)}
.idea__kicker{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:var(--tracking-wide);font-size:var(--text-xs);color:var(--color-primary)}
.idea__title{font-size:var(--text-3xl);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);color:#F3F0E7;text-wrap:balance}
.idea__lead{font-size:var(--text-lg);line-height:var(--leading-body);color:rgba(243,240,231,.80);max-width:48ch}
.idea__beats{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-1)}
.idea__beats li{display:flex;align-items:center;gap:var(--space-2);font-family:var(--font-mono);font-size:var(--text-sm);color:rgba(243,240,231,.90);border:1px solid rgba(243,240,231,.18);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3)}
.idea__beats .icon{width:16px;height:16px;color:var(--heat-amber);flex:none}
.idea__visual{position:relative;z-index:1;display:flex;justify-content:center}
.idea__svg{width:100%;max-width:300px;height:auto;filter:drop-shadow(0 0 32px rgba(255,90,30,.25))}
@media(max-width:860px){.idea{grid-template-columns:1fr;gap:var(--space-8)}.idea__visual{order:-1;justify-content:flex-start}.idea__svg{max-width:190px}}

/* ============================================================
   App-Entwicklung — Technik als „Spec-Sheet" (Datenblatt-Optik)
   Deep-Green + Mono-HUD, Hairline-Raster, Glut-Oberkante
   ============================================================ */
.techspec{position:relative;display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(var(--space-8),5vw,var(--space-16));background:var(--color-green-deep);color:#F3F0E7;border-radius:var(--radius-lg);padding:clamp(var(--space-8),5vw,var(--space-16));overflow:hidden}
.techspec::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:var(--grad-molten)}
.techspec::after{content:"";position:absolute;inset:0;background:var(--grad-ember-veil);pointer-events:none}
.techspec__intro{position:relative;z-index:1;align-self:start}
.techspec__kicker{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:var(--tracking-wide);font-size:var(--text-xs);color:var(--color-primary)}
.techspec__intro h2{color:#F3F0E7;font-size:var(--text-2xl);line-height:var(--leading-snug);letter-spacing:var(--tracking-tight);margin-top:var(--space-4);text-wrap:balance}
.techspec__intro p{color:rgba(243,240,231,.76);font-size:var(--text-base);line-height:var(--leading-body);margin-top:var(--space-4);max-width:34ch}
.techspec__list{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:0 clamp(var(--space-6),3vw,var(--space-12))}
.techspec__list li{display:flex;gap:var(--space-3);align-items:flex-start;padding:var(--space-4) 0;border-top:1px solid rgba(243,240,231,.13)}
.techspec__list li:nth-child(-n+2){border-top:0}
.techspec__ico{display:inline-flex;flex:none;width:34px;height:34px;align-items:center;justify-content:center;border-radius:var(--radius-md);background:rgba(243,240,231,.07);border:1px solid rgba(243,240,231,.16)}
.techspec__ico .icon{width:18px;height:18px;color:var(--heat-amber)}
.techspec__txt h3{font-size:var(--text-base);color:#F3F0E7;line-height:1.25}
.techspec__txt p{font-size:var(--text-sm);color:rgba(243,240,231,.72);margin-top:2px;line-height:1.45}
@media(max-width:860px){.techspec{grid-template-columns:1fr;gap:var(--space-8)}.techspec__list{grid-template-columns:1fr}.techspec__list li:nth-child(2){border-top:1px solid rgba(243,240,231,.13)}}
.cols-2{columns:2;column-gap:var(--space-12)}
.cols-2 li{break-inside:avoid;margin-bottom:var(--space-3)}
@media (max-width:768px){.cols-2{columns:1}}
.cols-3{columns:3;column-gap:var(--space-8)}
.cols-3 li{break-inside:avoid;margin-bottom:var(--space-3)}
@media (max-width:900px){.cols-3{columns:2}}
@media (max-width:560px){.cols-3{columns:1}}
/* Service-Split: Text + konkrete Punkte nebeneinander (weniger Whitespace, klare Führung) */
.svc-split{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-12);align-items:center}
.svc-split__label{font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--color-accent)}
@media (max-width:860px){.svc-split{grid-template-columns:1fr;gap:var(--space-8)}}
.crosslinks{display:flex;flex-wrap:wrap;gap:var(--space-3);font-family:var(--font-mono);font-size:var(--text-sm)}
.crosslinks a{padding:var(--space-2) var(--space-4);border:1px solid var(--color-line);border-radius:var(--radius-md);color:var(--color-text-muted)}
.crosslinks a:hover{border-color:var(--color-primary);color:var(--color-text)}

/* ===== Trust- & Conversion-Bausteine ===== */
.hero-trust{display:flex;flex-wrap:wrap;gap:var(--space-2) var(--space-6);margin-top:var(--space-8);font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}
.hero-trust li{display:flex;align-items:center;gap:var(--space-2)}
.hero-trust .icon{width:15px;height:15px;color:var(--color-primary);flex:none}

.trust-ledger{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}
.trust-row{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-6);background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-lg);transition:border-color var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out)}
.trust-row:hover{border-color:var(--color-primary);transform:translateY(-3px);box-shadow:var(--shadow-md)}
.trust-row__badge{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:var(--radius-md);background:var(--color-surface-2);border:1px solid var(--color-line);flex:none}
.trust-row__badge .icon{width:24px;height:24px;color:var(--color-primary)}
.trust-row h3{font-size:var(--text-lg)}
.trust-row p{color:var(--color-text-muted);font-size:var(--text-base);line-height:var(--leading-body)}
@media(max-width:980px){.trust-ledger{grid-template-columns:repeat(2,1fr)}}
/* Prozess-Karten (Deep-Green, mit Bullets) */
.process{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6)}
.process__card{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-8);background:var(--color-green-deep);border:1px solid transparent;border-radius:var(--radius-lg);transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out),border-color var(--dur-base) var(--ease-out)}
.process__card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--color-primary)}
.process__badge{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-md);background:rgba(243,240,231,.08);border:1px solid rgba(243,240,231,.16)}
.process__badge .icon{width:24px;height:24px;color:var(--color-primary)}
.process__card h3{font-family:var(--font-display);font-size:var(--text-lg);color:#F3F0E7}
.process__card>p{color:rgba(243,240,231,.74);line-height:var(--leading-body)}
.process__list{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-2);padding-top:var(--space-4);border-top:1px solid rgba(243,240,231,.12)}
.process__list li{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:rgba(243,240,231,.88)}
.process__list .icon{width:15px;height:15px;color:var(--color-primary);flex:none}
@media(max-width:860px){.process{grid-template-columns:1fr}}

.quote-hl{position:relative;max-width:52ch;margin-inline:auto;text-align:center;padding-top:var(--space-16)}
.quote-hl::before{content:"\201C";position:absolute;top:0;left:50%;transform:translateX(-50%);font-family:var(--font-display);font-weight:700;font-size:8rem;line-height:.8;color:var(--color-primary);opacity:.22}
.quote-hl blockquote{font-family:var(--font-display);font-weight:500;font-size:var(--text-2xl);line-height:var(--leading-snug);letter-spacing:var(--tracking-tight);color:var(--color-text)}
.quote-hl figcaption{margin-top:var(--space-8);font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-accent);display:flex;flex-direction:column;gap:var(--space-1);text-transform:uppercase;letter-spacing:.05em}
.quote-hl figcaption span{color:var(--color-text-muted);text-transform:none;letter-spacing:0}

/* Integrationen — kategorisierte Karten mit Hover-Animation */
.integrations{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-5,20px)}
.intg-card{padding:var(--space-6);border:1px solid var(--color-line);border-radius:var(--radius-lg);background:var(--color-surface)}
/* Hoeher spezifiziert als .reveal / .reveal.is-visible (die sonst die Hover-Transition
   und das Hover-transform der Karte ueberschreiben). opacity bleibt fuer die Einblendung. */
.integrations .intg-card{transition:opacity var(--dur-slow) var(--ease-out),transform var(--dur-base) var(--ease-emphasized),box-shadow var(--dur-base) var(--ease-emphasized),border-color var(--dur-base) var(--ease-emphasized)}
.integrations .intg-card:hover{transform:translateY(-4px);border-color:var(--color-line-strong);box-shadow:var(--shadow-md)}
.intg-card__head{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-5,20px)}
.intg-card__icon{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;flex:none;
  border-radius:var(--radius-md);background:var(--color-surface-2);color:var(--color-accent);
  transition:transform var(--dur-base) var(--ease-forge),background var(--dur-base) var(--ease-out),color var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out)}
.intg-card__icon .icon{width:20px;height:20px}
.intg-card:hover .intg-card__icon{transform:rotate(-6deg) scale(1.08);background:var(--color-primary);color:var(--color-on-primary);box-shadow:var(--glow-amber)}
.intg-card__head h3{margin:0;font-size:var(--text-base)}
.intg-card__chips{display:flex;flex-wrap:wrap;gap:var(--space-2)}
.intg-card__chips li{display:inline-flex;align-items:center;gap:var(--space-2);white-space:nowrap;
  padding:var(--space-2) var(--space-3);border:1px solid var(--color-line);border-radius:var(--radius-md);
  background:var(--color-bg);font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-text-muted);
  transition:transform var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out)}
.intg-card__chips li:hover{transform:translateY(-2px);border-color:var(--color-accent);background:var(--color-surface);box-shadow:var(--shadow-sm)}
.intg-card__chips .intg-logo{width:16px;height:16px;flex:none;object-fit:contain}
.intg-card__chips li.is-more{border-style:dashed;letter-spacing:.14em;padding-inline:var(--space-4)}
.intg-card__chips li.is-more:hover{border-color:var(--color-accent);color:var(--color-accent)}
@media (max-width:980px){.integrations{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.integrations{grid-template-columns:1fr;gap:var(--space-4)}}

@media (max-width:768px){
  .trust-ledger{grid-template-columns:1fr}
  .quote-hl blockquote{font-size:var(--text-xl)}
}

/* ===== Testimonials / Quotes ===== */
.quotes{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6)}
.quote{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-8);background:var(--color-surface);
  border:1px solid var(--color-line);border-left:2px solid var(--color-primary);border-radius:var(--radius-md)}
.quote p{font-family:var(--font-display);font-weight:600;font-size:var(--text-xl);line-height:var(--leading-snug);color:var(--color-text);max-width:none;letter-spacing:var(--tracking-tight)}
.quote cite{font-style:normal;font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-text-muted)}
@media (max-width:768px){.quotes{grid-template-columns:1fr}}

/* ===== Projekt-Profile (Referenzen) ===== */
.profiles-viewport{overflow-x:auto;overflow-y:hidden;touch-action:pan-x;scroll-snap-type:x proximity;scroll-padding-left:max(var(--container-gutter),calc((100% - var(--container-max)) / 2 + var(--container-gutter)));scrollbar-width:none;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;padding-block:var(--space-2) var(--space-4)}
.profiles-viewport::-webkit-scrollbar{display:none}
.profiles{display:flex;gap:var(--space-8);padding-left:max(var(--container-gutter),calc((100% - var(--container-max)) / 2 + var(--container-gutter)));padding-right:0}
.profiles>.profile{flex:0 0 min(88vw,420px);scroll-snap-align:start}
/* Referenzen-Hub: Mehrspalten-Grid statt Slider (nur auf /referenzen) */
.profiles--grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-8);padding:0}
.profiles--grid>.profile{flex:none;scroll-snap-align:none}
/* Referenzen-Filter: Mono-Chips unter der Subheading; aktiver Chip = Deep-Green */
#ref-grid{position:relative}
.ref-filter{display:flex;flex-wrap:wrap;gap:var(--space-3);margin:var(--space-6) 0 var(--space-12)}
.ref-filter__btn{display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-text-muted);background:transparent;border:1px solid var(--color-line);border-radius:var(--radius-md);padding:var(--space-2) var(--space-4);cursor:pointer;transition:border-color var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out)}
.ref-filter__btn:hover{border-color:var(--color-primary);color:var(--color-text)}
.ref-filter__btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}
.ref-filter__btn.is-active{background:var(--color-green-deep);border-color:var(--color-green-deep);color:#F3F0E7}
.ref-filter__n{font-size:var(--text-xs);opacity:.55;font-variant-numeric:tabular-nums}
.ref-filter__btn.is-active .ref-filter__n{opacity:.7}
@media(max-width:600px){.ref-filter{gap:var(--space-2);margin:var(--space-5) 0 var(--space-8)}.ref-filter__btn{font-size:var(--text-xs);padding:var(--space-2) var(--space-3)}}
@media(max-width:760px){.profiles--grid{grid-template-columns:1fr}}

/* Referenzen: White-Label-Badge pro Card + moderner Tooltip */
.wl{position:relative;align-self:flex-start;display:inline-flex;align-items:center;gap:6px;margin-bottom:calc(var(--space-2) * -1);
  font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;
  color:var(--color-text-muted);background:var(--color-bg);border:1px solid var(--color-line);padding:5px 10px;border-radius:var(--radius-md);
  cursor:help;transition:border-color var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out)}
.wl>.icon{width:13px;height:13px;color:var(--color-accent)}
.wl:hover,.wl:focus,.wl:focus-within{border-color:var(--color-accent);color:var(--color-text);background:var(--color-surface-2);outline:none}
.wl__tip{position:absolute;top:calc(100% + var(--space-3));left:0;width:min(284px,76vw);
  display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-6);text-transform:none;letter-spacing:normal;
  background:var(--color-green-deep);color:#F3F0E7;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);
  opacity:0;visibility:hidden;transform:translateY(-6px) scale(.97);transform-origin:top left;
  transition:opacity var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out),visibility var(--dur-base);z-index:4}
.wl__tip::before{content:"";position:absolute;top:calc(-1 * var(--space-2) + 1px);left:var(--space-6);border:var(--space-2) solid transparent;border-top:0;border-bottom-color:var(--color-green-deep)}
.wl:hover .wl__tip,.wl:focus .wl__tip,.wl:focus-within .wl__tip{opacity:1;visibility:visible;transform:none}
.wl__tip-head{display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-display);font-weight:600;font-size:var(--text-base);color:#fff}
.wl__tip-head .icon{width:16px;height:16px;color:var(--heat-amber);flex:none}
.wl__tip-body{font-family:var(--font-body);font-size:var(--text-sm);line-height:var(--leading-body);color:rgba(243,240,231,.82)}
@media (prefers-reduced-motion:reduce){.wl__tip{transition:none}}
.profile{display:flex;flex-direction:column;background:var(--color-surface);border:1px solid var(--color-line);border-radius:var(--radius-lg);overflow:hidden;transition:border-color var(--dur-base) var(--ease-out)}
.profile:hover{border-color:var(--color-line-strong)}
.profile__media{position:relative;aspect-ratio:3/2;background:var(--color-bg)}
.profile__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.profile__tags{position:absolute;left:var(--space-4);top:var(--space-4);display:flex;flex-wrap:wrap;gap:var(--space-2)}
.profile__tags span{font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;background:rgba(37,50,42,.82);color:#F3F0E7;padding:4px 8px;border-radius:var(--radius-sm)}
.profile__body{padding:var(--space-8);display:flex;flex-direction:column;gap:var(--space-4)}
.profile__body h3{font-size:var(--text-xl)}
.profile__facts{display:flex;flex-direction:column;gap:var(--space-3)}
.profile__facts > div{display:grid;grid-template-columns:104px 1fr;gap:var(--space-4)}
.profile__facts dt{font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--color-primary);padding-top:2px}
.profile__facts dd{color:var(--color-text-muted)}
.profile__quote{margin-top:var(--space-2);border-left:2px solid var(--color-primary);padding-left:var(--space-4);font-family:var(--font-display);font-weight:600;color:var(--color-text)}
.profile__quote cite{display:block;margin-top:var(--space-2);font-family:var(--font-mono);font-size:var(--text-sm);font-style:normal;color:var(--color-text-muted);font-weight:400}
@media (max-width:768px){
  .profile__body{padding:var(--space-6)}
  .profile__facts > div{grid-template-columns:1fr;gap:var(--space-1)}
}

/* ===== Footer ===== */
/* Footer — transparent (zeigt auf der Home die Blueprint-Fläche durch), editorial verfeinert */
.site-footer{position:relative;z-index:2;background:transparent;padding-block:var(--space-16) var(--space-8)}
.site-footer::before{content:"";position:absolute;inset:0 0 auto 0;height:1px;
  background:linear-gradient(90deg,transparent,var(--color-line-strong) 16%,var(--color-line-strong) 84%,transparent)}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.1fr;gap:var(--space-8) var(--space-12)}
.footer-brand{display:flex;flex-direction:column;gap:var(--space-4);max-width:36ch}
.footer-claim{font-family:var(--font-display);font-weight:600;font-size:var(--text-xl);line-height:var(--leading-snug);letter-spacing:var(--tracking-tight);color:var(--color-text)}
.footer-col h4{font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.12em;color:var(--color-text-muted);margin-bottom:var(--space-5);display:inline-flex;align-items:center;gap:var(--space-2)}
.footer-col h4::before{content:"";width:14px;height:1px;background:var(--color-primary)}
.footer-col ul{display:flex;flex-direction:column;gap:var(--space-3)}
.footer-col a{position:relative;width:fit-content;color:var(--color-text-muted);font-size:var(--text-sm);transition:color var(--dur-fast) var(--ease-out)}
.footer-col a::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:1px;background:var(--color-primary);transition:width var(--dur-base) var(--ease-out)}
.footer-col a:hover{color:var(--color-text)}
.footer-col a:hover::after{width:100%}
/* Anschrift: optisch abgesetzt (feine Trennlinie) + bewusst sehr dezent/zurückhaltend */
.footer-col address{font-style:normal;font-size:var(--text-xs);line-height:1.9;letter-spacing:.01em;
  color:var(--color-text-muted);color:color-mix(in srgb, var(--color-text-muted) 58%, transparent);
  margin-top:var(--space-6);padding-top:var(--space-5);border-top:1px solid var(--color-line)}
.footer-col address a{color:inherit;transition:color var(--dur-fast) var(--ease-out)}
.footer-col address a:hover{color:var(--color-accent)}
.footer-social{display:flex;gap:var(--space-3);margin-top:var(--space-2)}
.footer-social a{width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--color-line-strong);border-radius:var(--radius-md);color:var(--color-text-muted);
  transition:color var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out)}
.footer-social a:hover{color:var(--color-on-primary);background:var(--color-primary);border-color:var(--color-primary);transform:translateY(-2px)}
.footer-bottom{margin-top:var(--space-16);padding-top:var(--space-6);border-top:1px solid var(--color-line);
  display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:var(--space-4);
  font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-muted)}
.footer-bottom a:hover{color:var(--color-accent)}

/* ===== Legal pages ===== */
.legal{max-width:760px}
.legal h2{font-size:var(--text-xl);margin-top:var(--space-12);margin-bottom:var(--space-4)}
.legal p,.legal address{margin-bottom:var(--space-4);color:var(--color-text-muted)}
.legal address{font-style:normal;line-height:1.9}

/* ===== Reveal (IO-gesteuert) ===== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity var(--dur-slow) var(--ease-out),transform var(--dur-slow) var(--ease-out)}
.reveal.is-visible{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}.reveal[data-d="4"]{transition-delay:.32s}
.page-hero{padding-top:calc(var(--space-32) + var(--space-8));padding-bottom:var(--space-16);position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background:var(--grad-ember-veil);opacity:.32;z-index:0}
/* Statischer Blueprint auf Unterseiten entfernt – es bleibt nur der animierte WebGL-Hintergrund sichtbar */
.page-hero::after{display:none}
.page-hero .container{position:relative;z-index:2}

/* ============================================================
   Über uns — Manifest-Statement + Gründer-Monogramme (Blueprint draw-on)
   ============================================================ */
.manifesto{max-width:64ch}
.manifesto__statement{font-size:var(--text-display);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);text-wrap:balance;margin-top:var(--space-4)}
.manifesto__lead{margin-top:var(--space-6);font-size:var(--text-lg);color:var(--color-text-muted);line-height:var(--leading-body);text-wrap:pretty;max-width:60ch}

.founders__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(var(--space-8),5vw,var(--space-16));margin-top:var(--space-12)}
.founder{display:flex;flex-direction:column;gap:var(--space-6);perspective:1100px}
.founder__plate{position:relative;aspect-ratio:6/7;background:var(--color-green-deep);border:1px solid var(--color-line-strong);border-radius:var(--radius-lg);overflow:hidden;transform-style:preserve-3d;will-change:transform;transition:transform .45s var(--ease-out),box-shadow var(--dur-base) var(--ease-out),border-color var(--dur-base) var(--ease-out)}
.founder__plate::before{content:"";position:absolute;z-index:3;inset:0;pointer-events:none;background-image:repeating-linear-gradient(to right,rgba(243,240,231,.06) 0 1px,transparent 1px 32px),repeating-linear-gradient(to bottom,rgba(243,240,231,.06) 0 1px,transparent 1px 32px)}
.founder__plate.is-tilting{transition:box-shadow var(--dur-base) var(--ease-out),border-color var(--dur-base) var(--ease-out)}
.founder:hover .founder__plate{border-color:var(--color-primary);box-shadow:var(--shadow-lg)}
/* Initialen-Fallback (sichtbar, solange kein Foto hinterlegt ist) */
.founder__fallback{position:absolute;z-index:0;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:140px;letter-spacing:-.03em;color:#F3F0E7;opacity:.9}
/* Abstrahiertes, monochrom getöntes Porträt */
.founder__photo{position:absolute;z-index:1;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 28%;filter:grayscale(1) contrast(1.05) brightness(1.04);transform:scale(1.03);transition:filter .55s var(--ease-out),transform .6s var(--ease-out)}
.founder__duo{position:absolute;z-index:2;inset:0;pointer-events:none;background:linear-gradient(160deg,rgba(44,63,38,.66) 0%,rgba(44,63,38,.34) 48%,rgba(255,106,0,.26) 100%);mix-blend-mode:multiply;transition:opacity .55s var(--ease-out)}
.founder__svg{position:absolute;z-index:4;inset:0;width:100%;height:100%;pointer-events:none}
.founder__draw{transition:stroke var(--dur-base) var(--ease-out)}
.founder__spec{font-family:var(--font-mono);font-size:13px;letter-spacing:.12em;fill:#F3F0E7;opacity:.72;transition:fill var(--dur-base) var(--ease-out)}
.founder__badge{position:absolute;z-index:4;top:14px;left:14px;font-family:var(--font-mono);font-size:13px;letter-spacing:.12em;color:#F3F0E7;background:rgba(20,30,20,.55);padding:5px 9px;border-radius:var(--radius-sm)}
/* Hover: echtes Farbfoto enthüllen */
.founder:hover .founder__photo{filter:grayscale(0) contrast(1.02);transform:scale(1.08)}
.founder:hover .founder__duo{opacity:0}
.founder:hover .founder__draw{stroke:var(--color-primary)}
.founder:hover .founder__spec{fill:var(--color-primary);opacity:1}
.founder__plate.no-photo .founder__photo,.founder__plate.no-photo .founder__duo{display:none}
.founder__body{display:flex;flex-direction:column;gap:var(--space-3)}
.founder__role{font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--color-accent)}
.founder__name{font-size:var(--text-2xl);line-height:var(--leading-snug)}
.founder__bio{color:var(--color-text-muted);line-height:var(--leading-body);max-width:48ch}
.founder__tags{display:flex;flex-wrap:wrap;gap:var(--space-2);list-style:none;padding:0;margin-top:var(--space-2)}
.founder__tags li{font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);background:var(--color-surface);border:1px solid var(--color-line);padding:6px 10px;border-radius:var(--radius-md)}
@media (prefers-reduced-motion:reduce){.founder__plate{transition:none}}
@media (max-width:768px){.founders__grid{grid-template-columns:1fr}.founder__fallback{font-size:112px}.manifesto__statement{font-size:var(--text-3xl)}}

/* ============================================================
   Webentwicklung — Relaunch-Check (dunkelgrün + Formular) + Pitch-Cards
   ============================================================ */
.relaunch{position:relative;overflow:hidden;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(var(--space-8),4vw,var(--space-12));background:var(--color-green-deep);color:#F3F0E7;border-radius:var(--radius-lg);padding:clamp(var(--space-8),4vw,var(--space-16));box-shadow:var(--shadow-lg)}
.relaunch::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(120% 90% at 100% 0%,rgba(255,106,0,.20),transparent 55%)}
.relaunch>*{position:relative;z-index:1}
.relaunch .eyebrow{color:var(--color-primary)}
.relaunch__title{font-size:var(--text-2xl);line-height:var(--leading-snug);letter-spacing:var(--tracking-tight);text-wrap:balance;margin-top:var(--space-4);max-width:18ch}
.relaunch__lead{margin-top:var(--space-4);color:rgba(243,240,231,.82);line-height:var(--leading-body);max-width:52ch}
.relaunch__points{list-style:none;padding:0;margin:var(--space-6) 0 0;display:flex;flex-direction:column;gap:var(--space-3)}
.relaunch__points li{display:flex;align-items:flex-start;gap:var(--space-3);color:rgba(243,240,231,.92);font-size:var(--text-base)}
.relaunch__points .icon{color:var(--color-primary);width:20px;height:20px;flex:none;margin-top:2px}
.relaunch__svg{display:block;width:100%;max-width:360px;height:auto;margin-top:var(--space-8)}
.relaunch__panel{background:rgba(243,240,231,.05);border:1px solid rgba(243,240,231,.16);border-radius:var(--radius-md);padding:clamp(var(--space-6),2.5vw,var(--space-8));align-self:start}
.relaunch__form[hidden],.relaunch__success[hidden]{display:none}
.relaunch__form{display:flex;flex-direction:column;gap:var(--space-4)}
.relaunch__form .field{display:flex;flex-direction:column;gap:var(--space-2)}
.relaunch__form>.field>label{font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:rgba(243,240,231,.8)}
.relaunch__form input[type=url],.relaunch__form input[type=email]{width:100%;padding:13px 14px;font:inherit;font-size:var(--text-base);color:#F3F0E7;background:rgba(12,11,10,.25);border:1px solid rgba(243,240,231,.22);border-radius:var(--radius-md);transition:border-color var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out)}
.relaunch__form input::placeholder{color:rgba(243,240,231,.4)}
.relaunch__form input:focus-visible{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(255,106,0,.28)}
.relaunch__form .field--check{flex-direction:row;align-items:flex-start;gap:var(--space-3)}
.relaunch__form .field--check input{margin-top:3px;accent-color:var(--color-primary);width:16px;height:16px;flex:none}
.relaunch__form .field--check label{font-family:var(--font-body);text-transform:none;letter-spacing:0;font-size:var(--text-sm);color:rgba(243,240,231,.75);line-height:1.5}
.relaunch__form .field--check a{color:#F3F0E7}
.relaunch__submit{justify-content:center;margin-top:var(--space-2)}
.relaunch__submit.is-loading{opacity:.7;pointer-events:none}
.relaunch__micro{font-family:var(--font-mono);font-size:var(--text-xs);color:rgba(243,240,231,.55);text-align:center;margin-top:var(--space-1)}
.relaunch .hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.relaunch__success{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-3);padding:var(--space-4) 0}
.relaunch__successicon{display:inline-flex;width:48px;height:48px;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,106,0,.16);color:var(--color-primary)}
.relaunch__successicon .icon{width:26px;height:26px}
.relaunch__success h3{font-size:var(--text-xl)}
.relaunch__success p{color:rgba(243,240,231,.82);line-height:var(--leading-body)}
/* Kontaktformular: Erfolgsmeldung (heller Hintergrund) */
.form[hidden],.form-success[hidden]{display:none}
.form-success{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-3);padding:var(--space-4) 0}
.form-success__icon{display:inline-flex;width:48px;height:48px;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,106,0,.12);color:var(--color-primary)}
.form-success__icon .icon{width:26px;height:26px}
.form-success h3{font-size:var(--text-xl)}
.form-success p{color:var(--color-text-muted);line-height:var(--leading-body)}
.form-error[hidden]{display:none}
.form-error{margin-top:var(--space-4);font-size:var(--text-sm);line-height:var(--leading-body);color:var(--color-accent)}
.form-error a{color:var(--color-accent);font-weight:600;text-decoration:underline}
.relaunch__panel .form-error{margin-top:var(--space-2);color:var(--heat-amber)}
.relaunch__panel .form-error a{color:var(--heat-amber)}
@media (max-width:860px){.relaunch{grid-template-columns:1fr;gap:var(--space-8)}.relaunch__svg{max-width:300px}}

.pitch{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6);margin-top:var(--space-12);perspective:1100px}
.pitch__card{display:flex;flex-direction:column;gap:var(--space-4);background:var(--color-green-deep);color:#F3F0E7;border:1px solid transparent;border-radius:var(--radius-lg);padding:var(--space-8);position:relative;transform-style:preserve-3d;will-change:transform;transition:transform .45s var(--ease-out),box-shadow var(--dur-base) var(--ease-out),border-color var(--dur-base) var(--ease-out)}
.pitch__card.is-tilting{transition:box-shadow var(--dur-base) var(--ease-out),border-color var(--dur-base) var(--ease-out)}
.pitch__card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-lg)}
.pitch__icon{display:inline-flex;width:48px;height:48px;align-items:center;justify-content:center;border-radius:var(--radius-md);background:rgba(255,106,0,.14);color:var(--color-primary);transform:translateZ(30px)}
.pitch__icon .icon{width:24px;height:24px}
.pitch__card h3{color:#F3F0E7;font-size:var(--text-lg);transform:translateZ(20px)}
.pitch__card p{color:rgba(243,240,231,.74);line-height:var(--leading-body);transform:translateZ(12px)}
@media (max-width:860px){.pitch{grid-template-columns:1fr;perspective:none}.pitch__card{transform:none!important}}

/* ===== No-JS / Reduced-Motion: alles sichtbar ===== */
html.no-js .reveal{opacity:1;transform:none}
html.no-js .hero__canvas{display:none}
html.no-js .mobile-menu{position:static;clip-path:none;visibility:visible;padding:var(--space-8) var(--container-gutter);background:var(--color-surface)}
html.no-js .hamburger{display:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .hero__canvas,.cursor,.spark{display:none!important}
  *{animation-duration:.001ms!important;animation-iteration-count:1!important}
}

/* ============================================================
   Cookie-Consent (vanilla-cookieconsent) — an die Marke angepasst
   ============================================================ */
#cc-main{
  --cc-font-family:var(--font-body);
  --cc-bg:var(--color-surface);
  --cc-primary-color:var(--color-text);
  --cc-secondary-color:var(--color-text-muted);
  --cc-link-color:var(--color-accent);
  --cc-btn-primary-bg:var(--color-primary);
  --cc-btn-primary-color:var(--color-on-primary);
  --cc-btn-primary-border-color:var(--color-primary);
  --cc-btn-primary-hover-bg:#e85f00;
  --cc-btn-primary-hover-color:var(--color-on-primary);
  --cc-btn-primary-hover-border-color:#e85f00;
  --cc-btn-secondary-bg:var(--color-surface-2);
  --cc-btn-secondary-color:var(--color-text);
  --cc-btn-secondary-border-color:var(--color-line-strong);
  --cc-btn-secondary-hover-bg:#e4dfd2;
  --cc-btn-secondary-hover-color:var(--color-text);
  --cc-btn-secondary-hover-border-color:var(--color-line-strong);
  --cc-separator-border-color:var(--color-line);
  --cc-cookie-category-block-bg:var(--color-surface-2);
  --cc-cookie-category-block-border:var(--color-line);
  --cc-cookie-category-block-hover-bg:#e4dfd2;
  --cc-cookie-category-block-hover-border:var(--color-line-strong);
  --cc-cookie-category-expanded-block-bg:var(--color-surface-2);
  --cc-cookie-category-expanded-block-hover-bg:#e4dfd2;
  --cc-section-category-border:var(--color-line);
  --cc-overlay-bg:rgba(37,50,42,.55);
  --cc-toggle-on-bg:var(--color-primary);
  --cc-toggle-off-bg:#b9b2a4;
  --cc-toggle-on-knob-bg:#fff;
  --cc-toggle-off-knob-bg:#fff;
  --cc-toggle-enabled-icon-color:var(--color-on-primary);
  --cc-toggle-disabled-icon-color:#fbf9f2;
  --cc-toggle-readonly-bg:#cfc9bc;
  --cc-toggle-readonly-knob-bg:#fbf9f2;
  --cc-toggle-readonly-knob-icon-color:var(--color-text);
  --cc-modal-border-radius:var(--radius-lg);
  --cc-btn-border-radius:var(--radius-md);
  --cc-z-index:9000;
  --cc-footer-bg:var(--color-surface-2);
  --cc-footer-color:var(--color-text-muted);
  --cc-footer-border-color:var(--color-line)
}
#cc-main .cm,#cc-main .pm{box-shadow:var(--shadow-lg);border:1px solid var(--color-line)}
#cc-main .cm__title,#cc-main .pm__title{font-family:var(--font-display);letter-spacing:var(--tracking-tight)}
#cc-main .cm__btn,#cc-main .pm__btn{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;font-size:var(--text-sm)}
.cc-reopen{font:inherit;color:inherit;background:none;border:0;padding:0;margin:0;cursor:pointer;text-decoration:none}
.cc-reopen:hover{color:var(--color-text)}
@media (prefers-reduced-motion:reduce){#cc-main{--cc-modal-transition-duration:0s}}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:1024px){
  .hero__grid{grid-template-columns:1fr;gap:var(--space-8)}
  .hero__hud{display:none}
  .contact-grid{grid-template-columns:1fr;gap:var(--space-12)}
  .faq{grid-template-columns:1fr;gap:var(--space-8)}
  .faq__index{position:static;flex-direction:row;flex-wrap:wrap;gap:var(--space-4)}
  .steps{grid-template-columns:1fr;gap:var(--space-8)}
  .steps__sticky{position:static;padding-top:0}
  .footer-grid{grid-template-columns:1fr 1fr}
}
/* Nav kollabiert frueher zum Hamburger (<=1050px) — mehr Luft fuer Logo + CTA */
@media (max-width:1050px){
  .nav-links,.nav-cta{display:none}
  .hamburger{display:inline-flex}
}
@media (max-width:768px){
  .duo{grid-template-columns:1fr;gap:var(--space-6)}
  .duo__card:nth-child(2){transform:none}
  .stance__row{grid-template-columns:1fr;gap:var(--space-4)}
  .duo__card{padding:var(--space-8);min-height:260px}
}
/* Mobile-Hero: verhindert, dass Titel/Eyebrow den Hero horizontal sprengen.
   - min-width:0 loest den Grid-Track-Blowout (sonst blaeht der nowrap-Eyebrow die 1fr-Spalte auf 786px auf)
   - Eyebrow darf umbrechen + kleiner, Titel skaliert mit der Viewport-Breite (statt starrer 48px-clamp-Untergrenze) */
@media (max-width:600px){
  .hero__content{min-width:0}
  .hero .eyebrow{white-space:normal;font-size:calc(var(--text-xs) * 1.25)}
  .hero__title{font-size:clamp(2.1rem,9.2vw,3rem)}
  .hero__sub{font-size:var(--text-base)}
}
@media (max-width:520px){
  .footer-grid{grid-template-columns:1fr}
  .panel{padding:var(--space-6)}
  .hero__proof{gap:var(--space-3)}
}

/* ============================================================
   View Transitions — native Cross-Document (MPA), library-frei
   ------------------------------------------------------------
   - Default: sauberer Cross-Fade (240 ms, in 200-300 ms).
   - Der Header bleibt STATISCH: ein eigener view-transition-name
     loest ihn aus dem root-Snapshot -> der fixed-Header ruckelt
     nicht mehr beim Cross-Fade mit. Brand & CTA sind als Teil des
     stabilen Headers durchgehend praesent (impliziter Shared-Element).
   - Greift nur bei Navigation; Cross-Document animiert NIE den
     initialen Load (auch nicht die Homepage) -> Anforderung erfuellt.
   - Graceful degradation: Browser ohne Support navigieren normal,
     das DOM-Update laeuft immer durch.
   ============================================================ */
@view-transition{navigation:auto}

/* Default-Cross-Fade verkuerzen (Browser-Default ~250 ms) + ruhige Kurve */
::view-transition-group(root),
::view-transition-old(root),
::view-transition-new(root){animation-duration:240ms;animation-timing-function:cubic-bezier(.2,0,0,1)}

/* Header STATISCH halten: eigener Name loest den position:fixed-Header aus dem
   root-Snapshot. Gleiche Geometrie auf alt & neu -> kein Versatz/Ruckeln; die
   Inhalte darunter cross-faden, der Header bleibt stehen. Footer-.brand bleibt
   unbenannt (Teil des root). */
.site-header{view-transition-name:wf-header}
::view-transition-group(wf-header){animation-duration:240ms;animation-timing-function:cubic-bezier(.2,0,0,1)}

/* prefers-reduced-motion: sofortiger, bewegungsloser Wechsel.
   (Das globale *{animation-duration:.001ms} oben matcht KEINE
   ::view-transition-*-Pseudoelemente, daher hier explizit.) */
@media (prefers-reduced-motion:reduce){
  ::view-transition-group(*),
  ::view-transition-old(*),
  ::view-transition-new(*){animation-duration:.001ms!important;animation-delay:0ms!important}
}
/* Mobile-Hero: eigenes Hochformat-Bild (nach Basis-.hero__poster → gewinnt) */
@media (max-width:600px){
  .hero__poster{background:
    radial-gradient(80% 38% at 50% 78%, rgba(255,106,0,.16), transparent 70%),
    radial-gradient(70% 40% at 50% 14%, rgba(76,107,60,.10), transparent 70%),
    var(--color-bg)}
}

/* ============================================================
   Content-Schicht: Blog, Referenz-Detail, gekürzte Card (CMS)
   ============================================================ */
/* Mobile-Menü: 7. Punkt (Blog ergänzt) */
.mobile-menu.is-open li:nth-child(7){transition-delay:.38s}

/* Gekürzte Referenz-Card + CTA zur Detailseite */
.profile--card .profile__media{display:block}
.profile__body h3 a{color:inherit;text-decoration:none}
.profile--card:hover .profile__body h3 a{color:var(--color-accent)}
.profile__cta{margin-top:auto;display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-accent);font-weight:500;text-decoration:none}
.profile__cta .icon{width:16px;height:16px;transition:transform var(--dur-fast) var(--ease-out)}
.profile--card:hover .profile__cta .icon{transform:translateX(4px)}

/* Referenz-Detailseite */
.case{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-12);align-items:start}
.case__media{position:relative;border:1px solid var(--color-line);border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:3/2;background:var(--color-bg)}
.case__media img{width:100%;height:100%;object-fit:cover;display:block}
.case__media .profile__tags{position:absolute;left:var(--space-4);top:var(--space-4)}
.case__body{display:flex;flex-direction:column;gap:var(--space-6)}
.case__body .wl{margin-bottom:0}
@media (max-width:900px){.case{grid-template-columns:1fr;gap:var(--space-8)}}

/* Prose (gerenderter Markdown: Blog-Artikel + Case-Body) */
.prose{max-width:70ch;font-size:var(--text-base);line-height:var(--leading-body);color:var(--color-text)}
.prose > * + *{margin-top:var(--space-6)}
.prose h2{font-family:var(--font-display);font-size:var(--text-xl);letter-spacing:var(--tracking-tight);margin-top:var(--space-12)}
.prose h3{font-family:var(--font-display);font-size:var(--text-lg);margin-top:var(--space-8)}
.prose ul,.prose ol{padding-left:var(--space-6)}
.prose li{color:var(--color-text-muted)}
.prose li+li{margin-top:var(--space-2)}
.prose strong{color:var(--color-text);font-weight:600}
.prose a{color:var(--color-accent);text-decoration:underline;text-underline-offset:2px}
.prose blockquote{border-left:2px solid var(--color-primary);padding-left:var(--space-4);font-family:var(--font-display);font-weight:600;color:var(--color-text);font-size:var(--text-lg)}
.prose code{font-family:var(--font-mono);font-size:.9em;background:var(--color-surface-2);padding:2px 6px;border-radius:var(--radius-sm)}

/* Blog-Artikel-Kopf */
.article__head{padding:calc(var(--space-16) + var(--space-8)) 0 var(--space-8);border-bottom:1px solid var(--color-line)}
.article__meta{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-3);font-family:var(--font-mono);font-size:var(--text-sm);margin-bottom:var(--space-6)}
.article__back{color:var(--color-text-muted);text-decoration:none}
.article__back:hover{color:var(--color-accent)}
.article__head h1{font-size:var(--text-3xl);letter-spacing:var(--tracking-tight);max-width:22ch}
.article__head .lead{margin-top:var(--space-4);max-width:60ch}
.article__body{padding-block:var(--space-12)}

/* Blog-Index + Homepage-News: Karten-Grid */
.post-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-8)}
.post-grid--3{grid-template-columns:repeat(3,1fr)}
.post-card{border:1px solid var(--color-line);border-radius:var(--radius-lg);background:var(--color-surface)}
.post-grid .post-card{transition:opacity var(--dur-slow) var(--ease-out),transform var(--dur-base) var(--ease-emphasized),box-shadow var(--dur-base) var(--ease-emphasized),border-color var(--dur-base) var(--ease-emphasized)}
.post-grid .post-card:hover{transform:translateY(-4px);border-color:var(--color-line-strong);box-shadow:var(--shadow-md)}
.post-card__link{display:flex;flex-direction:column;height:100%;text-decoration:none;color:inherit}
.post-card__media{aspect-ratio:16/9;overflow:hidden;background:var(--color-bg);border-bottom:1px solid var(--color-line)}
.post-card__media img{width:100%;height:100%;object-fit:cover;display:block;transition:transform var(--dur-slow) var(--ease-out)}
.post-card:hover .post-card__media img{transform:scale(1.04)}
.post-card__text{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-8);flex:1}
.post-card__meta{display:flex;align-items:center;gap:var(--space-3);font-family:var(--font-mono);font-size:var(--text-xs)}
.post-card__cat{text-transform:uppercase;letter-spacing:.06em;color:var(--color-primary)}
.post-card__meta time{color:var(--color-text-muted)}
.post-card h3{font-size:var(--text-xl);letter-spacing:var(--tracking-tight)}
.post-card__more{margin-top:auto;display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-accent)}
.post-card__more .icon{width:16px;height:16px;transition:transform var(--dur-fast) var(--ease-out)}
.post-card:hover .post-card__more .icon{transform:translateX(4px)}
/* Homepage „Neueste Artikel": Full-Bleed-Slider (horizontal scroll-snap, library-frei) */
.news-viewport{overflow-x:auto;overflow-y:hidden;touch-action:pan-x;scroll-snap-type:x proximity;scroll-padding-left:max(var(--container-gutter),calc((100% - var(--container-max)) / 2 + var(--container-gutter)));scrollbar-width:none;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;padding-block:var(--space-2) var(--space-4)}
.news-viewport::-webkit-scrollbar{display:none}
.news-track{display:flex;gap:var(--space-8);padding-left:max(var(--container-gutter),calc((100% - var(--container-max)) / 2 + var(--container-gutter)));padding-right:0}
.news-track::after{content:"";flex:none;width:max(var(--container-gutter),calc((100vw - var(--container-max)) / 2 + var(--container-gutter) - var(--space-8)))}
.news-track>.post-card{flex:0 0 min(86vw,360px);scroll-snap-align:start;transition:transform var(--dur-base) var(--ease-emphasized),box-shadow var(--dur-base) var(--ease-emphasized),border-color var(--dur-base) var(--ease-emphasized)}
.news-track>.post-card:hover{transform:translateY(-4px);border-color:var(--color-line-strong);box-shadow:var(--shadow-md)}
@media (max-width:900px){.post-grid--3{grid-template-columns:repeat(2,1fr)}}
@media (max-width:760px){.post-grid,.post-grid--3{grid-template-columns:1fr}}

/* ============================================================
   Referenz-Detail (Case-Study-Layout)
   ============================================================ */
.case-hero{padding:calc(var(--space-16) + var(--space-8)) 0 var(--space-8)}
.case-hero__back{display:inline-flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-8);font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-text-muted);text-decoration:none}
.case-hero__back .icon{width:16px;height:16px;transition:transform var(--dur-fast) var(--ease-out)}
.case-hero__back:hover{color:var(--color-accent)}
.case-hero__back:hover .icon{transform:translateX(-3px)}
.case-hero__title{font-size:var(--text-3xl);letter-spacing:var(--tracking-tight);line-height:var(--leading-tight);max-width:20ch;margin-top:var(--space-3)}
.case-hero__lead{margin-top:var(--space-5);max-width:62ch}
.case-hero__tags{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-6);padding:0;list-style:none}
.case-hero__tags li{font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);border:1px solid var(--color-line);border-radius:var(--radius-md);padding:5px 10px}
.case-cover{padding-bottom:var(--space-8)}
.case-cover__frame{position:relative;margin:0;border:1px solid var(--color-line);border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:16/9;background:var(--color-bg)}
.case-cover__frame img{width:100%;height:100%;object-fit:cover;display:block}
.case-grid{display:grid;grid-template-columns:300px minmax(0,1fr);gap:var(--space-16);align-items:start}
.case-aside{position:sticky;top:var(--space-24);display:flex;flex-direction:column;gap:var(--space-6)}
.case-facts{border:1px solid var(--color-line);border-radius:var(--radius-lg);background:var(--color-surface);padding:var(--space-6)}
.case-facts__h{font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.12em;color:var(--color-text-muted);margin-bottom:var(--space-5)}
.case-fact{padding-block:var(--space-4);border-top:1px solid var(--color-line)}
.case-fact:first-of-type{border-top:0;padding-top:0}
.case-fact dt{font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--color-primary);margin-bottom:var(--space-2)}
.case-fact dd{color:var(--color-text);margin:0;font-weight:500}
.case-leistungen{list-style:none;padding:0;display:flex;flex-direction:column;gap:var(--space-2);margin:0;font-weight:400}
.case-leistungen li{display:flex;gap:var(--space-3);color:var(--color-text-muted);font-size:var(--text-sm)}
.case-leistungen li::before{content:"";flex:none;width:6px;height:6px;margin-top:.55em;border-radius:50%;background:var(--color-primary)}
.case-aside .wl{align-self:flex-start;margin-bottom:0}
.case-aside__cta{justify-content:center}
.case-quote{margin:var(--space-12) 0 0;padding:var(--space-8);border:0;border-left:3px solid var(--color-primary);background:var(--color-surface);border-radius:0 var(--radius-lg) var(--radius-lg) 0}
.case-quote p{font-family:var(--font-display);font-weight:600;font-size:var(--text-xl);line-height:var(--leading-snug);color:var(--color-text);margin:0}
.case-quote cite{display:block;margin-top:var(--space-4);font-family:var(--font-mono);font-size:var(--text-sm);font-style:normal;color:var(--color-text-muted)}
.section--tint{background:var(--color-surface-2)}
@media (max-width:900px){
  .case-grid{grid-template-columns:1fr;gap:var(--space-8)}
  .case-aside{position:static;flex-direction:column}
  .case-cover__frame{aspect-ratio:3/2}
  .case-hero__title{font-size:var(--text-2xl)}
}

/* Blog-Artikel-Cover + Inline-Bilder im Prose-Text */
.article__cover{margin:var(--space-12) 0 0;border:1px solid var(--color-line);border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:16/9;background:var(--color-bg)}
.article__cover img{width:100%;height:100%;object-fit:cover;display:block}
.prose img{display:block;max-width:100%;height:auto;margin:var(--space-6) auto var(--space-2);border:1px solid var(--color-line);border-radius:var(--radius-md);background:var(--color-surface)}
.prose p:has(> img){text-align:center;margin-top:var(--space-8)}
.prose p:has(> img) em{font-style:normal;font-size:var(--text-sm);color:var(--color-text-muted)}
