/* ============================================================
   MOREMEDIA® — D11 Theme Refresh
   Sanftes, modernes Update im bestehenden Stil.
   Restyles the existing Drupal markup. No content changes.
   ============================================================ */

/* ---------- Fonts ---------- */
@font-face{font-family:'Volte';font-weight:400;font-style:normal;font-display:swap;
  src:url('fonts/37A2EE_1_0.woff2') format('woff2'),url('fonts/37A2EE_1_0.woff') format('woff');}
@font-face{font-family:'Volte';font-weight:700;font-style:normal;font-display:swap;
  src:url('fonts/37A2EE_0_0.woff2') format('woff2'),url('fonts/37A2EE_0_0.woff') format('woff');}
@font-face{font-family:'Scto Grotesk A';font-weight:400;font-style:normal;font-display:optional;
  src:url('fonts/Scto_Grotesk_A_Regular.woff') format('woff');}
@font-face{font-family:'Scto Grotesk A';font-weight:500;font-style:normal;font-display:optional;
  src:url('fonts/Scto_Grotesk_A_Medium.woff') format('woff');}
@font-face{font-family:'Scto Grotesk A';font-weight:700;font-style:normal;font-display:optional;
  src:url('fonts/Scto_Grotesk_A_Bold.woff') format('woff');}
/* Icon font (live from moremedia.at) */
@font-face{font-family:'moremedia';font-display:block;
  src:url('/assets/fonts/moremedia.woff') format('woff'),url('/assets/fonts/moremedia.ttf') format('truetype');}

/* ---------- Tokens ---------- */
:root{
  --ink:#15140F;          /* warm near-black */
  --ink-2:#3a382f;
  --paper:#ffffff;
  --paper-warm:#F7F5F0;   /* light warm beige */
  --paper-warm-2:#F0EDE6;
  --muted:#8A847B;        /* warm gray (orig #87807c) */
  --muted-2:#B6B0A6;
  --line:rgba(21,20,15,.13);
  --line-strong:rgba(21,20,15,.26);
  --dark:#151412;         /* the single anthracite tone */
  --dark-soft:#151412;
  --on-dark-muted:#A8A296;
  --accent:#15140F;
  --r-sm:6px; --r-md:10px; --r-lg:18px; --r-pill:999px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --container:1500px;
  --pad:clamp(20px,5vw,92px);
  --sec-y:clamp(72px,11vh,168px);
  --lp-eyebrow-gap:clamp(48px,5.5vw,78px);
  --font-display:'Scto Grotesk A',-apple-system,BlinkMacSystemFont,sans-serif;
  --font-ui:'Scto Grotesk A',-apple-system,BlinkMacSystemFont,sans-serif;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scrollbar-gutter:stable;}
body{margin:0;font-family:var(--font-ui);font-weight:400;color:var(--ink);
  background:var(--paper);font-size:19px;line-height:1.68;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;overflow-x:hidden;}
img,video{max-width:100%;height:auto;display:block;border:0;}
a{color:inherit;text-decoration:none;transition:color .25s var(--ease),opacity .25s var(--ease);}
h1,h2,h3,h4,h5,h6,p,ul,ol,figure{margin:0;}
ul{padding:0;list-style:none;}
button{font-family:inherit;}
::selection{background:var(--ink);color:#fff;}
:focus-visible{outline:2px solid var(--ink);outline-offset:3px;}
.clearfix::after{content:"";display:table;clear:both;}
[class^="icon-"],[class*=" icon-"]{font-family:'moremedia'!important;font-style:normal;line-height:1;speak:none;}
i.mm-svg{display:inline-flex;align-items:center;justify-content:center;width:1em;height:1em;}
i.mm-svg::before{content:none!important;}
i.mm-svg svg{width:100%;height:100%;display:block;}

/* Hide noscript / drupal cruft, ensure content visible */
#noscript{display:none!important;}
#page-wrapper{display:block!important;}
[class*="redir-link"]{cursor:pointer;}

/* ---------- Layout primitives ---------- */
.section{width:100%;max-width:var(--container);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad);}
#page,#main-wrapper,#main,.region-content,#block-system-main,#block-system-main>div,
.node-full,#article-wrapper,#content-wrapper{width:100%;float:none;}
#main-wrapper{padding-top:0;}

/* generic section vertical rhythm */
#intro,#einleitung,#einleitungNeu,#leistungenNeu,#services,#mission,#referenzen_slider,
#galerie,#kunden,#customers,#fakten,#kontakt{padding-block:var(--sec-y);position:relative;}
#services,#kunden,#customers,#fakten{background:var(--paper-warm);}

/* ---------- Type ---------- */
.h1,h1.title,h2.title,h1.h1,h2.h1,h3.h1{font-family:var(--font-display);font-weight:700;
  letter-spacing:-.02em;line-height:1.04;color:var(--ink);text-wrap:balance;}
.subtitle,.untertitel,.label,.kunde{font-family:var(--font-ui);font-weight:500;
  text-transform:uppercase;letter-spacing:.16em;font-size:.74rem;color:var(--muted);}
.subtitle,.untertitel{margin-bottom:clamp(18px,2.4vw,30px);}

/* hero headline scale */
#intro>.section>.title,#einleitung h1,#einleitungNeu h1,#leistungenNeu h1,#kontakt h1.title,
#einleitung .title.big{font-size:clamp(2.5rem,6vw,5.8rem);line-height:1.12;}
/* Headline darf nicht unter das runde „Ausgewählte Projekte"-Badge laufen (nur wo es sichtbar ist) */
@media(min-width:861px){#intro>.section>.title{padding-right:clamp(200px,19vw,300px);}}
/* section headlines */
#services>.section>.title,#mission .h1,#referenzen_slider .h1,#fakten .h1,#customers .section>.title{
  font-size:clamp(1.9rem,3.6vw,3.4rem);line-height:1.1;max-width:18ch;}
#mission .h1,#referenzen_slider .h1{max-width:22ch;}

/* rich text body — tuned for comfortable reading */
.text,.body{font-size:19px;line-height:1.78;color:var(--ink);
  max-width:66ch;letter-spacing:.002em;font-weight:400;}
.text p,.body p{margin-bottom:1.15em;}
.text p:last-child,.body p:last-child{margin-bottom:0;}
.text h2,.text h2.less-margin{font-family:var(--font-display);font-weight:700;color:var(--ink);
  font-size:clamp(1.25rem,2vw,1.7rem);letter-spacing:-.01em;line-height:1.2;margin:1.8em 0 .6em;}
.text h2:first-child{margin-top:0;}
.text ul{margin:1.1em 0;display:flex;flex-direction:column;gap:.55em;}
.text ul li{position:relative;padding-left:1.4em;}
/* Einheitlicher Aufzählungspunkt site-weit: kleiner gefüllter Punkt (siehe auch
   #node-legal .legal-body und .art-body — identischer Marker für konsistente Listen). */
.text ul li::before{content:"";position:absolute;left:0;top:.66em;width:6px;height:6px;border-radius:50%;background:var(--muted-2);}
/* in-body links read like the surrounding text; underline only on hover/focus */
.text a,.body a,a.alinks-link{color:inherit;text-decoration:none;
  text-decoration-thickness:1px;text-underline-offset:3px;
  transition:text-decoration-color .2s var(--ease);}
.text a:hover,.body a:hover,a.alinks-link:hover,
.text a:focus-visible,.body a:focus-visible,a.alinks-link:focus-visible{text-decoration:underline;text-decoration-color:currentColor;}

/* ---------- Buttons ---------- */
a.button,a.button-big,.button-wrapper>a,a.show,a.typeform,a.website,.show-more a,.show-more>a{
  display:inline-flex;align-items:center;gap:.7em;font-family:var(--font-ui);font-weight:500;
  font-size:.95rem;letter-spacing:.01em;padding:1.05em 2.1em;border:1.5px solid var(--ink);
  border-radius:var(--r-pill);color:var(--ink);background:transparent;cursor:pointer;
  transition:background .35s var(--ease),color .35s var(--ease),border-color .35s var(--ease);}
a.button:hover,a.button-big:hover,.button-wrapper>a:hover,a.show:hover,a.typeform:hover,
a.website:hover,.show-more a:hover{background:var(--ink);color:#fff;}
a.button.white{border-color:#fff;color:#fff;}
a.button.white:hover{background:#fff;color:var(--ink);}
.button-wrapper{margin-top:clamp(34px,5vw,64px);}
.typeform-wrapper{margin-top:clamp(28px,4vw,46px);}

/* ---------- Header ---------- */
#header{position:fixed;top:0;left:0;width:100%;z-index:1000;
  transition:transform .4s var(--ease),background .22s var(--ease),backdrop-filter .22s var(--ease),box-shadow .3s var(--ease),border-color .22s var(--ease);
  border-bottom:1px solid transparent;}
#header .section{display:flex;align-items:center;justify-content:space-between;
  padding-block:clamp(16px,2.4vh,26px);}
#logo{display:inline-flex;align-items:center;line-height:1;z-index:2;}
#logo .logo-img{height:21px;width:auto;}
#logo .logo-white{display:block;}
#logo .logo-black{display:none;}
#secondary-menu ul,#main-menu .menu{display:flex;align-items:center;gap:clamp(20px,2.6vw,42px);margin:0;}
#secondary-menu ul li{margin:0;}
#secondary-menu a{font-family:var(--font-ui);font-weight:500;font-size:1rem;color:var(--ink);
  display:inline-flex;align-items:baseline;gap:.35em;position:relative;padding:.2em 0;}
#secondary-menu a .dot{font-size:.62rem;font-weight:500;color:var(--muted);transform:translateY(-.6em);
  font-family:var(--font-ui);}
#secondary-menu a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;
  background:currentColor;transition:width .3s var(--ease);}
#secondary-menu a:hover::after{width:100%;}
#secondary-menu{display:none;}

/* default chrome: dark logo + burger on light backgrounds */
#header #logo .logo-black{display:block;}
#header #logo .logo-white{display:none;}
#header #burger span{background:var(--ink);}
#header #menu-icon .menu-label{color:var(--ink);}
/* over dark heroes (top, not scrolled) → white chrome */
body.menu-white #header:not(.small) #logo .logo-black,
body.node-type-referenz-neu #header:not(.small) #logo .logo-black,
html[data-mode="dark"] #header:not(.small) #logo .logo-black{display:none;}
body.menu-white #header:not(.small) #logo .logo-white,
body.node-type-referenz-neu #header:not(.small) #logo .logo-white,
html[data-mode="dark"] #header:not(.small) #logo .logo-white{display:block;}
body.menu-white #header:not(.small) #burger span,
body.node-type-referenz-neu #header:not(.small) #burger span,
html[data-mode="dark"] #header:not(.small) #burger span{background:#fff;}
body.menu-white #header:not(.small) #menu-icon .menu-label,
body.node-type-referenz-neu #header:not(.small) #menu-icon .menu-label,
html[data-mode="dark"] #header:not(.small) #menu-icon .menu-label{color:#fff;}
/* glass when scrolled */
#header.small{background:rgba(255,255,255,.82);backdrop-filter:saturate(1.4) blur(16px);
  -webkit-backdrop-filter:saturate(1.4) blur(16px);border-bottom-color:var(--line);}
html[data-mode="dark"] #header.small{background:rgba(21,20,15,.8);border-bottom-color:var(--line);}
#header.small #logo .logo-black{display:block;}
#header.small #logo .logo-white{display:none;}
html[data-mode="dark"] #header.small #logo .logo-black{display:none;}
html[data-mode="dark"] #header.small #logo .logo-white{display:block;}
#header.small #burger span{background:var(--ink);}
#header.small #menu-icon .menu-label{color:var(--ink);}
/* Tweak: header 'pill' — on scroll the bar/logo go, only the menu-icon stays as a frosted pill */
#logo{transition:opacity .14s var(--ease);}
html[data-headerstyle="pill"] #header.small{background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;border-bottom-color:transparent;}
html[data-headerstyle="pill"] #header.small .section{position:relative;}
html[data-headerstyle="pill"] #header.small .section::before{content:"";position:absolute;z-index:-1;
  top:50%;transform:translateY(-50%);left:calc(var(--pad) - 16px);right:calc(var(--pad) - 16px);
  height:clamp(52px,6.5vh,70px);border-radius:var(--r-pill);
  background:rgba(247,245,240,.72);backdrop-filter:blur(14px) saturate(1.4);-webkit-backdrop-filter:blur(14px) saturate(1.4);}
html[data-mode="dark"][data-headerstyle="pill"] #header.small .section::before{background:rgba(21,20,15,.6);}
/* pill mode: never auto-hide — the menu pill stays fixed */
html[data-headerstyle="pill"] #header.hide{transform:none!important;}
html[data-mode="dark"] #header.small #burger span{background:var(--ink);}
html[data-mode="dark"] #header.small #menu-icon .menu-label{color:var(--ink);}
/* auto-hide on scroll down, reveal on scroll up */
/* auto-hide on scroll down, reveal on scroll up (with hysteresis in JS) */
#header.hide{transform:translateY(-100%);}
body.nav-open #header{transform:none;}
/* no glass while the menu overlay is open */
/* menu open: the header keeps its (glass) background — it is NOT faded out, the menu simply overlays it */
/* frosted menu: header stays exactly as-is (its glass is kept, the menu just overlays around it) */

/* burger — visible on ALL viewports, sits above the overlay */
#menu-icon{position:fixed;top:clamp(16px,2.4vh,26px);right:max(var(--pad), calc((100vw - var(--container)) / 2 + var(--pad)));z-index:1002;cursor:pointer;
  display:inline-flex;align-items:center;gap:13px;flex-direction:row-reverse;
  height:auto;transition:transform .4s var(--ease);}
body.hdr-hide:not(.nav-open) #menu-icon{transform:translateY(-160%);}
#menu-icon #burger span{background:var(--ink);}
#menu-icon .menu-label{color:var(--ink);}
body.menu-white:not(.hdr-small) #menu-icon #burger span{background:#fff;}
body.menu-white:not(.hdr-small) #menu-icon .menu-label{color:#fff;}
body.nav-open #menu-icon #burger span{background:#fff;}
body.nav-open #menu-icon .menu-label{color:#fff;}
#menu-icon .burger-ring,#menu-icon .path-burger,#menu-icon svg{display:none;}
#menu-icon .menu-label{font-family:var(--font-ui);font-weight:500;font-size:1.24rem;letter-spacing:.02em;
  transition:color .3s var(--ease);}
#menu-icon .menu-label .lbl-open{display:inline-block;}
#menu-icon .menu-label .lbl-close{display:none;}
#burger{position:relative;width:39px;height:21px;flex:0 0 auto;}
#burger span{position:absolute;left:0;width:100%;height:2.5px;background:#fff;border-radius:2px;
  transition:transform .4s var(--ease),opacity .25s var(--ease),background .3s,width .3s var(--ease);}
#burger span:nth-child(1){top:0;} #burger span:nth-child(2){top:9px;width:72%;} #burger span:nth-child(3){top:18px;}
#menu-icon:hover #burger span:nth-child(2){width:100%;}
/* chrome color handled by mix-blend-mode:difference (always white content) */
/* open state → morph to X, force white on dark overlay (high specificity to beat default chrome) */
body.nav-open #header #burger span{background:#fff;width:100%;}
body.nav-open #header #menu-icon .menu-label{color:#fff;}
/* label stays "Menü" on open so the button keeps its exact position/width */
body.nav-open #menu-icon .menu-label .lbl-open{display:inline-block;}
body.nav-open #menu-icon .menu-label .lbl-close{display:none;}
body.nav-open #burger span:nth-child(1){transform:translateY(9px) rotate(45deg);}
body.nav-open #burger span:nth-child(2){opacity:0;}
body.nav-open #burger span:nth-child(3){transform:translateY(-9px) rotate(-45deg);}

/* ---------- Full-page nav overlay — striking clip-path reveal ---------- */
#navigation-wrapper{position:fixed;inset:0;background:var(--dark);color:#fff;z-index:1001;
  display:flex!important;flex-direction:column;justify-content:center;
  padding:clamp(80px,12vh,150px) 0 clamp(40px,8vh,90px);
  clip-path:circle(0% at var(--nav-x,calc(100% - 90px)) var(--nav-y,46px));pointer-events:none;
  transition:clip-path .85s cubic-bezier(.76,0,.24,1);}
body.nav-open #navigation-wrapper{clip-path:circle(250% at var(--nav-x,calc(100% - 90px)) var(--nav-y,46px));pointer-events:auto;}
#navigation-wrapper{will-change:clip-path;}
/* Tweak: frosted-glass menu instead of solid dark */
html[data-menustyle="frost"] #navigation-wrapper{background:rgba(21,20,15,.5);
  backdrop-filter:blur(22px) saturate(1.3);-webkit-backdrop-filter:blur(22px) saturate(1.3);}
/* over the open menu: no blend, force clean white logo + burger */
body.nav-open #header #logo,body.nav-open #header #menu-icon{mix-blend-mode:normal;}
/* logo turns white only once the reveal circle has reached it (delayed via JS class) */
/* once the reveal has reached the logo, the menu simply covers it (logo fades out) */
body.nav-logo-white #header #logo{opacity:0!important;visibility:hidden;pointer-events:none;transition:opacity .35s var(--ease);}
#navigation-wrapper::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(55% 45% at 68% 22%,rgba(255,255,255,.08),transparent 62%);
  animation:navglow 14s ease-in-out infinite alternate;}
@keyframes navglow{
  0%{transform:translate(-5%,-4%) scale(1.05);opacity:.55;}
  100%{transform:translate(6%,5%) scale(1.18);opacity:1;}}
@media(prefers-reduced-motion:reduce){#navigation-wrapper::before{animation:none;}}
#navigation-wrapper .navigation-container{position:relative;z-index:1;display:flex;flex-direction:column;
  justify-content:space-between;flex:1 1 auto;
  gap:clamp(48px,9vh,150px);max-width:var(--container);margin:0 auto;width:100%;padding-inline:var(--pad);transform:translateZ(0);}
#navigation-wrapper #main-menu .menu{display:flex;flex-direction:column;align-items:flex-start;
  gap:clamp(4px,1vw,12px);counter-reset:navi;}
#navigation-wrapper #main-menu li{overflow:hidden;display:block;}
#navigation-wrapper,.mm-cov{--nav-scale:clamp(1, calc(1 + (100vw - 1600px)/2600px), 1.7);}
#navigation-wrapper::before,.mm-cov::before{display:none!important;}
#navigation-wrapper{--nav-scale-menu:clamp(1, calc(1 + (100vw - 1200px)/1400px), 2.5);}
#navigation-wrapper #main-menu a{position:relative;display:flex;align-items:baseline;gap:clamp(14px,1.6vw,26px);
  font-family:var(--font-display);font-weight:700;color:#fff;white-space:nowrap;
  font-size:calc(clamp(2.7rem,8.6vw,6rem) * var(--nav-scale-menu,1));letter-spacing:-.03em;line-height:1.06;
  opacity:0;transition:opacity .55s var(--ease),color .3s var(--ease);}
#navigation-wrapper #main-menu li{counter-increment:navi;}
#navigation-wrapper #main-menu a::before{content:none;}
#navigation-wrapper #main-menu a:hover{color:var(--muted-2);}
#navigation-wrapper #main-menu a:hover::before{color:#fff;}
/* staggered reveal on open */
body.nav-open #navigation-wrapper #main-menu a{opacity:1;}
body.nav-open #navigation-wrapper #main-menu li:nth-child(1) a{transition-delay:.16s;}
body.nav-open #navigation-wrapper #main-menu li:nth-child(2) a{transition-delay:.24s;}
body.nav-open #navigation-wrapper #main-menu li:nth-child(3) a{transition-delay:.32s;}
body.nav-open #navigation-wrapper #main-menu li:nth-child(4) a{transition-delay:.4s;}
body.nav-open #navigation-wrapper #main-menu li:nth-child(5) a{transition-delay:.48s;}
body.nav-open #navigation-wrapper #main-menu li:nth-child(6) a{transition-delay:.56s;}
#navigation-wrapper .region-header{display:flex;flex-wrap:wrap;gap:clamp(20px,4vw,60px);
  font-size:calc(1.05rem * var(--nav-scale-menu,1));color:var(--on-dark-muted);border-top:1px solid rgba(255,255,255,.16);padding-top:clamp(24px,4vw,40px);
  opacity:0;transform:translateY(20px);transition:opacity .5s var(--ease) .5s,transform .6s var(--ease) .5s;}
body.nav-open #navigation-wrapper .region-header{opacity:1;transform:none;}
#navigation-wrapper .region-header a{color:#fff;}
#navigation-wrapper .region-header a:hover{color:var(--muted-2);}
#navigation-wrapper .email a{font-size:1.2rem;}
@media(prefers-reduced-motion:reduce){
  #navigation-wrapper{transition:none;}
  #navigation-wrapper #main-menu a{transform:none;transition:color .3s;}
  #navigation-wrapper .region-header{transition:none;}
}
#navigation-wrapper .region-header a{color:#fff;}
#navigation-wrapper .region-header a:hover{color:var(--muted-2);}
#navigation-wrapper .email a{font-size:1.2rem;}

/* ---------- Hero (#intro / #einleitung) ---------- */
#intro{position:relative;}
#intro>.section{position:relative;}
/* rotating "Ausgewählte Projekte" badge — anchored to the hero's right edge (like the original) */
#intro .scrolldown{position:absolute;right:var(--pad);top:clamp(160px,23vh,330px);z-index:3;
  margin:0!important;width:clamp(177px,16.5vw,228px);height:clamp(177px,16.5vw,228px);display:block!important;}
/* inline rotating badge: text ring spins, arrow stays static — one element */
#intro .scrolldown .turning-svg{position:absolute;top:0;left:0;width:clamp(177px,16.5vw,228px);height:clamp(177px,16.5vw,228px);color:var(--ink);overflow:visible;}
#intro .scrolldown .turning-svg .ring{transform-box:view-box;transform-origin:center;animation:spin 24s linear infinite;}
#intro .scrolldown .turning-text{fill:var(--ink);font-family:var(--font-ui);font-weight:500;font-size:8.4px;letter-spacing:1.2px;}
html[data-mode="dark"] #intro .scrolldown .turning-svg{color:#fff;}
html[data-mode="dark"] #intro .scrolldown .turning-text{fill:#fff;}
@media(prefers-reduced-motion:reduce){#intro .scrolldown .turning-svg .ring{animation:none;}}
#intro .scrolldown .icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1;
  width:auto!important;height:auto!important;border:0!important;background:none!important;
  font-size:2.85rem;color:var(--ink);display:block;}
#intro .scrolldown:hover .icon{transform:translate(-50%,-50%) translateY(5px);transition:transform .3s var(--ease);}
@media(max-width:860px){#intro .scrolldown{display:none!important;}}
#intro,#einleitung,#leistungenNeu{padding-top:clamp(150px,20vh,260px);}
/* Leistungen-Übersicht: etwas kompakterer Abstand Header → Headline (auf Wunsch) */
#leistungenNeu{padding-top:clamp(112px,14vh,180px);}
/* Sehr kleine Screens: weniger Abstand Header → erster Text, Viewport besser nutzen */
@media(max-width:480px){#intro,#einleitung,#leistungenNeu{padding-top:104px;}}
@media(max-width:380px){#intro,#einleitung,#leistungenNeu{padding-top:88px;}}
#einleitung .scrolldown,#intro .scrolldown,.scrolldown{display:inline-flex;align-items:center;gap:1em;
  margin-top:clamp(40px,6vw,80px);color:var(--muted);font-size:.85rem;letter-spacing:.04em;}
.scrolldown .icon{width:46px;height:46px;border:1.5px solid var(--line-strong);border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--ink);
  transition:transform .3s var(--ease),background .3s;}
.scrolldown:hover .icon{transform:translateY(5px);}
.scrolldown img.turning{width:86px;height:86px;animation:spin 16s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.scroll-line{display:none;}

/* Home references grid */
.references{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(16px,2.2vw,30px);
  margin-top:clamp(40px,6vw,72px);}
.references .views-row{margin:0;}

/* project card (references + galerie) */
.views-row a.link,.swiper-slide a.link{display:block;color:inherit;}
.views-row .bild,.swiper-slide .bild{position:relative;overflow:hidden;border-radius:var(--r-md);
  background:var(--paper-warm-2);aspect-ratio:16/10;}
.views-row .video-container,.views-row .bild>div,.swiper-slide .video-container{width:100%;height:100%;}
.views-row video,.views-row .bild img,.views-row .lottie,.swiper-slide video{
  width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease);}
.views-row a.link:hover video,.views-row a.link:hover img{transform:scale(1.045);}
.views-row .content-html{display:flex;align-items:baseline;justify-content:space-between;gap:1em;
  padding:clamp(16px,1.6vw,22px) 2px 0;}
.views-row .content-html .kunde{order:0;}
.views-row .content-html .title{font-family:var(--font-display);font-weight:700;font-size:clamp(1.15rem,1.7vw,1.5rem);
  letter-spacing:-.01em;line-height:1.18;color:var(--ink);flex:1;text-transform:none;}
.views-row .kunde{font-size:.72rem;}
.views-row .read-more{margin-left:auto;width:34px;height:34px;border:1.5px solid var(--line-strong);
  border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--ink);
  flex:0 0 auto;transition:transform .35s var(--ease),background .35s,color .35s;font-weight:300;}
.views-row a.link:hover .read-more{background:var(--ink);color:#fff;transform:rotate(90deg);}
.content-html .title{order:1;}

/* galerie grid */
.galerie{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(20px,3vw,52px);}
.galerie .views-row{margin:0;}
.galerie .views-row:nth-child(4n+1),.galerie .views-row:nth-child(4n){grid-column:span 1;}

/* ---------- Services (#services) ---------- */
.leistungen{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,90px);
  margin-top:clamp(40px,6vw,80px);align-items:start;}
.leistungen .label{font-size:.74rem;text-transform:uppercase;letter-spacing:.16em;color:var(--muted);
  padding-bottom:14px;margin-bottom:6px;border-bottom:1px solid var(--line);}
.leistungen .items{display:flex;flex-direction:column;}
.leistungen .item a.link{display:flex;align-items:center;justify-content:space-between;gap:1em;
  padding:clamp(16px,1.6vw,22px) 0;border-bottom:1px solid var(--line);}
.leistungen .item h4.title{font-family:var(--font-display);font-weight:700;font-size:clamp(1.25rem,2vw,1.85rem);
  letter-spacing:-.01em;color:var(--ink);transition:transform .3s var(--ease);text-transform:none;}
.leistungen .item a.link:hover h4.title{transform:translateX(10px);}
.leistungen .item .read-more{width:32px;height:32px;border:1.5px solid var(--line-strong);border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:var(--ink);font-weight:300;font-size:1.1rem;
  transition:background .3s,color .3s,transform .3s var(--ease);}
.leistungen .item a.link:hover .read-more{background:var(--ink);color:#fff;transform:rotate(90deg);}

/* leistungen index (#leistungenNeu) */
#leistungenNeu .leistungen{display:grid;grid-template-columns:repeat(2,1fr);gap:0
  clamp(30px,5vw,80px);margin-top:clamp(46px,6vw,84px);}
#leistungenNeu .leistung a.link{display:grid;grid-template-columns:auto 1fr auto;align-items:center;
  gap:clamp(18px,2.4vw,34px);padding:clamp(20px,2.4vw,32px) 0;border-bottom:1px solid var(--line);}
#leistungenNeu .leistung .count{font-family:var(--font-ui);font-weight:500;font-size:.9rem;color:var(--muted);
  font-variant-numeric:tabular-nums;}
#leistungenNeu .leistung h4.title{font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.5rem,2.6vw,2.4rem);letter-spacing:-.015em;color:var(--ink);text-transform:none;
  transition:transform .3s var(--ease);}
#leistungenNeu .leistung a.link:hover h4.title{transform:translateX(12px);}
#leistungenNeu .leistung .pfeil{width:30px;opacity:.45;transition:opacity .3s,transform .3s var(--ease);}
#leistungenNeu .leistung a.link:hover .pfeil{opacity:1;transform:translateX(8px);}
#leistungenNeu .leistung .pfeil img{width:100%;}

/* ---------- Swiper slider (#referenzen_slider) ---------- */
.swiper-container{margin-top:clamp(34px,5vw,60px);overflow:hidden;position:relative;}
.swiper-wrapper{display:flex;transition:transform .7s var(--ease);will-change:transform;}
.swiper-slide{flex:0 0 clamp(280px,42vw,640px);margin-right:clamp(16px,2vw,30px);}
.swiper-slide .bild{aspect-ratio:16/10;}
.swiper-pagination{display:flex;gap:8px;margin-top:26px;justify-content:flex-start;}
.swiper-pagination .bullet{width:8px;height:8px;border-radius:50%;background:var(--line-strong);cursor:pointer;
  transition:background .3s,width .3s var(--ease);}
.swiper-pagination .bullet.active{background:var(--ink);width:26px;border-radius:6px;}

/* ---------- Customers logos (#customers) ---------- */
#customers .customers.desktop{display:flex;flex-direction:column;gap:clamp(28px,4vw,54px);
  margin-top:clamp(40px,6vw,72px);}
#customers .row-1,#customers .row-2,#customers .row-3{display:grid;
  grid-template-columns:repeat(6,1fr);gap:clamp(20px,3vw,48px);align-items:center;}
#customers .logo{display:flex;align-items:center;justify-content:center;}
#customers .logo>div{width:100%;display:flex;align-items:center;justify-content:center;}
#customers .logo img{max-height:42px;width:auto;object-fit:contain;filter:grayscale(1);opacity:.55;
  transition:filter .4s var(--ease),opacity .4s var(--ease);mix-blend-mode:multiply;}
#customers .logo:hover img{filter:grayscale(0);opacity:1;}
#customers .customers.mobile{display:none;}

/* kunden text rows — mehrzeilige Laufschrift (marquee) */
.kunden{margin-top:clamp(34px,4vw,56px);display:flex;flex-direction:column;gap:clamp(8px,1vw,16px);
  --marquee-dur:46s;}
.kunden .row{overflow:hidden;width:100%;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);}
.kunden .row .items{display:flex;flex-wrap:nowrap;width:max-content;gap:0;
  animation:mm-marquee var(--marquee-dur,46s) linear infinite;will-change:transform;}
.kunden .row[data-reversed] .items{animation-direction:reverse;}
.kunden:hover .row .items{animation-play-state:paused;}
.kunden .item{font-family:var(--font-display);font-weight:700;font-size:clamp(1.3rem,2.6vw,2.5rem);
  letter-spacing:-.02em;color:var(--muted-2);transition:color .3s var(--ease);flex:0 0 auto;
  padding:0 clamp(20px,2.4vw,40px);white-space:nowrap;display:flex;align-items:center;gap:clamp(20px,2.4vw,40px);}
.kunden .item::after{content:"";width:5px;height:5px;border-radius:50%;background:currentColor;opacity:.5;flex:0 0 auto;}
.kunden .item a{color:inherit;}
.kunden .item a:hover,.kunden .item:hover{color:var(--ink);}
@keyframes mm-marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}
@media(prefers-reduced-motion:reduce){
  .kunden .row .items{animation:none;flex-wrap:wrap;width:auto;}
  .kunden .row{-webkit-mask-image:none;mask-image:none;}
}

/* ---------- Fakten / counters (#fakten) ---------- */
#fakten .items{display:grid;grid-template-columns:repeat(5,1fr);gap:clamp(20px,3vw,40px);}
#fakten .item{display:flex;flex-direction:column;gap:.4em;}
#fakten .number{font-family:var(--font-display);font-weight:700;color:var(--ink);
  font-size:clamp(2.6rem,6vw,5rem);line-height:1;letter-spacing:-.03em;font-variant-numeric:tabular-nums;}
#fakten .titel{font-size:.92rem;color:var(--muted);line-height:1.4;}
@media(max-width:860px){#fakten .items{grid-template-columns:repeat(2,1fr);}}

/* Referenz-Detailseiten: Original-Hintergrundfarben der Rows beibehalten (wie Live) — keine Überschreibung */

/* Tweak: Fakten als Apple-Keynote-Zusammenfassung (data-fakten="apple") */
html[data-fakten="apple"] #fakten .items{grid-template-columns:repeat(5,minmax(0,1fr));gap:0;
  background:var(--paper-warm);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;}
html[data-fakten="apple"] #fakten .item{padding:clamp(30px,3.6vw,60px) clamp(18px,1.8vw,32px);text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:.45em;border-right:1px solid var(--line);}
html[data-fakten="apple"] #fakten .item:last-child{border-right:0;}
html[data-fakten="apple"] #fakten .item::before{content:none;}
html[data-fakten="apple"] #fakten .item:nth-child(1){--ic:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Cpath d='M12 7v5l3 2'/%3E%3C/svg%3E");}
html[data-fakten="apple"] #fakten .item:nth-child(2){--ic:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Cpath d='M8 12l3 3 5-6'/%3E%3C/svg%3E");}
html[data-fakten="apple"] #fakten .item:nth-child(3){--ic:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3l7 3v5c0 4-3 7-7 9-4-2-7-5-7-9V6z'/%3E%3Cpath d='M9 12l2 2 4-4'/%3E%3C/svg%3E");}
html[data-fakten="apple"] #fakten .item:nth-child(4){--ic:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 12a8 8 0 1 1-2.3-5.7'/%3E%3Cpath d='M20 4v4h-4'/%3E%3C/svg%3E");}
html[data-fakten="apple"] #fakten .item:nth-child(5){--ic:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3l2.6 5.3 5.8.8-4.2 4.1 1 5.8L12 16.3 6.8 19l1-5.8L3.6 9.1l5.8-.8z'/%3E%3C/svg%3E");}
html[data-fakten="apple"] #fakten .number{font-size:clamp(2.6rem,5vw,4.4rem);line-height:1;}
html[data-fakten="apple"] #fakten .titel{font-size:.82rem;color:var(--muted);max-width:15ch;line-height:1.45;}
@media(max-width:860px){
  html[data-fakten="apple"] #fakten .items{grid-template-columns:repeat(2,1fr);}
  html[data-fakten="apple"] #fakten .item:nth-child(2n){border-right:0;}
  html[data-fakten="apple"] #fakten .item{border-bottom:1px solid var(--line);}
}
/* Agentur hat 6 Fakten. Die 6. Kachel (Google-Bewertung) NUR anzeigen, wenn das
   Raster ohnehin mehrzeilig ist (Smartphone/2-spaltig). In den einzeiligen Breiten
   (5 nebeneinander) ausblenden, damit keine Waise in einer zweiten Reihe entsteht. */
#node-agentur #fakten .item:nth-child(6){display:none;}
@media(max-width:860px){
  #node-agentur #fakten .item:nth-child(6){display:flex;}
  html[data-fakten="apple"] #node-agentur #fakten .item:nth-child(n+5){border-bottom:0;}
}

/* ---------- Mission section ---------- */
#mission .mission{display:block;}
#mission .text{margin-top:clamp(44px,5.5vw,82px);}

/* ---------- FAQ accordion (.faq-item) ---------- */
.faq-item{border-bottom:1px solid var(--line);}
.faq-item:first-child{border-top:0;}
.faq-item:last-child{border-bottom:0;}
.faq-item>p.less-margin,.faq-item>p.small:first-child,.faq-item>p:first-child{cursor:pointer;
  font-family:var(--font-display);font-weight:700;font-size:clamp(1.1rem,1.7vw,1.45rem);
  letter-spacing:-.01em;color:var(--ink);padding:clamp(20px,2.2vw,30px) 56px clamp(20px,2.2vw,30px) 0;
  position:relative;margin:0;line-height:1.3;}
.faq-item>p:first-child strong{font-weight:700;}
.faq-item>p:first-child::after{content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);
  font-family:var(--font-ui);font-weight:400;font-size:1.7rem;color:var(--muted);transition:transform .35s var(--ease);}
.faq-item.open>p:first-child::after{content:"+";transform:translateY(-50%) rotate(45deg);}
.faq-item .answer{display:grid;grid-template-rows:0fr;overflow:hidden;opacity:0;color:var(--ink-2);font-size:1.05rem;line-height:1.7;
  transition:grid-template-rows .42s var(--ease),opacity .32s var(--ease),padding .32s var(--ease);padding:0;}
.faq-item .answer>*{min-height:0;margin:0;}
.faq-item.open .answer{grid-template-rows:1fr;opacity:1;padding:0 0 clamp(22px,2.4vw,30px);}
.faq-item .answer:empty{display:none;}

/* ---------- Kontakt page (#kontakt) ---------- */
#kontakt{padding-top:clamp(160px,22vh,280px);background:var(--dark);color:#fff;min-height:88vh;
  display:flex;align-items:center;}
#kontakt .content{max-width:var(--container);margin:0 auto;padding-inline:var(--pad);width:100%;}
#kontakt h1.title{color:#fff;font-size:clamp(2.6rem,7vw,6rem);}
#kontakt .body{color:var(--on-dark-muted);font-size:clamp(1.1rem,1.5vw,1.4rem);max-width:46ch;
  margin-top:clamp(24px,3vw,40px);}
#kontakt .body a{color:#fff;text-decoration-color:rgba(255,255,255,.4);}
#kontakt .typeform{display:flex;flex-wrap:wrap;gap:16px;margin-top:clamp(32px,4vw,52px);}
#kontakt .kontaktdaten{display:flex;flex-wrap:wrap;gap:clamp(30px,6vw,90px);margin-top:clamp(40px,6vw,72px);
  padding-top:clamp(30px,4vw,46px);border-top:1px solid rgba(255,255,255,.16);font-size:1.1rem;line-height:1.7;}
#kontakt .kontaktdaten a{color:#fff;}
#kontakt .kontaktdaten a:hover{color:var(--muted-2);}
.block-social-media{display:flex;gap:14px;}
#kontakt+.block-social-media,#kontakt .block-social-media{margin-top:30px;}
.block-social-media a{width:46px;height:46px;border:1.5px solid rgba(255,255,255,.28);border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.05rem;}
.block-social-media a:hover{background:#fff;color:var(--ink);}
.block-social-media a span{display:none;}

/* ---------- Bottom CTA (#bottom #block-kontakt) ---------- */
#bottom{background:var(--dark);color:#fff;}
#bottom .section{max-width:none;}
#block-kontakt .content{padding:0;}
#block-kontakt a.wrapper{display:flex;align-items:center;justify-content:space-between;gap:3vw;
  padding:clamp(70px,12vw,170px) var(--pad);max-width:var(--container);margin:0 auto;flex-wrap:wrap;}
#block-kontakt h4.title{font-family:var(--font-display);font-weight:700;color:#fff;
  font-size:clamp(2.4rem,7vw,6rem);letter-spacing:-.02em;line-height:1.0;text-transform:none;}
#block-kontakt .contact{display:flex;align-items:center;gap:1.4em;}
#block-kontakt .contact .icon{width:64px;height:64px;border:1.5px solid rgba(255,255,255,.35);border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:#fff;
  transition:transform .35s var(--ease),background .35s,color .35s;}
#block-kontakt a.wrapper:hover .contact .icon{background:#fff;color:var(--ink);transform:translateX(6px);}
#block-kontakt img.turning{width:96px;height:96px;animation:spin 18s linear infinite;}
#block-kontakt .contact .turning-svg{width:96px;height:96px;display:block;color:#fff;overflow:visible;}
#block-kontakt .contact .turning-svg .ring{transform-box:view-box;transform-origin:center;animation:spin 22s linear infinite;}
#block-kontakt .contact .turning-svg .disc{fill:none;stroke:none;}
#block-kontakt .contact .turning-text{fill:#fff;font-family:var(--font-ui);font-weight:500;font-size:8.4px;letter-spacing:1.2px;}
@media(prefers-reduced-motion:reduce){#block-kontakt .contact .turning-svg .ring{animation:none;}}

/* ---------- Footer ---------- */
#footer{background:var(--dark-soft);color:#fff;padding-block:clamp(54px,7vw,96px);}
#footer .section{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:clamp(30px,5vw,70px);align-items:start;}
#footer .region-footer{display:contents;}
#footer .kontaktdaten p{color:var(--on-dark-muted);line-height:1.9;font-size:1.05rem;}
#footer .kontaktdaten a{color:#fff;}
#footer .kontaktdaten .trenner{display:none;}
#footer .block-social-media{gap:12px;}
#footer #block-menu-menu-fusszeile .menu{display:flex;flex-direction:column;gap:12px;}
#footer #block-menu-menu-fusszeile a,#footer #block-menu-menu-fusszeile .redir-link{color:var(--on-dark-muted);font-size:1.02rem;}
#footer #block-menu-menu-fusszeile a:hover,#footer #block-menu-menu-fusszeile .redir-link:hover{color:#fff;}
#footer a:hover{color:var(--muted-2);}

/* ============================================================
   CASE STUDY (Referenz) — #einleitung hero + #rows
   ============================================================ */
.node-referenz-neu #einleitung,article#node-referenz #einleitung{padding:0;min-height:100vh;display:flex;
  align-items:center;color:#fff;position:relative;overflow:hidden;}
.node-referenz-neu #einleitung .bg,article#node-referenz #einleitung .bg{position:absolute;inset:0;z-index:0;}
.node-referenz-neu #einleitung .section,article#node-referenz #einleitung .section{position:relative;z-index:2;
  padding-top:clamp(140px,18vh,220px);padding-bottom:clamp(60px,8vh,110px);}
#einleitung .content-wrapper{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(30px,5vw,70px);
  align-items:center;}
#einleitung .content .info{display:flex;align-items:center;gap:14px;font-size:.78rem;text-transform:uppercase;
  letter-spacing:.16em;color:rgba(255,255,255,.75);margin-bottom:clamp(20px,2.4vw,30px);}
#einleitung .content .info strong{font-weight:500;}
#einleitung .content .info .line{width:34px;height:1px;background:rgba(255,255,255,.45);}
/* Smartphone: Hero-Meta („Kunde — …") untereinander statt nebeneinander */
@media(max-width:760px){
  #einleitung .content .info{flex-direction:column;align-items:flex-start;gap:5px;}
  #einleitung .content .info .line{display:none;}
}
#einleitung h1.title.big{color:#fff;font-size:clamp(2.3rem,5.4vw,5rem);line-height:1.05;}
/* „mehr erfahren"-Button im Referenz-Hero entfernt (auf Wunsch) */
#einleitung .show-more{display:none;}
#einleitung .show-more a{display:inline-flex;border:1.5px solid rgba(255,255,255,.4);color:#fff;
  padding:.9em 1.9em;border-radius:var(--r-pill);font-weight:500;font-size:.92rem;}
#einleitung .show-more a:hover{background:#fff;color:var(--ink);}
#einleitung .bild{border-radius:var(--r-lg);overflow:hidden;}
#einleitung .bild video,#einleitung .bild img{width:100%;border-radius:var(--r-lg);}

/* text-block intro */
#text-block{padding-block:var(--sec-y);}
#text-block .content{max-width:var(--container);margin:0 auto;padding-inline:var(--pad);
  display:block;}
#text-block h2.title{font-family:var(--font-display);font-weight:700;font-size:clamp(1.7rem,3vw,2.8rem);
  letter-spacing:-.02em;line-height:1.12;color:var(--ink);margin:0 0 clamp(44px,5.5vw,82px);max-width:none;}
#text-block h2.title span{display:block;}
#text-block .body{margin:0;column-count:2;column-gap:clamp(26px,2.6vw,48px);column-fill:balance;}
#text-block .body p{break-inside:auto;margin:0;}
#text-block .body p + p{margin-top:1em;}
#text-block a.website{margin-top:clamp(24px,3vw,38px);}
#text-block a.scroll-down{display:none;}

/* rows */
#rows{position:relative;}
.rows-wrapper{display:flex;flex-direction:column;}
.row{position:relative;overflow:hidden;}
.row .bg-fixed{position:absolute;inset:-1px 0;z-index:0;}
.row .wrapper,.row .text{position:relative;z-index:2;}
/* Slider-Zeilen mit background-fixed: .slider-container steht (anders als .wrapper)
   nicht automatisch über dem absoluten .bg-fixed → sonst verdeckt das Overlay den Slider. */
.row .slider-container{position:relative;z-index:2;}
.row.text .text{max-width:var(--container);margin:0 auto;padding:clamp(40px,6vw,96px) var(--pad);}
/* prevent generic .text rich-text rule from hitting case-study rows */
.row.text,.row .text,.row .body{max-width:none;color:inherit;}
.row.text .text>div{max-width:60ch;}
.row.text h3.title{font-family:var(--font-display);font-weight:700;font-size:clamp(1.7rem,3.4vw,3rem);
  letter-spacing:-.02em;line-height:1.12;margin-bottom:clamp(44px,5.5vw,82px);}
.row.text .body{font-size:19px;line-height:1.75;color:inherit;opacity:.92;max-width:60ch;}
.row.text.text-color-white .body,.row.text-color-white .body{opacity:.85;}
/* narrative Text-Rows: Headline volle Breite, Fließtext zweispaltig & balanciert */
.row.text:not(.howto-flow) .text>div{max-width:none;}
.row.text:not(.howto-flow) h3.title{max-width:none;}
.row.text:not(.howto-flow) .body{max-width:none;column-count:2;column-gap:clamp(28px,3vw,56px);column-fill:balance;text-align:justify;-webkit-hyphens:auto;hyphens:auto;}
.row.text:not(.howto-flow) .body p{break-inside:auto;margin:0;}
.row.text:not(.howto-flow) .body p + p{margin-top:1em;}
@media(max-width:760px){.row.text:not(.howto-flow) .body{column-count:1;}}
.row .wrapper{max-width:var(--container);margin:0 auto;padding:0 var(--pad);}
.row.full-width .wrapper{max-width:none;padding-inline:0;}
.row.padding .wrapper{padding-block:clamp(40px,6vw,90px);}
.row.bilder:not(.full-width) .wrapper{padding-bottom:clamp(16px,2.2vw,30px);}
/* `.padding`-Klasse = horizontale Gutter wie im Original (padding:0 140px) → schmälere,
   niedrigere Bilder. KEIN vertikales Padding (das liefert padding-top/-bottom separat). */
#rows .row.bilder.padding > .wrapper,
#rows .row.bilder_spalten.padding > .wrapper{max-width:none;padding-block:0;
  padding-inline:clamp(40px,14vw,200px);}
/* Bild-Spalten: vertikaler Abstand zwischen gestapelten Bildern = horizontaler Spaltenabstand */
#rows .row.bilder_spalten > .wrapper{--bsp-gap:clamp(14px,1.8vw,26px);display:flex;gap:var(--bsp-gap);align-items:flex-start;}
#rows .row.bilder_spalten > .wrapper > .column{flex:1 1 0;min-width:0;}
#rows .row.bilder_spalten .column .bild + .bild,
#rows .row.bilder_spalten .column .bilder + .bilder,
#rows .row.bilder_spalten .column .bilder .bild + .bild{margin-top:var(--bsp-gap);}
/* aufeinanderfolgende Bild-Reihen: Abstand kommt nur von der oberen Reihe (kein doppelter Spalt) */
#rows .row.bilder + .row.bilder .wrapper{padding-top:0;}
#rows .row:has(+ .row.full-width) .wrapper{padding-bottom:0;}
#rows .row.full-width + .row .wrapper{padding-top:clamp(16px,2.2vw,30px);}
.row.padding-top .wrapper{padding-top:clamp(40px,6vw,90px);}
.row.padding-bottom .wrapper{padding-bottom:clamp(40px,6vw,90px);}
/* Gestapelte Rows: nur die obere Row liefert den Abstand → keine doppelten Lücken */
#rows .row + .row .wrapper{padding-top:0;}
#rows .row + .row.text .text{padding-top:clamp(48px,6.5vw,104px);}
/* mehr Luft über full-bleed-Medien, die auf einen Inhaltsblock folgen — Sequenzen aus
   aufeinanderfolgenden Full-Width-Medien bleiben bündig (kein Spalt dazwischen) */
#rows .row:not(.full-width) + .row.full-width > .wrapper{padding-top:clamp(22px,3.2vw,52px);}
#rows .row.full-width + .row .wrapper{padding-top:clamp(16px,2.2vw,30px);}
.row .bild{width:100%;}
.row .bild .img-wrapper{position:relative;width:100%;overflow:hidden;}
#rows .row.slidein{transform:none!important;}
/* Leere Bilder-Zeilen (Wrapper ohne Bild/Video — z. B. reine Parallax-Dekor-Layer aus
   dem Transfer) reservieren keinen Platz → sonst große weiße Lücken. */
#rows .row.bilder:not(:has(img)):not(:has(video)){display:none;}
/* Zone-B-Bilder exakt wie im Original: volle Breite, natürliche Höhe (KEIN object-fit:cover).
   Die padding-top-Ratio des .img-wrapper reserviert die exakte Höhe → Bild sitzt vollständig,
   unbeschnitten. Parallax zoomt/verschiebt nur das innere Bild (overflow:hidden am Wrapper). */
.row .bild img{position:absolute;top:0;left:0;width:100%;height:auto;}
.row.grid-2 .wrapper{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(14px,2vw,28px);}
.row.grid-3 .wrapper{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,2vw,28px);}
.row video.querformat{width:100%;display:block;}
.row video.hochformat{display:none;}
.row .mute-button{position:absolute;left:50%;transform:translateX(-50%);bottom:clamp(16px,2vw,26px);z-index:5;width:48px;height:48px;border-radius:50%;
  background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(6px);}
.row .mute-button img{width:20px;}.row .mute-button .unmute{display:none;}
.row .mute-button.on .mute{display:none;}.row .mute-button.on .unmute{display:block;}
.only-mobile{display:none;}

/* Große animierte Zahl in Referenz-Textblöcken (zählt beim Einscrollen hoch) */
#rows .ref-bignum{display:flex;flex-direction:column;align-items:center;text-align:center;
  margin-top:clamp(40px,6.5vw,104px);}
#rows .ref-bignum .value{font-family:var(--font-display);font-weight:700;line-height:.86;
  letter-spacing:-.045em;font-size:clamp(7rem,27vw,32rem);font-variant-numeric:tabular-nums;color:inherit;}
#rows .ref-bignum .ref-bignum-cap{font-family:var(--font-ui);font-weight:700;
  font-size:clamp(.88rem,1.15vw,1.1rem);letter-spacing:.005em;margin-top:clamp(10px,1.2vw,20px);
  color:inherit;max-width:42ch;}

/* ---------- Reveal animation ---------- */
.fadein,.slidein{opacity:0;transform:translateY(26px);
  transition:opacity .9s var(--ease),transform .9s var(--ease);will-change:opacity,transform;}
.slidein{transform:translateY(40px);}
.fadein.in,.slidein.in{opacity:1;transform:none;}
/* Reveal-Bewegung NUR für Text-Rows (Full-Bleed-Bilder bleiben versatzfrei → keine Nähte) */
#rows .row.text.slidein .text{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease);will-change:opacity,transform;}
#rows .row.text.slidein.in .text{opacity:1;transform:none;}
/* Zone B: Sektions-/Zeilenhintergrund SOFORT & vorgefärbt sichtbar; nur Bilder/Slider/Text faden
   darüber ein → kein sichtbares „Pop-in" der Farbe beim Lazyload/Scrollen. */
#rows .row.slidein{opacity:1!important;transform:none!important;}
#rows .row.bilder.slidein .wrapper,
#rows .row.bilder_spalten.slidein .wrapper,
#rows .row.video.slidein .wrapper,
#rows .row.mockup.slidein .wrapper,
#rows .row.slider.slidein .slider-container{opacity:0;transition:opacity .9s var(--ease);will-change:opacity;}
#rows .row.bilder.slidein.in .wrapper,
#rows .row.bilder_spalten.slidein.in .wrapper,
#rows .row.video.slidein.in .wrapper,
#rows .row.mockup.slidein.in .wrapper,
#rows .row.slider.slidein.in .slider-container{opacity:1;}
.references .views-row.fadein{transition-delay:calc(var(--i,0)*90ms);}
.galerie .views-row.fadein{transition-delay:calc(var(--i,0)*60ms);}
.leistungen .item.fadein,#customers .logo.fadein{transition-delay:calc(var(--i,0)*45ms);}

@media(prefers-reduced-motion:reduce){
  .fadein,.slidein{opacity:1!important;transform:none!important;transition:none;}
  .scrolldown img.turning,#block-kontakt img.turning{animation:none;}
  html{scroll-behavior:auto;}
}

/* ---------- Misc cleanups ---------- */
.alinks-link{white-space:normal;}
.spamspan .t{display:none;}
img.lazy{background:transparent;}
.lottie{width:100%;height:100%;}
#article-wrapper{overflow:hidden;}
hr{border:0;border-top:1px solid var(--line);margin:var(--sec-y) 0;}

/* responsive */
@media(max-width:1024px){
  :root{--sec-y:clamp(60px,9vh,110px);}
  #einleitung .content-wrapper{grid-template-columns:1fr;}
  #text-block .body{column-count:1;}
  .leistungen{grid-template-columns:1fr;}
  #leistungenNeu .leistungen{grid-template-columns:1fr;}
  #customers .row-1,#customers .row-2,#customers .row-3{grid-template-columns:repeat(3,1fr);}
}
@media(max-width:760px){
  body{font-size:16px;}
  /* etwas mehr Abstand zum Rand links/rechts (nur wenig) */
  :root{--pad:clamp(28px,7vw,92px);}
  .galerie{grid-template-columns:1fr;gap:30px;}
  #footer .section{grid-template-columns:1fr;gap:36px;}
  #customers .row-1,#customers .row-2,#customers .row-3{grid-template-columns:repeat(2,1fr);}
  .row.grid-2 .wrapper,.row.grid-3 .wrapper{grid-template-columns:1fr;}
  .row video.querformat{display:none;}.row video.hochformat{display:block;}
  .only-mobile{display:block;}.only-desktop{display:none;}
  #block-kontakt a.wrapper{flex-direction:column;align-items:flex-start;gap:30px;}
}

/* ============================================================
   TWEAKS — Designstile, Farben, Hell/Dunkel, Radius, Fließtext
   Controlled by assets/tweaks.js via html[data-*] attributes.
   Defaults (no attribute) == baseline refresh look.
   ============================================================ */

/* ---- Akzentfarbe ---- */
:root{--accent:var(--ink);--accent-ink:#fff;}
html[data-accent="blau"]{--accent:#2B6CB0;--accent-ink:#fff;}
html[data-accent="gruen"]{--accent:#1A7B52;--accent-ink:#fff;}
html[data-accent="terra"]{--accent:#B5562B;--accent-ink:#fff;}
html[data-accent="stein"]{--accent:#94815F;--accent-ink:#fff;}
/* accent applied to interactive + label spots (defaults to ink → baseline unchanged) */
.views-row a.link:hover .read-more,
.leistungen .item a.link:hover .read-more{background:var(--accent);border-color:var(--accent);color:var(--accent-ink);}
.swiper-pagination .bullet.active{background:var(--accent);}
.faq-item.open>p:first-child::after{color:var(--accent);}
.scrolldown:hover .icon{background:var(--accent);border-color:var(--accent);color:var(--accent-ink);}
:focus-visible{outline-color:var(--accent);}
html[data-accent]:not([data-accent="kein"]) .subtitle,
html[data-accent]:not([data-accent="kein"]) .untertitel,
html[data-accent]:not([data-accent="kein"]) .leistungen .label,
html[data-accent]:not([data-accent="kein"]) #leistungenNeu .leistung .count{color:var(--accent);}
/* (in-body links intentionally inherit text color — see rich text rules) */

/* ---- Eckenradius ---- */
html[data-radius="scharf"]{--r-sm:0px;--r-md:0px;--r-lg:0px;--r-pill:2px;}
html[data-radius="sanft"]{--r-sm:10px;--r-md:16px;--r-lg:26px;}
html[data-radius="rund"]{--r-sm:14px;--r-md:22px;--r-lg:36px;}

/* ---- Fließtext: Editorial ---- */
html[data-body="editorial"] .text,
html[data-body="editorial"] #text-block .body{max-width:74ch;}
html[data-body="editorial"] #text-block .body{max-width:none;}
html[data-body="editorial"] .text p,
html[data-body="editorial"] .body p{line-height:1.9;}
html[data-body="editorial"] #services .text>p:first-of-type,
html[data-body="editorial"] #mission .text>p:first-of-type,
html[data-body="editorial"] .text>p:first-of-type{font-size:1.26em;line-height:1.55;color:var(--ink);}
html[data-body="editorial"] #services .text>p:first-of-type::first-letter,
html[data-body="editorial"] #mission .text>p:first-of-type::first-letter,
html[data-body="editorial"] .text>p:first-of-type::first-letter{
  font-family:var(--font-display);font-weight:700;float:left;font-size:3.5em;line-height:.72;
  margin:.06em .12em -.04em 0;color:var(--accent);}
html[data-body="editorial"] .text a:hover,
html[data-body="editorial"] .body a:hover{text-decoration-color:currentColor;}

/* ---- Designstil-Attribute (über Presets) ---- */
html[data-paper="pur"]{--paper-warm:#ffffff;--paper-warm-2:#efedea;}
html[data-display="xl"] #intro>.section>.title,html[data-display="xl"] #einleitung h1,
html[data-display="xl"] #einleitungNeu h1,html[data-display="xl"] #leistungenNeu h1,
html[data-display="xl"] #kontakt h1.title,html[data-display="xl"] #einleitung .title.big{
  font-size:clamp(3rem,9vw,8rem);line-height:.93;letter-spacing:-.035em;}
html[data-display="xl"] #mission .h1,html[data-display="xl"] #referenzen_slider .h1,
html[data-display="xl"] #services>.section>.title,html[data-display="xl"] #fakten .h1{
  font-size:clamp(2.4rem,5.2vw,4.6rem);letter-spacing:-.03em;}
html[data-display="xl"] .views-row .content-html .title,
html[data-display="xl"] .leistungen .item h4.title{letter-spacing:-.025em;}

/* ---- Hochburg-XL (Tweak data-xl): NUR größere Headlines auf der Startseite + breitere Inhaltsbreite.
   Sonst keine Änderung (kein Fließtext-Scaling, keine Header-Färbung, kein globales Scaling). ---- */
html[data-xl="an"]{--container:1800px;}
html[data-xl="an"] body.front #intro>.section>.title{font-size:clamp(3.2rem,10vw,9.5rem);line-height:.9;letter-spacing:-.04em;font-weight:700;}
html[data-xl="an"] body.front #services>.section>.title,
html[data-xl="an"] body.front #mission .h1,
html[data-xl="an"] body.front #customers .title{font-size:clamp(2.6rem,6vw,5.4rem);line-height:1;letter-spacing:-.03em;font-weight:700;}

/* ---- Preloader: Marken-Reveal beim Laden ---- */
html.mm-loading{overflow:hidden;}
#mm-preloader{position:fixed;inset:0;z-index:200000;background:var(--ink);display:grid;place-items:center;
  will-change:clip-path;transition:clip-path .9s cubic-bezier(.76,0,.24,1);}
#mm-preloader.mm-pl-out{clip-path:inset(0 0 100% 0);}
.mm-pl-inner{display:flex;flex-direction:column;align-items:center;gap:28px;}
/* 1 · Morph — Quadrat ⇄ Kreis */
.mm-pl-mark{width:74px;height:74px;border:1.5px solid rgba(255,255,255,.9);border-radius:6px;
  animation:mm-pl-morph 1.5s cubic-bezier(.76,0,.24,1) infinite;}
@keyframes mm-pl-morph{0%{transform:rotate(0deg) scale(.8);border-radius:6px}
  50%{transform:rotate(180deg) scale(1.1);border-radius:50%}
  100%{transform:rotate(360deg) scale(.8);border-radius:6px}}
.mm-pl-bar{height:2px;width:min(200px,40vw);background:rgba(255,255,255,.18);border-radius:2px;overflow:hidden;}
.mm-pl-bar i{display:block;height:100%;width:42%;background:#fff;border-radius:2px;animation:mm-pl-load 1s ease-in-out infinite;}
@keyframes mm-pl-load{0%{transform:translateX(-120%)}100%{transform:translateX(330%)}}
/* 2 · Counter — große Prozentzahl */
.mm-pl-count{font-family:var(--font-display);font-weight:700;color:#fff;font-size:clamp(4.5rem,18vw,12rem);
  line-height:1;letter-spacing:-.05em;font-variant-numeric:tabular-nums;}
.mm-pl-count::after{content:"%";font-size:.38em;vertical-align:super;color:var(--muted-2);margin-left:.08em;letter-spacing:0;}
/* Counter: beiger Hintergrund + Scto Grotesk + Fortschrittsbalken */
#mm-preloader[data-pl="counter"]{background:#F1ECE1;}
#mm-preloader[data-pl="counter"] .mm-pl-count{color:#15140F;font-family:'Scto Grotesk A',var(--font-display);}
#mm-preloader[data-pl="counter"] .mm-pl-count::after{color:#8A847B;}
.mm-pl-prog{width:min(300px,52vw);height:3px;background:rgba(21,20,15,.14);border-radius:2px;overflow:hidden;margin-top:8px;}
.mm-pl-prog i{display:block;height:100%;width:0;background:#15140F;border-radius:2px;transition:width .12s linear;}
/* 3 · Bars — Equalizer */
.mm-pl-bars{display:flex;align-items:flex-end;gap:11px;height:96px;}
.mm-pl-bars i{width:13px;background:#fff;border-radius:3px;height:20px;animation:mm-pl-eq 1.1s ease-in-out infinite;}
.mm-pl-bars i:nth-child(2){animation-delay:-.15s}.mm-pl-bars i:nth-child(3){animation-delay:-.3s}
.mm-pl-bars i:nth-child(4){animation-delay:-.45s}.mm-pl-bars i:nth-child(5){animation-delay:-.6s}
@keyframes mm-pl-eq{0%,100%{height:18px}50%{height:96px}}
/* 4 · Ring — rotierender Bogen */
.mm-pl-ring{width:96px;height:96px;animation:mm-pl-spin 1.05s linear infinite;}
.mm-pl-ring circle{fill:none;stroke:#fff;stroke-width:3;stroke-linecap:round;stroke-dasharray:80 200;}
@keyframes mm-pl-spin{to{transform:rotate(360deg)}}
/* 5 · Stripes — Lichtscan über Säulen (vollflächig) */
.mm-pl-stripes{position:absolute;inset:0;display:flex;}
.mm-pl-stripes i{flex:1;position:relative;overflow:hidden;}
.mm-pl-stripes i+i{border-left:1px solid rgba(255,255,255,.05);}
.mm-pl-stripes i::before{content:"";position:absolute;left:0;right:0;top:-45%;height:45%;
  background:linear-gradient(rgba(255,255,255,0),rgba(255,255,255,.13),rgba(255,255,255,0));
  animation:mm-pl-scan 1.7s ease-in-out infinite;}
.mm-pl-stripes i:nth-child(2)::before{animation-delay:.1s}.mm-pl-stripes i:nth-child(3)::before{animation-delay:.2s}
.mm-pl-stripes i:nth-child(4)::before{animation-delay:.3s}.mm-pl-stripes i:nth-child(5)::before{animation-delay:.4s}
.mm-pl-stripes i:nth-child(6)::before{animation-delay:.5s}
@keyframes mm-pl-scan{0%{top:-45%}55%,100%{top:115%}}
@media(prefers-reduced-motion:reduce){#mm-preloader{display:none;}}

/* ---- Hell / Dunkel ---- */
html[data-mode="dark"]{
  --ink:#F3F0E9;--ink-2:#CCC6BA;--paper:#15140F;--paper-warm:#1D1B14;--paper-warm-2:#26241B;
  --muted:#9C968A;--muted-2:#6C675D;--line:rgba(232,226,212,.14);--line-strong:rgba(232,226,212,.30);
}
html[data-mode="dark"] body{background:var(--paper);color:var(--ink);}
html[data-mode="dark"] #header.small{background:rgba(21,20,15,.82);border-bottom-color:var(--line);}
html[data-mode="dark"] #header.small #logo,
html[data-mode="dark"] #header.small #secondary-menu a{color:var(--ink);}
html[data-mode="dark"] #header.small #burger span{background:var(--ink);}
html[data-mode="dark"] ::selection{background:var(--ink);color:var(--paper);}
/* logos: turn into light silhouettes on dark */
html[data-mode="dark"] #customers .logo img{mix-blend-mode:screen;filter:grayscale(1) brightness(0) invert(1);opacity:.7;}
html[data-mode="dark"] #customers .logo:hover img{filter:grayscale(1) brightness(0) invert(1);opacity:1;}
html[data-mode="dark"] img.lazy{background:var(--paper-warm-2);}
/* footer/bottom/kontakt/case-study already dark — keep their #fff text */

/* ============================================================
   TWEAKS PANEL UI
   ============================================================ */
#mm-tweaks{position:fixed;left:20px;bottom:20px;z-index:100000;width:312px;max-width:calc(100vw - 40px);
  max-height:calc(100vh - 40px);overflow-y:auto;background:#fff;color:#15140F;
  border:1px solid rgba(21,20,15,.16);border-radius:14px;box-shadow:0 18px 50px rgba(20,18,10,.22);
  font-family:'Scto Grotesk A',sans-serif;padding:18px 18px 20px;display:none;}
#mm-tweaks.open{display:block;}
#mm-tweaks .mm-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
#mm-tweaks .mm-title{font-weight:700;font-size:1.02rem;letter-spacing:-.01em;}
#mm-tweaks .mm-close{border:0;background:none;font-size:1.4rem;line-height:1;cursor:pointer;color:#8A847B;
  width:28px;height:28px;border-radius:50%;}
#mm-tweaks .mm-close:hover{background:rgba(21,20,15,.07);color:#15140F;}
#mm-tweaks .mm-grp{margin-top:14px;}
#mm-tweaks .mm-lbl{font-size:.66rem;text-transform:uppercase;letter-spacing:.13em;color:#8A847B;
  font-weight:500;margin-bottom:8px;}
#mm-tweaks .mm-seg{display:flex;flex-wrap:wrap;gap:6px;}
#mm-tweaks .mm-opt{border:1px solid rgba(21,20,15,.18);background:#fff;color:#15140F;border-radius:8px;
  padding:7px 11px;font-size:.82rem;font-family:inherit;cursor:pointer;transition:all .15s;flex:0 0 auto;}
#mm-tweaks .mm-opt:hover{border-color:rgba(21,20,15,.4);}
#mm-tweaks .mm-opt.active{background:#15140F;color:#fff;border-color:#15140F;}
#mm-tweaks .mm-presets .mm-opt{flex:1 1 calc(50% - 6px);text-align:center;font-weight:500;}
#mm-tweaks .mm-sw{width:24px;height:24px;border-radius:50%;padding:0;border:1px solid rgba(21,20,15,.2);position:relative;}
#mm-tweaks .mm-sw.active{outline:2px solid #15140F;outline-offset:2px;border-color:transparent;}
#mm-tweaks .mm-note{font-size:.72rem;color:#8A847B;line-height:1.5;margin-top:16px;
  border-top:1px solid rgba(21,20,15,.1);padding-top:12px;}

/* ============================================================
   SUB-PAGE SECTIONS — Agentur & Leistungs-Detailseiten
   Restyle Drupal markup to match the original intent.
   ============================================================ */

/* ---------- #werte (Agentur): sticky Überschrift + Werte-Liste ---------- */
#node-agentur #werte{padding-block:var(--sec-y);}
#node-agentur #werte .werte{display:grid;grid-template-columns:minmax(0,37%) minmax(0,1fr);
  gap:clamp(28px,6vw,110px);align-items:start;padding:0;}
#node-agentur #werte .text-wrapper{position:sticky;top:clamp(120px,30vh,300px);width:auto;left:auto;}
#node-agentur #werte .text-wrapper .untertitel{margin-bottom:14px;}
#node-agentur #werte .text-wrapper .h3{font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.9rem,3.2vw,3rem);line-height:1.07;letter-spacing:-.02em;color:var(--ink);}
#node-agentur #werte .wrapper{padding:0;}
#node-agentur #werte .wert{padding:clamp(26px,3vw,42px) 0;border-top:1px solid var(--line);display:grid;gap:.55em;}
#node-agentur #werte .wert:last-of-type{border-bottom:1px solid var(--line);}
#node-agentur #werte .wert .titel{font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.2rem,1.9vw,1.6rem);letter-spacing:-.01em;color:var(--ink);}
#node-agentur #werte .wert .text{max-width:64ch;color:var(--ink-2);-webkit-hyphens:auto;hyphens:auto;
  font-size:clamp(1rem,1.05vw,1.12rem);line-height:1.72;}
@media(max-width:860px){
  #node-agentur #werte .werte{grid-template-columns:1fr;gap:22px;}
  #node-agentur #werte .text-wrapper{position:static;}
}

/* ---------- #auszeichnungen (Agentur): „Awards“ → Panel teilt sich → Zahl + Liste ---------- */
#node-agentur #auszeichnungen{background:var(--dark);color:#fff;position:relative;padding:0;}
#node-agentur #auszeichnungen .aw-spacer{position:relative;height:200vh;z-index:2;pointer-events:none;}
#node-agentur #auszeichnungen .aw-curtain{position:sticky;top:0;height:100vh;overflow:hidden;}
#node-agentur #auszeichnungen .aw-reveal{position:relative;z-index:1;margin:-100vh auto 0;
  max-width:var(--container);padding:clamp(60px,11vh,130px) var(--pad) clamp(70px,10vh,130px);}
#node-agentur #auszeichnungen .aw-head{display:flex;align-items:flex-end;gap:clamp(16px,2vw,30px);
  margin-bottom:clamp(34px,5vw,72px);}
#node-agentur #auszeichnungen .aw-head .n{font-family:var(--font-display);font-weight:700;line-height:.78;
  font-size:clamp(5rem,15vw,15rem);letter-spacing:-.03em;}
#node-agentur #auszeichnungen .aw-head .t{font-family:var(--font-ui);text-transform:uppercase;
  letter-spacing:.14em;font-size:clamp(.72rem,1vw,.9rem);color:rgba(255,255,255,.6);line-height:1.5;padding-bottom:.7em;}
#node-agentur #auszeichnungen .aw-shutter{position:absolute;left:0;width:100%;height:50.6%;
  background:var(--dark);will-change:transform;}
#node-agentur #auszeichnungen .aw-shutter.top{top:0;}
#node-agentur #auszeichnungen .aw-shutter.bottom{bottom:0;}
#node-agentur #auszeichnungen .aw-word{position:absolute;inset:0;display:flex;align-items:center;
  justify-content:center;pointer-events:none;}
#node-agentur #auszeichnungen .aw-word span{font-family:var(--font-display);font-weight:700;color:#fff;
  font-size:clamp(4rem,15vw,14rem);letter-spacing:-.03em;will-change:transform,opacity;}
@media(prefers-reduced-motion:reduce){
  #node-agentur #auszeichnungen .aw-spacer{display:none;}
  #node-agentur #auszeichnungen .aw-reveal{margin-top:0;}
}
#node-agentur #auszeichnungen .untertitel{color:rgba(255,255,255,.62);text-align:left;
  max-width:52ch;margin:0 0 clamp(34px,4.5vw,64px);}
#node-agentur #auszeichnungen .auszeichnungen{position:static;opacity:1;transform:none;width:auto;z-index:auto;}
#node-agentur #auszeichnungen .auszeichnungen>.wrapper{display:flex;flex-direction:column;gap:0;margin:0;
  border-top:1px solid rgba(255,255,255,.18);}
#node-agentur #auszeichnungen .auszeichnung{position:relative;cursor:default;border-bottom:1px solid rgba(255,255,255,.18);transition:background .3s var(--ease);border-radius:var(--r-sm);}
#node-agentur #auszeichnungen .auszeichnung:hover{background:rgba(255,255,255,.06);}
#node-agentur #auszeichnungen .auszeichnung>.wrapper{display:flex;flex-wrap:nowrap;align-items:center;
  justify-content:flex-start;gap:clamp(14px,2vw,30px);margin:0;padding:clamp(14px,1.9vw,28px) clamp(12px,1.6vw,22px);color:#fff;}
#node-agentur #auszeichnungen .auszeichnung .anzahl{order:2;align-self:center;font-family:var(--font-ui);font-weight:600;
  font-size:clamp(.74rem,.92vw,.92rem);color:#fff;background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.34);border-radius:var(--r-pill);letter-spacing:.06em;text-transform:none;
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:background .3s var(--ease),border-color .3s var(--ease),transform .3s var(--ease);
  padding:.55em 1.05em;flex:0 0 auto;}
#node-agentur #auszeichnungen .auszeichnung:hover .anzahl{background:var(--accent,rgba(255,255,255,.16));border-color:transparent;transform:translateY(-1px) scale(1.04);}
#node-agentur #auszeichnungen .auszeichnung .titel{order:1;font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.5rem,3.6vw,3.4rem);line-height:1.04;letter-spacing:-.025em;transition:opacity .35s var(--ease),transform .35s var(--ease);}
#node-agentur #auszeichnungen .auszeichnung .image{position:absolute;top:50%;left:50%;
  width:clamp(150px,16vw,215px);transform:translate(-50%,-50%) scale(.92);opacity:0;pointer-events:none;
  z-index:6;transition:opacity .35s var(--ease),left .16s var(--ease),top .16s var(--ease);filter:drop-shadow(0 24px 60px rgba(0,0,0,.55));}
#node-agentur #auszeichnungen .auszeichnung .image img{width:100%;border-radius:6px;}
#node-agentur #auszeichnungen .auszeichnung:hover .image{opacity:1;}
#node-agentur #auszeichnungen .auszeichnung:hover .image{opacity:1;transform:translate(-50%,-50%) scale(1);}
/* Touch-Geräte: kein Hover → Antippen klappt das Award-Bild inline auf (nur eines offen) */
@media(hover:none){
  #node-agentur #auszeichnungen .auszeichnung>.wrapper{flex-wrap:wrap;cursor:pointer;}
  #node-agentur #auszeichnungen .auszeichnung .image{position:static;transform:none;left:auto;top:auto;opacity:0;width:0;height:0;margin:0;overflow:hidden;pointer-events:none;flex-basis:100%;order:3;filter:none;transition:opacity .3s var(--ease);}
  #node-agentur #auszeichnungen .auszeichnung.open .image{opacity:1;width:clamp(130px,44vw,210px);height:auto;margin:12px 0 2px;overflow:visible;}
  #node-agentur #auszeichnungen .auszeichnung .titel::after{content:"+";margin-left:.55em;font-weight:400;opacity:.45;font-size:.62em;vertical-align:middle;}
  #node-agentur #auszeichnungen .auszeichnung.open .titel::after{content:"\2013";}
}
#node-agentur #auszeichnungen .button-wrapper{display:none;}
#node-agentur #auszeichnungen .button-wrapper .show{display:inline-block;font-family:var(--font-ui);
  font-weight:600;font-size:.95rem;color:#fff;border:1.5px solid rgba(255,255,255,.4);border-radius:var(--r-pill);
  padding:18px 50px;transition:background .4s var(--ease),color .4s var(--ease),border-color .4s var(--ease);}
#node-agentur #auszeichnungen .button-wrapper .show:hover{background:#fff;color:var(--dark);border-color:#fff;}

/* ---------- #vision (Agentur): großes, plakatives Statement (kein Kasten) ---------- */
#node-agentur #vision{padding-block:clamp(90px,15vh,210px);background:transparent;}
#node-agentur #vision .vision{max-width:none;text-align:left;background:none;border:0;padding:0;}
#node-agentur #vision .vision .untertitel{color:var(--muted);margin-bottom:clamp(22px,3vw,42px);}
#node-agentur #vision .vision .h1{font-family:var(--font-display);font-weight:700;
  font-size:clamp(2rem,4.6vw,4.1rem);line-height:1.12;letter-spacing:-.028em;color:var(--ink);
  max-width:none;margin:0;text-wrap:balance;-webkit-hyphens:auto;hyphens:auto;}

/* ---------- #vision (Leistungsseiten): hervorgehobener Sand-Block (Kontakt-CTA) ---------- */
#node-landingpage_2023 #vision{padding-top:clamp(40px,6vh,84px);padding-bottom:clamp(72px,11vh,150px);background:transparent;}
#node-landingpage_2023 #vision .vision{background:var(--dark);color:#fff;border-radius:clamp(18px,2.4vw,30px);
  padding:clamp(24px,2.8vw,40px) clamp(30px,4.5vw,64px);position:relative;overflow:hidden;
  margin-inline:calc(clamp(14px,1.8vw,30px) - clamp(20px,5vw,140px));
  display:flex;align-items:stretch;gap:clamp(30px,4vw,56px);}
#node-landingpage_2023 #vision .vision-main{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;justify-content:center;}
#node-landingpage_2023 #vision .vision::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(60% 120% at 88% 0%,rgba(255,255,255,.1),transparent 60%);}
#node-landingpage_2023 #vision .vision .untertitel{grid-column:1;color:rgba(255,255,255,.6);margin:0 0 .7em;}
#node-landingpage_2023 #vision .vision .h1{grid-column:1;font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.5rem,2.6vw,2.3rem);line-height:1.16;letter-spacing:-.015em;color:#fff;
  max-width:22ch;text-wrap:balance;}
#node-landingpage_2023 #vision .vision .h1,#node-landingpage_2023 #vision .vision .h1 *,
#node-landingpage_2023 #vision .vision h3{color:#fff!important;}
#node-landingpage_2023 #vision .typeform-wrapper{align-self:start;margin-top:clamp(20px,2.4vw,30px);position:relative;}
#node-landingpage_2023 #vision .vision-facts{flex:0 0 clamp(196px,27%,290px);align-self:stretch;
  border-left:1px solid rgba(255,255,255,.18);padding-left:clamp(24px,3vw,46px);
  display:flex;flex-direction:column;justify-content:space-between;}
#node-landingpage_2023 #vision .vf{padding:clamp(12px,1.5vw,18px) 0;border-top:1px solid rgba(255,255,255,.14);}
#node-landingpage_2023 #vision .vf:first-child{border-top:0;padding-top:0;}
#node-landingpage_2023 #vision .vf:last-child{padding-bottom:0;}
#node-landingpage_2023 #vision .vf-n{display:block;font-family:var(--font-display);font-weight:700;
  font-size:clamp(2.3rem,3.6vw,3.5rem);line-height:.95;letter-spacing:-.03em;color:#fff;}
html[data-accent]:not([data-accent="kein"]) #node-landingpage_2023 #vision .vf-n{color:var(--accent);}
#node-landingpage_2023 #vision .vf-l{display:block;font-size:.9rem;line-height:1.35;color:rgba(255,255,255,.66);margin-top:4px;}
#node-landingpage_2023 #vision a.typeform{display:inline-block;background:#fff;color:var(--dark);
  border:0;font-family:var(--font-ui);font-weight:600;font-size:1.02rem;border-radius:var(--r-pill);
  padding:17px 40px;white-space:nowrap;transition:transform .25s var(--ease),box-shadow .25s var(--ease);}
#node-landingpage_2023 #vision a.typeform:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(0,0,0,.34);}
html[data-accent]:not([data-accent="kein"]) #node-landingpage_2023 #vision a.typeform{background:var(--accent);color:var(--accent-ink);}
@media(max-width:760px){
  #node-landingpage_2023 #vision .vision{flex-direction:column;align-items:stretch;text-align:left;gap:clamp(20px,4vw,28px);margin-inline:0;}
  #node-landingpage_2023 #vision .vision-main{align-items:flex-start;}
  #node-landingpage_2023 #vision .vision .h1{max-width:none;}
  #node-landingpage_2023 #vision .typeform-wrapper{align-self:flex-start;}
  #node-landingpage_2023 #vision .vision-facts{flex-basis:auto;border-left:0;padding-left:0;
    border-top:1px solid rgba(255,255,255,.16);padding-top:clamp(18px,4vw,24px);margin-top:clamp(4px,2vw,8px);width:100%;
    display:grid;grid-template-columns:1fr 1fr;gap:0 clamp(18px,4vw,28px);text-align:left;}
  #node-landingpage_2023 #vision .vf{border-top:0;padding:clamp(12px,3.4vw,16px) 0;}
  #node-landingpage_2023 #vision .vf:nth-child(-n+2){padding-top:0;}
  #node-landingpage_2023 #vision .vf:nth-child(n+3){border-top:1px solid rgba(255,255,255,.14);}
}

/* ---------- #leistungenNeu: große Liste ---------- */
#leistungenNeu .leistungen{grid-template-columns:1fr;gap:0;
  margin-top:clamp(46px,6vw,84px);}
#leistungenNeu .leistung:last-child a.link{border-bottom:0;}
#leistungenNeu .leistung a.link{padding:clamp(26px,3.4vw,46px) 0;}
#leistungenNeu .leistung h4.title{font-size:clamp(2rem,5vw,4.2rem);letter-spacing:-.026em;line-height:1;}
#leistungenNeu .leistung .count{align-self:flex-start;padding-top:.7em;}
#leistungenNeu .leistung .pfeil{width:clamp(34px,3vw,46px);}
#leistungenNeu .leistung a.link:hover h4.title{transform:translateX(16px);}
/* Smartphone: Leistungs-Liste etwas kompakter (kleinere Titel, weniger Polsterung) */
@media(max-width:760px){
  #leistungenNeu .leistung h4.title{font-size:clamp(1.3rem,5.6vw,1.75rem);letter-spacing:-.02em;}
  #leistungenNeu .leistung a.link{padding:clamp(16px,4.2vw,26px) 0;}
  #leistungenNeu .leistung .pfeil{width:clamp(22px,5.4vw,30px);}
  /* CTA-Button „Kostenloses Erstgespräch" im Hero der Leistungsseiten am Smartphone ausblenden */
  #node-landingpage_2023 #einleitung .typeform-wrapper{display:none;}
}

/* ---------- #einleitungNeu: mehr Luft nach oben (Textstart-Seiten, fixer Header) ---------- */
#einleitungNeu{padding-top:clamp(150px,20vh,260px);}

/* ---------- Leistungs-Detailseiten: nicht benötigte Sektionen entfernen ---------- */
#node-landingpage_2023 #kunden,
#node-landingpage_2023 #referenzen_slider,
#node-landingpage_2023 #auszeichnungen{display:none;}

/* Leistungs-Detail #galerie: passende Projekte als Raster wie auf der Referenzübersicht */
#node-landingpage_2023 #galerie{padding-top:clamp(60px,9vh,140px);}
#node-landingpage_2023 #galerie .galerie{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));
  gap:clamp(28px,3.4vw,56px) clamp(26px,3.4vw,72px);max-width:none;margin:0;padding:0;}
#node-landingpage_2023 #galerie .views-row:nth-child(n+6){display:none;}
#node-landingpage_2023 #galerie .lp-gal-head{margin-bottom:clamp(24px,3.5vw,52px);}
#node-landingpage_2023 #galerie .lp-gal-title{font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.9rem,3.6vw,3.2rem);letter-spacing:-.02em;line-height:1.1;color:var(--ink);margin:clamp(8px,1.2vw,16px) 0 0;}
/* Raster exakt wie Referenzübersicht: gestaffelte Reihen, quadratische 5n+2/3, Hero 5n+5 */
#node-landingpage_2023 #galerie .galerie{align-items:start;gap:clamp(26px,3.4vw,64px) clamp(26px,3.4vw,72px);}
#node-landingpage_2023 #galerie .views-row .video-container{background:var(--paper-warm-2);}
#node-landingpage_2023 #galerie .views-row:nth-child(5n+2){margin-top:clamp(36px,7vw,108px);}
#node-landingpage_2023 #galerie .views-row:nth-child(5n+3){margin-top:clamp(26px,5vw,76px);}
#node-landingpage_2023 #galerie .views-row:nth-child(5n+2) .video-container,
#node-landingpage_2023 #galerie .views-row:nth-child(5n+3) .video-container{aspect-ratio:1/1;}
#node-landingpage_2023 #galerie .views-row:nth-child(5n+5) .video-container{aspect-ratio:21/9;}
@media(max-width:760px){
  #node-landingpage_2023 #galerie .views-row{margin-top:0!important;}
  #node-landingpage_2023 #galerie .views-row .video-container,
  #node-landingpage_2023 #galerie .views-row:nth-child(5n+5) .video-container{aspect-ratio:16/10;}
}
#node-landingpage_2023 #galerie .views-row{margin:0;min-width:0;transform:none;opacity:1;}
#node-landingpage_2023 #galerie .views-row .link{display:block;color:inherit;}
#node-landingpage_2023 #galerie .bild{width:100%;overflow:hidden;border-radius:var(--r-md);}
#node-landingpage_2023 #galerie .bild .video-container{position:relative;aspect-ratio:16/9;height:auto;padding-top:0;overflow:hidden;}
#node-landingpage_2023 #galerie .bild .video-container video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);}
#node-landingpage_2023 #galerie .bild img,#node-landingpage_2023 #galerie .bild picture img{width:100%;height:auto;display:block;transition:transform .6s var(--ease);}
#node-landingpage_2023 #galerie .bild picture,#node-landingpage_2023 #galerie .bild .lottie{display:block;aspect-ratio:auto;height:auto;padding:0;}
#node-landingpage_2023 #galerie .bild picture img{position:static;}
#node-landingpage_2023 #galerie .link:hover .bild video,
#node-landingpage_2023 #galerie .link:hover .bild img{transform:scale(1.05);}
#node-landingpage_2023 #galerie .views-row:nth-child(5n+5){grid-column:1 / -1;}
#node-landingpage_2023 #galerie .views-row:nth-child(5n+5) .video-container{aspect-ratio:16/7;}
#node-landingpage_2023 #galerie .content-html{display:flex;flex-direction:column;gap:.3em;margin-top:clamp(12px,1.3vw,18px);padding:0 2px;}
#node-landingpage_2023 #galerie .content-html .kunde{order:-1;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);}
#node-landingpage_2023 #galerie .content-html .title{font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.1rem,1.5vw,1.4rem);letter-spacing:-.01em;line-height:1.18;color:var(--ink);}
#node-landingpage_2023 #galerie .read-more{display:none;}
@media(max-width:760px){#node-landingpage_2023 #galerie .galerie{grid-template-columns:1fr;}}

/* Leistungs-Detail #werte: Headline über die gesamte Inhaltsbreite */
#node-landingpage_2023 #werte .text-wrapper{max-width:none;}
#node-landingpage_2023 #werte .text-wrapper .h3{max-width:none;}

/* Leistungs-Detail #einleitung: zweispaltige Einleitung unter der Headline */
#node-landingpage_2023 #einleitung{padding-top:clamp(150px,20vh,260px);}
/* Smartphone + sehr kleine Screens: oberen Abstand verringern */
@media(max-width:760px){#node-landingpage_2023 #einleitung{padding-top:clamp(96px,13vh,132px);}}
@media(max-width:430px){#node-landingpage_2023 #einleitung{padding-top:84px;}}
/* Leistungs-Detail: Button im Mission-Block raus + einheitliche Blockabstände, Trennlinien bei gleicher Hintergrundfarbe */
#node-landingpage_2023 #mission .typeform-wrapper{display:none;}
#node-landingpage_2023 #mission{padding-top:var(--lp-eyebrow-gap);padding-bottom:0;}
#node-landingpage_2023 #mission > .section{border-top:0;padding-top:var(--lp-eyebrow-gap);position:relative;}
/* Trennlinien der Leistungs-Blöcke auf Inhaltsbreite (nicht über den Seitenrand) */
#node-landingpage_2023 #werte > .section,#node-landingpage_2023 #lp-prozess .lp-prozess-inner{border-top:0!important;position:relative;}
#node-landingpage_2023 #mission > .section::before,
#node-landingpage_2023 #werte > .section::before,
#node-landingpage_2023 #lp-prozess .lp-prozess-inner::before{content:"";position:absolute;top:0;left:var(--pad);right:var(--pad);height:1px;background:var(--line);}
#node-landingpage_2023 #lp-prozess{padding:0;}
#node-landingpage_2023 #lp-prozess .lp-prozess-inner{border-top:1px solid var(--line);margin-top:var(--lp-eyebrow-gap);padding-top:var(--lp-eyebrow-gap);padding-bottom:0;}
#node-landingpage_2023 #galerie{padding:0;}
#node-landingpage_2023 #galerie .section{margin-top:var(--lp-eyebrow-gap);padding-top:var(--lp-eyebrow-gap);padding-bottom:0;position:relative;}
/* keine Trennlinie über der Galerie: darüber liegt das warme Fakten-Band (andere Hintergrundfarbe) */
/* Galerie als horizontaler Slider (wie „Weitere Referenzen") */
#node-landingpage_2023 #galerie .galerie.lp-gal-slider{display:flex;grid-template-columns:none;align-items:start;
  width:100vw;margin-left:calc(50% - 50vw);
  padding-inline:max(var(--pad),calc((100vw - var(--container))/2 + var(--pad)));
  scroll-padding-left:max(var(--pad),calc((100vw - var(--container))/2 + var(--pad)));
  overflow-x:auto;scroll-snap-type:x proximity;gap:clamp(20px,2.4vw,40px);padding-bottom:6px;
  -webkit-overflow-scrolling:touch;scrollbar-width:none;}
#node-landingpage_2023 #galerie .galerie.lp-gal-slider::-webkit-scrollbar{display:none;}
#node-landingpage_2023 #galerie .lp-gal-slider .views-row{flex:0 0 clamp(280px,34%,440px);scroll-snap-align:start;margin:0!important;}
#node-landingpage_2023 #galerie .lp-gal-slider .views-row .bild{aspect-ratio:1/1!important;position:relative;background:var(--paper-warm-2);}
#node-landingpage_2023 #galerie .lp-gal-slider .views-row .bild .video-container{position:absolute!important;inset:0;width:100%;height:100%;aspect-ratio:auto!important;padding:0!important;background:transparent;}
#node-landingpage_2023 #galerie .lp-gal-slider .views-row .bild video,
#node-landingpage_2023 #galerie .lp-gal-slider .views-row .bild img{object-fit:cover!important;width:100%;height:100%;}
/* Slider-Karten: nur Video, ohne Caption darunter */
#node-landingpage_2023 #galerie .lp-gal-slider .content-html{display:none!important;}
#node-landingpage_2023 #galerie .lp-gal-slider .views-row:nth-child(5n+5){grid-column:auto;}
/* Smartphone: Slider-Karten größer, Nachbarn nur leicht angeschnitten, 1:1 gefüllt */
@media(max-width:760px){
  #node-landingpage_2023 #galerie .lp-gal-slider .views-row{flex:0 0 84%;}
  #node-landingpage_2023 #galerie .lp-gal-slider .views-row .bild video{object-fit:cover!important;}
  #block-weitere-slider .swiper-slide{flex:0 0 84%!important;}
}
#node-landingpage_2023 #galerie .lp-gal-nav{display:flex;gap:10px;margin-top:clamp(20px,2.4vw,32px);}
#node-landingpage_2023 #galerie .lp-gal-nav a{width:52px;height:52px;border-radius:50%;border:1px solid var(--line-strong);
  display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink);
  transition:background .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease);}
#node-landingpage_2023 #galerie .lp-gal-nav a:hover{background:var(--ink);color:#fff;border-color:var(--ink);}
#node-landingpage_2023 #galerie .lp-gal-dots{display:flex;justify-content:flex-start;gap:10px;margin-top:clamp(22px,2.6vw,38px);}
#node-landingpage_2023 #galerie .lp-gal-dots button{width:9px;height:9px;border-radius:999px;border:0;padding:0;cursor:pointer;background:var(--line-strong);opacity:.5;transition:width .3s var(--ease),opacity .25s var(--ease),background .25s var(--ease);}
#node-landingpage_2023 #galerie .lp-gal-dots button:hover{opacity:.8;}
#node-landingpage_2023 #galerie .lp-gal-dots button.active{opacity:1;background:var(--ink);width:34px;}
.lp-gal-cursor{position:fixed;z-index:9999;top:0;left:0;transform:translate(-50%,-50%) scale(.6);background:var(--ink);color:#fff;font-family:var(--font-ui);font-size:.8rem;letter-spacing:.04em;padding:13px 22px;border-radius:var(--r-pill);pointer-events:none;opacity:0;white-space:nowrap;transition:opacity .2s var(--ease),transform .2s var(--ease);}
.lp-gal-cursor.show{opacity:1;transform:translate(-50%,-50%) scale(1);}
.wr-cap{display:none!important;}
/* Alle Eyebrows einheitlich 12px */
.ed-eyebrow,.ht-eyebrow,.ws-eyebrow,.imp-eyebrow,.untertitel,.ft-eyebrow,.subtitle.ht-eyebrow,.lp-gal-head .subtitle{font-size:12px!important;letter-spacing:.14em;}
/* Einheitlicher Abstand Eyebrow → Headline auf der Leistungs-Detailseite */
#node-landingpage_2023 .untertitel,#node-landingpage_2023 .ht-eyebrow,#node-landingpage_2023 .lp-gal-head .subtitle{margin-bottom:clamp(12px,1.5vw,18px)!important;}
#node-landingpage_2023 #lp-prozess .lp-prozess-title,#node-landingpage_2023 #galerie .lp-gal-title,#node-landingpage_2023 #mission .lp-topic .lp-topic-h,#node-landingpage_2023 #werte .text-wrapper .h3,#node-landingpage_2023 #vision .vision>h3.h1,#node-landingpage_2023 #mission .mission>h2.h1{margin-top:0!important;}
/* Lottie-Kacheln: gleiche Fläche wie die Video-Kacheln */
#node-landingpage_2023 #galerie .bild .lottie{aspect-ratio:4/3;width:100%;overflow:hidden;border-radius:var(--r-md);background:var(--paper-warm-2);}
#node-landingpage_2023 #galerie .bild .lottie svg{width:100%!important;height:100%!important;display:block;object-fit:cover;}
/* Einheitlicher Block-Headline-Stil für ALLE Leistungs-Blöcke */
#node-landingpage_2023 #lp-prozess .lp-prozess-title,
#node-landingpage_2023 #galerie .lp-gal-title,
#node-landingpage_2023 #mission .lp-topic:has(ul) .lp-topic-h,
#node-landingpage_2023 #werte .text-wrapper .h3{
  font-family:var(--font-display);font-weight:700;font-size:clamp(2.1rem,4.2vw,51px);
  line-height:1.1;letter-spacing:-.02em;color:var(--ink);max-width:none;}
/* gleiche Headline-Größe auch für den Leistungs-Block (höhere Spezifität) */
article#node-landingpage_2023 #mission .lp-topic:has(ul) .lp-topic-h{font-size:clamp(2.1rem,4.2vw,51px);max-width:none;}
article#node-landingpage_2023 #werte .text-wrapper .h3{font-size:clamp(2.1rem,4.2vw,51px);max-width:none!important;}
article#node-landingpage_2023 #werte .werte,article#node-landingpage_2023 #werte .text-wrapper{max-width:none;}
/* Trennlinie auch zwischen galerie (weiß) und #werte (weiß) */
#node-landingpage_2023 #werte{padding:0;}
#node-landingpage_2023 #werte > .section{border-top:1px solid var(--line);margin-top:var(--lp-eyebrow-gap);padding-top:var(--lp-eyebrow-gap);padding-bottom:0;}
#node-landingpage_2023 #werte .text-wrapper{max-width:none;}
#node-landingpage_2023 #werte .text-wrapper .h3{max-width:none;}
/* #vision Headline im H2-Stil (wie Mission-Statement) */
#node-landingpage_2023 #vision .vision > h3.h1{font-family:var(--font-display);font-weight:700;
  font-size:clamp(2.1rem,4.2vw,51px);line-height:1.12;letter-spacing:-.02em;color:var(--ink);max-width:none;}
#node-landingpage_2023 #einleitung .einl-intro{column-count:2;column-gap:clamp(34px,4vw,64px);column-fill:balance;
  max-width:none;margin-top:clamp(34px,4.5vw,64px);text-align:justify;-webkit-hyphens:auto;hyphens:auto;}
#node-landingpage_2023 #einleitung .einl-intro p{break-inside:auto;margin:0 0 1em;color:var(--ink-2);
  font-size:19px;line-height:1.7;}
#node-landingpage_2023 #einleitung .einl-intro p:last-child{margin-bottom:0;}
@media(max-width:760px){#node-landingpage_2023 #einleitung .einl-intro{column-count:1;}}

/* Leistungs-Detail #mission: normaler zweispaltiger Fließtext unter der Headline */
#node-landingpage_2023 #mission .mission{display:block;}
/* Leistungs-Detail: injizierter Zahlen-&-Fakten-Block — identisches Styling wie #fakten (Agentur), 4-spaltig */
/* Fakten: Desktop/Tablet = einzeiliger Balken (4 Kennzahlen). Die vollen 6 Kacheln
   (inkl. Awards + Google-Bewertung) NUR in der Smartphone-Version. */
#node-landingpage_2023 #fakten .items{grid-template-columns:repeat(4,minmax(0,1fr));}
#node-landingpage_2023 #fakten .item:nth-child(n+5){display:none;}
@media(max-width:760px){
  #node-landingpage_2023 #fakten .items{grid-template-columns:repeat(2,1fr);}
  #node-landingpage_2023 #fakten .item:nth-child(n+5){display:flex;}
}
#lp-prozess{padding-block:clamp(56px,8vw,120px);}
#lp-prozess .lp-prozess-inner{max-width:var(--container);margin:0 auto;padding:0 var(--pad);}
#lp-prozess .lp-prozess-title{font-family:var(--font-display);font-weight:700;font-size:clamp(1.9rem,3.6vw,3.2rem);
  letter-spacing:-.02em;line-height:1.1;margin:clamp(8px,1.2vw,16px) 0 clamp(34px,4.5vw,60px);}
/* Slider full-bleed (volle Breite) wie der Referenz-Slider (#galerie .lp-gal-slider):
   100vw, mittig ausgebrochen, erstes Element bündig zur Inhaltskante (nicht zu weit rechts). */
#lp-prozess .lp-steps{display:flex;gap:clamp(16px,2vw,28px);overflow-x:auto;scroll-snap-type:x mandatory;
  scrollbar-width:none;-webkit-overflow-scrolling:touch;
  width:100vw;margin-left:calc(50% - 50vw);
  padding-inline:max(var(--pad),calc((100vw - var(--container))/2 + var(--pad)));
  scroll-padding-left:max(var(--pad),calc((100vw - var(--container))/2 + var(--pad)));}
#lp-prozess .lp-steps::-webkit-scrollbar{display:none;}
#lp-prozess .lp-step{display:flex;flex-direction:column;justify-content:flex-start;gap:clamp(12px,1.6vw,18px);
  flex:0 0 clamp(300px,38%,440px);aspect-ratio:auto;min-height:clamp(200px,24vw,300px);min-width:0;scroll-snap-align:start;
  background:var(--paper-warm);border:1px solid var(--line);border-radius:var(--r-md);padding:clamp(22px,2.4vw,34px);}
#lp-prozess .lp-step-n{font-family:var(--font-display);font-weight:700;font-size:clamp(2.4rem,3.6vw,3.4rem);
  line-height:1;letter-spacing:-.02em;color:var(--ink-2);}
#lp-prozess .lp-step-c strong{display:block;font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.05rem,1.4vw,1.3rem);margin-bottom:.3em;color:var(--ink);}
#lp-prozess .lp-step-c span{color:var(--ink-2);font-size:.98rem;line-height:1.6;}
/* Inhalt direkt unter der Zahl, durch feine Linie abgeteilt */
#lp-prozess .lp-step-c{border-top:1px solid var(--line);padding-top:clamp(12px,1.6vw,18px);}
/* Slider am Smartphone: aktive Kachel zentriert, Nachbarn links & rechts gleich leicht
   angeschnitten (gilt für alle Leistungsseiten-Slider). */
@media(max-width:640px){
  #node-landingpage_2023 #lp-prozess .lp-steps,
  #node-landingpage_2023 #galerie .galerie.lp-gal-slider{
    scroll-snap-type:x mandatory;padding-inline:var(--pad)!important;scroll-padding-inline:var(--pad);}
  #node-landingpage_2023 #lp-prozess .lp-step{flex:0 0 calc(100vw - 2*var(--pad))!important;scroll-snap-align:center;}
  #node-landingpage_2023 #galerie .galerie.lp-gal-slider .views-row{flex:0 0 calc(100vw - 2*var(--pad))!important;scroll-snap-align:center;}
}
@media(max-width:860px){#lp-prozess .lp-step{flex:0 0 clamp(280px,58%,400px);}}
@media(max-width:560px){#lp-prozess .lp-step{flex:0 0 86%;}}
/* Slider-Punkte für die Vorgehensweise (nur sichtbar, wenn scrollbar) */
#lp-prozess .lp-steps-dots{display:none;justify-content:flex-start;gap:9px;margin-top:clamp(24px,3vw,40px);}
#lp-prozess .lp-steps-dots.is-on{display:flex;}
@media(max-width:760px){#lp-prozess .lp-steps-dots{justify-content:flex-start;}}
#lp-prozess .lp-steps-dots button{width:9px;height:9px;border-radius:50%;border:0;cursor:pointer;padding:0;
  background:var(--line-strong);transition:background .25s var(--ease),transform .25s var(--ease);}
#lp-prozess .lp-steps-dots button.active{background:var(--ink);transform:scale(1.25);}
html[data-accent]:not([data-accent="kein"]) #lp-prozess .lp-steps-dots button.active{background:var(--accent);}
/* Rand-Cursor (Pfeile) zum Sliden der Vorgehensweise */
.lp-slide-cursor{position:fixed;z-index:1100;top:0;left:0;pointer-events:none;
  width:62px;height:62px;border-radius:50%;background:var(--ink);color:#fff;
  display:flex;align-items:center;justify-content:center;
  transform:translate(-50%,-50%) scale(.5);opacity:0;transition:opacity .2s var(--ease),transform .25s var(--ease);}
.lp-slide-cursor.show{opacity:1;transform:translate(-50%,-50%) scale(1);}
html[data-accent]:not([data-accent="kein"]) .lp-slide-cursor{background:var(--accent);color:var(--accent-ink);}
.lp-slide-cursor svg{width:24px;height:24px;animation:lp-arr 1.1s ease-in-out infinite;}
@keyframes lp-arr{0%,100%{transform:scale(1);}50%{transform:scale(1.2);}}
@media(hover:none){.lp-slide-cursor{display:none;}}
/* Leistungs-Detail #mission: Statement weniger dominant — als ruhiger Lead statt Riesen-Headline */
#node-landingpage_2023 #mission .mission > h2.h1{font-family:var(--font-display);font-weight:700;
  font-size:clamp(2.1rem,4.2vw,51px);line-height:1.12;letter-spacing:-.02em;color:var(--ink);
  max-width:none;margin:0;}
#node-landingpage_2023 #mission .text{column-count:1;max-width:none;margin-top:clamp(34px,4.5vw,60px);}
#node-landingpage_2023 #mission .lp-lead{font-size:19px;line-height:1.7;color:var(--ink-2);max-width:70ch;margin-bottom:clamp(34px,4.5vw,60px);}
#node-landingpage_2023 #mission .lp-topics{column-count:2;column-gap:clamp(40px,5vw,84px);column-fill:balance;margin-bottom:0;}
#node-landingpage_2023 #mission .lp-topics > .lp-topic:last-child{margin-bottom:0;}
#node-landingpage_2023 #mission .lp-topic{break-inside:avoid;border-top:1px solid var(--line);padding-top:clamp(18px,2.2vw,28px);margin:0 0 clamp(20px,2.4vw,34px);}
#node-landingpage_2023 #mission .lp-topic-h{font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.2rem,1.7vw,1.5rem);letter-spacing:-.01em;line-height:1.22;color:var(--ink);margin:0 0 .5em;}
#node-landingpage_2023 #mission .lp-topic p{font-size:19px;line-height:1.65;color:var(--ink-2);margin:0 0 .35em;}
#node-landingpage_2023 #mission .lp-topic p:last-child{margin-bottom:0;}
#node-landingpage_2023 #mission .lp-topic a{color:var(--ink);text-decoration:underline;text-underline-offset:2px;text-decoration-color:var(--line-strong);}
/* Leistungsliste: ein einspaltiges, helles Hervorhebungs-Element (Sandfläche, kein dunkler Kasten) */
#node-landingpage_2023 #mission .lp-topic:has(ul){column-span:all;margin-top:clamp(52px,6.5vw,96px);
  padding-top:clamp(40px,5vw,72px);border-top:1px solid var(--line);}
#node-landingpage_2023 #mission .lp-topic.lp-has-eyebrow::before{content:none;}
#node-landingpage_2023 #mission .lp-topic.lp-has-eyebrow .ht-eyebrow{margin:0 0 clamp(12px,1.5vw,20px);}
  font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:clamp(12px,1.5vw,20px);}
#node-landingpage_2023 #mission .lp-topic:has(ul) .lp-topic-h{font-size:clamp(1.7rem,3.2vw,2.9rem);line-height:1.08;
  letter-spacing:-.02em;max-width:20ch;margin:0 0 .5em;}
#node-landingpage_2023 #mission .lp-topic:has(ul) > p{font-size:19px;line-height:1.7;color:var(--ink-2);
  max-width:62ch;margin:0 0 clamp(18px,2.4vw,34px);}
#node-landingpage_2023 #mission .lp-topic ul{list-style:none;margin:clamp(22px,2.6vw,40px) 0 0;padding:0;
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));column-gap:clamp(40px,5vw,84px);}
#node-landingpage_2023 #mission .lp-topic li{border-top:0;border-bottom:1px solid var(--line);padding:clamp(14px,1.6vw,22px) 0;font-size:19px;line-height:1.6;color:var(--ink-2);}
#node-landingpage_2023 #mission .lp-topic:not(.lp-mm-box) ul li:nth-last-child(-n+2){border-bottom:0;}
/* Leistungsliste: Strich-Marker entfernen, kleine Nummerierung vor den Titel */
#node-landingpage_2023 #mission .lp-topic ul{counter-reset:lpsvc;}
#node-landingpage_2023 #mission .lp-topic li::before,
#node-landingpage_2023 #mission .lp-topic li strong::after{content:none!important;}
#node-landingpage_2023 #mission .lp-topic li strong::before{counter-increment:lpsvc;content:counter(lpsvc,decimal-leading-zero)!important;display:block;font-family:var(--font-ui);font-weight:600;font-size:12px;letter-spacing:.14em;color:var(--muted);margin:0 0 .5em;}
#node-landingpage_2023 #mission .lp-topic li strong{display:block;font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.3rem,2.1vw,1.9rem);letter-spacing:-.015em;line-height:1.2;color:var(--ink);margin:0;}
#node-landingpage_2023 #mission .lp-topic a{color:inherit;text-decoration:none;}
#node-landingpage_2023 #mission .lp-topic li:hover strong{transform:none;}
/* „Leistungen im Detail"-Liste im Stil der Startseiten-Leistungen: einspaltig,
   Titel + „+"-Kreis rechts, Trennlinien, Hover-Slide. Schriftgröße wie gehabt. */
#node-landingpage_2023 #mission .lp-topic:not(.lp-mm-box) ul{grid-template-columns:1fr;column-gap:0;}
#node-landingpage_2023 #mission .lp-topic:not(.lp-mm-box) ul li{display:flex;align-items:center;justify-content:space-between;gap:1em;}
#node-landingpage_2023 #mission .lp-topic:not(.lp-mm-box) ul li strong::before{content:none!important;}
#node-landingpage_2023 #mission .lp-topic:not(.lp-mm-box) ul li strong{transition:transform .3s var(--ease);}
#node-landingpage_2023 #mission .lp-topic:not(.lp-mm-box) ul li::after{content:"+";flex:0 0 auto;width:32px;height:32px;
  border:1.5px solid var(--line-strong);border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:var(--ink);font-weight:300;font-size:1.1rem;line-height:1;
  transition:background .3s var(--ease),color .3s var(--ease),transform .3s var(--ease);}
#node-landingpage_2023 #mission .lp-topic:not(.lp-mm-box) ul li:hover strong{transform:translateX(10px);}
#node-landingpage_2023 #mission .lp-topic:not(.lp-mm-box) ul li:hover::after{background:var(--ink);color:#fff;transform:rotate(90deg);}
#node-landingpage_2023 #mission .lp-topic:not(.lp-mm-box) ul li:nth-last-child(2){border-bottom:1px solid var(--line);}
#node-landingpage_2023 #mission .lp-topic:not(.lp-mm-box) ul li:last-child{border-bottom:0;}
@media(max-width:600px){#node-landingpage_2023 #mission .lp-topic ul{grid-template-columns:1fr;}
  /* Einspaltige Liste am Smartphone: NUR der letzte Eintrag ohne Trennlinie unten
     (im 2-Spalter werden die letzten zwei entfernt – das ist hier falsch). */
  #node-landingpage_2023 #mission .lp-topic:not(.lp-mm-box) ul li:nth-last-child(2){border-bottom:1px solid var(--line);}
  #node-landingpage_2023 #mission .lp-topic:not(.lp-mm-box) ul li:last-child{border-bottom:0;}}
@media(max-width:560px){#node-landingpage_2023 #mission .lp-topics{column-count:1;}
  /* einspaltig: erster Block ohne Linie darüber (sonst Strich über dem ersten Eintrag) */
  #node-landingpage_2023 #mission .lp-topics > .lp-topic:first-child{border-top:0;padding-top:0;}}
/* Leistungs-Themen am Smartphone als Akkordeon (Struktur per JS, Collapse nur hier) */
@media(max-width:760px){
  #node-landingpage_2023 #mission .lp-topics{column-count:1;}
  #node-landingpage_2023 #mission .lp-topic.lp-acc .lp-acc-h{cursor:pointer;position:relative;padding-right:1.8em;margin:0;
    -webkit-tap-highlight-color:transparent;}
  #node-landingpage_2023 #mission .lp-topic.lp-acc .lp-acc-h::after{content:"";position:absolute;right:.15em;top:.32em;
    width:11px;height:11px;border-right:2px solid var(--ink);border-bottom:2px solid var(--ink);
    transform:rotate(45deg);transition:transform .3s var(--ease);}
  #node-landingpage_2023 #mission .lp-topic.lp-acc.open .lp-acc-h::after{transform:rotate(-135deg);top:.5em;}
  #node-landingpage_2023 #mission .lp-topic.lp-acc .lp-acc-body{display:none;padding-top:.6em;}
  #node-landingpage_2023 #mission .lp-topic.lp-acc.open .lp-acc-body{display:block;}
}
/* Bento-Grid für den „unverzichtbar"-Block (hell, eine dunkle Akzentkachel) */
#node-landingpage_2023 #mission .lp-topic.lp-bento{column-span:all;margin-top:clamp(52px,6.5vw,96px);
  background:var(--paper-warm);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(30px,4vw,60px);}
#node-landingpage_2023 #mission .lp-bento .lp-topic-h{max-width:none;margin:0 0 clamp(22px,2.6vw,40px);}
#node-landingpage_2023 #mission .lp-bento-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));
  gap:0 clamp(34px,4.5vw,72px);}
#node-landingpage_2023 #mission .lp-bento-tile{display:grid;grid-template-columns:auto 1fr;column-gap:clamp(14px,1.4vw,20px);
  row-gap:.25em;align-items:start;background:none;border:0;padding:clamp(16px,1.8vw,26px) 0;min-height:0;}
#node-landingpage_2023 #mission .lp-bento-tile::before{content:"";grid-row:1 / span 2;
  width:clamp(22px,2vw,28px);height:clamp(22px,2vw,28px);border-radius:50%;
  background:var(--ink) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12l5 5L20 6'/%3E%3C/svg%3E") center/52% no-repeat;}
#node-landingpage_2023 #mission .lp-bento-tile strong{grid-column:2;font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.15rem,1.6vw,1.45rem);letter-spacing:-.01em;line-height:1.2;color:var(--ink);}
#node-landingpage_2023 #mission .lp-bento-tile span{grid-column:2;font-size:16px;line-height:1.5;color:var(--ink-2);}
@media(max-width:680px){#node-landingpage_2023 #mission .lp-bento-grid{grid-template-columns:1fr;}
  /* einspaltig: nur die letzte Kachel ohne Trennlinie unten */
  #node-landingpage_2023 #mission .lp-bento-grid .lp-bento-tile:nth-last-child(2){border-bottom:1px solid var(--line);}
  #node-landingpage_2023 #mission .lp-bento-grid .lp-bento-tile:last-child{border-bottom:0;}}
#node-landingpage_2023 #mission .lp-mm-box > p:not(.ht-eyebrow){column-count:2;column-gap:clamp(34px,4vw,64px);max-width:none;margin:0 0 clamp(8px,1.4vw,18px);text-align:justify;-webkit-hyphens:auto;hyphens:auto;}
@media(max-width:680px){#node-landingpage_2023 #mission .lp-mm-box > p:not(.ht-eyebrow){column-count:1;}}
#node-landingpage_2023 #mission .lp-mm-box .lp-bento-tile strong,
#node-landingpage_2023 #mission .lp-mm-box .lp-bento-tile strong span{font-size:19px;font-weight:600;line-height:1.4;letter-spacing:normal;}
/* Mission „Warum MOREMEDIA"-Block: Eyebrow/Headline/Einleitung außerhalb der Box, nur die Liste im Sand-Kasten */
#node-landingpage_2023 #mission .lp-topic.lp-mm-box{background:none;border:0;border-top:1px solid var(--line);border-radius:0;padding:clamp(40px,5vw,72px) 0 0;margin-top:clamp(40px,5vw,72px);}
#node-landingpage_2023 #mission .lp-mm-inner{background:var(--paper-warm);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:clamp(30px,4vw,60px);margin-top:clamp(34px,4vw,60px);}
#node-landingpage_2023 #mission .lp-topic:has(ul):not(.lp-mm-box) > p:not(.ht-eyebrow){display:none;}
#node-landingpage_2023 #mission .lp-mm-box .lp-topic-h{font-size:clamp(2.1rem,4.2vw,51px);line-height:1.1;letter-spacing:-.02em;}
#node-landingpage_2023 #mission .lp-bento-tile{border-bottom:1px solid var(--line);}
/* Härtung: „letzte zwei ohne Trennlinie" gilt NUR im 2-Spalter (Desktop/Tablet).
   Am Smartphone (1-Spalter) greift die Einspalter-Regel weiter oben → nur der letzte
   Eintrag ohne Strich. Sonst verliert die vorletzte Kachel (z. B. div:nth-child(4))
   am Smartphone fälschlich ihre Trennlinie. */
@media(min-width:681px){
  #node-landingpage_2023 #mission .lp-bento-grid .lp-bento-tile:nth-last-child(-n+2){border-bottom:0;}
}
#node-landingpage_2023 #mission .text p:last-child{margin-bottom:0;}
@media(max-width:760px){#node-landingpage_2023 #mission .text{column-count:1;}}
/* FAQ-Seite: Referenzen-Slider + Leistungs-Block entfernen */
.page-node-285 #referenzen_slider,
.page-node-285 #werte,
.page-node-285 #galerie{display:none;}
.page-node-285 #mission .mission > .untertitel,
.page-node-285 #mission .mission > h2,
.page-node-285 #mission .typeform-wrapper{display:none;}
.page-node-285 #mission .mission .text{max-width:none;}
.page-node-285 #mission{padding-top:clamp(8px,1.5vw,24px);}
.page-node-285 .faq-filter{display:flex;flex-wrap:wrap;gap:10px;position:sticky;top:clamp(54px,7vh,74px);
  z-index:900;width:100vw;margin-left:calc(50% - 50vw);
  background:transparent;border-bottom:1px solid transparent;
  transition:background .25s var(--ease),border-color .25s var(--ease),backdrop-filter .25s var(--ease);
  padding-block:clamp(11px,1.4vw,16px);
  padding-inline:max(var(--pad), calc((100vw - var(--container))/2 + var(--pad)));
  margin-bottom:clamp(22px,3vw,40px);}
.page-node-285 .faq-filter.is-stuck{background:rgba(255,255,255,.82);
  -webkit-backdrop-filter:saturate(1.4) blur(16px);backdrop-filter:saturate(1.4) blur(16px);
  border-bottom-color:var(--line);}
html[data-mode="dark"] .page-node-285 .faq-filter.is-stuck{background:rgba(21,20,15,.8);}
.page-node-285 .faq-filter button{font-family:var(--font-ui);font-size:.9rem;padding:9px 18px;
  border-radius:var(--r-pill);border:1px solid var(--line-strong);background:none;color:var(--muted);cursor:pointer;
  transition:color .2s var(--ease),background .2s var(--ease),border-color .2s var(--ease);}
.page-node-285 .faq-filter button:hover{color:var(--ink);border-color:var(--ink);}
.page-node-285 .faq-filter button.active{background:var(--ink);color:var(--paper);border-color:var(--ink);}
.page-node-285 .faq-group{margin-bottom:clamp(20px,3vw,44px);}
/* Leistungsübersicht: zweispaltiger SEO-Einleitungstext mit Silbentrennung */
#leistungenNeu .leist-intro{column-count:2;column-gap:clamp(34px,4vw,64px);column-fill:balance;
  max-width:none;margin-top:clamp(44px,5.5vw,82px);text-align:justify;-webkit-hyphens:auto;hyphens:auto;}
#leistungenNeu .leist-intro p{margin:0 0 1em;color:var(--ink-2);font-size:19px;line-height:1.6;break-inside:avoid-column;}
#leistungenNeu .leist-intro p:last-child{margin-bottom:0;}
/* Einspaltige Version (Smartphone): SEO-Einleitungstext ausblenden, damit man
   nicht erst daran vorbeiscrollen muss, um zu den Leistungen zu gelangen. */
@media(max-width:760px){#leistungenNeu .leist-intro{display:none;}}
.page-node-285 .faq-cat-title{font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.4rem,2.4vw,2rem);letter-spacing:-.02em;line-height:1.1;color:var(--ink);
  margin:0 0 clamp(10px,1.4vw,20px);padding-top:clamp(20px,2.4vw,34px);border-top:1px solid var(--ink);}
.page-node-285 .faq-group:first-of-type .faq-cat-title{padding-top:0;border-top:0;}
.page-node-285 #einleitung .faq-einl{max-width:none;column-count:2;column-gap:clamp(34px,4vw,64px);
  column-fill:balance;margin-top:clamp(44px,5.5vw,80px);}
.page-node-285 #einleitung .faq-einl p{break-inside:auto;margin:0;}
.page-node-285 #einleitung .faq-einl p + p{margin-top:1em;}
@media(max-width:680px){.page-node-285 #einleitung .faq-einl{column-count:1;}}
.page-node-285 #einleitung{padding-bottom:clamp(22px,3vw,46px);}

/* ---------- Leistungs-Detailseiten: #werte = FAQ-Akkordeon (wie Referenz-Detailseite) ---------- */
/* nur unten den Sektionsabstand (zu #vision) – oben gilt das normale Block-/Eyebrow-Muster
   (sonst doppelter Abstand zwischen Vorgehensweise und Häufige Fragen) */
#node-landingpage_2023 #werte{padding-bottom:var(--sec-y);}
#node-landingpage_2023 #werte .werte{display:grid;grid-template-columns:minmax(0,34%) minmax(0,1fr);
  gap:clamp(28px,6vw,100px);align-items:start;padding:0;}
#node-landingpage_2023 #werte .text-wrapper{position:sticky;top:clamp(120px,26vh,260px);width:auto;left:auto;}
#node-landingpage_2023 #werte .text-wrapper .h3{font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.7rem,2.8vw,2.6rem);line-height:1.1;letter-spacing:-.02em;color:var(--ink);}
#node-landingpage_2023 #werte .wrapper{padding:0;border-top:1px solid var(--line);}
#node-landingpage_2023 #werte .wert{padding:0;border-bottom:1px solid var(--line);}
#node-landingpage_2023 #werte .wert .titel{font-family:var(--font-display);font-weight:600;
  font-size:clamp(1.05rem,1.5vw,1.32rem);letter-spacing:-.005em;color:var(--ink);cursor:pointer;
  display:flex;align-items:flex-start;justify-content:space-between;gap:1.2em;
  padding:clamp(20px,2.2vw,28px) 0;transition:color .25s var(--ease);}
#node-landingpage_2023 #werte .wert .titel::after{content:"";flex:0 0 auto;width:16px;height:16px;margin-top:.28em;
  background:currentColor;-webkit-mask:var(--mm-plus) center/contain no-repeat;mask:var(--mm-plus) center/contain no-repeat;
  transition:transform .35s var(--ease);}
#node-landingpage_2023 #werte .wert.open .titel::after{transform:rotate(45deg);}
#node-landingpage_2023 #werte .wert .titel:hover{color:var(--muted);}
#node-landingpage_2023 #werte .wert .text{max-width:70ch;color:var(--ink-2);-webkit-hyphens:auto;hyphens:auto;
  font-size:clamp(1rem,1.02vw,1.08rem);line-height:1.72;
  display:grid;grid-template-rows:0fr;overflow:hidden;opacity:0;
  transition:grid-template-rows .4s var(--ease),opacity .4s var(--ease),padding .4s var(--ease);padding:0;}
#node-landingpage_2023 #werte .wert .text>span{min-height:0;display:block;}
#node-landingpage_2023 #werte .wert.open .text{grid-template-rows:1fr;opacity:1;padding:0 0 clamp(22px,2.4vw,30px);}
:root{--mm-plus:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath d='M7 0h2v16H7z'/%3E%3Cpath d='M0 7h16v2H0z'/%3E%3C/svg%3E");}
@media(max-width:860px){
  #node-landingpage_2023 #werte .werte{grid-template-columns:1fr;gap:20px;}
  #node-landingpage_2023 #werte .text-wrapper{position:static;}
}

/* ---------- #galerie (Referenzen-Übersicht): gleiche Spalten, lockeres Raster, Featured ---------- */
#node-referenzen_uebersicht #galerie .galerie{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));
  gap:clamp(26px,3.4vw,64px) clamp(26px,3.4vw,72px);align-items:start;}
#node-referenzen_uebersicht #galerie .views-row{margin:0;position:relative;}
#node-referenzen_uebersicht #galerie .views-row .bild{width:100%;overflow:hidden;border-radius:var(--r-md);aspect-ratio:auto;}
#node-referenzen_uebersicht #galerie .views-row .video-container{position:relative;width:100%;
  aspect-ratio:16/10;height:auto;padding:0;overflow:hidden;background:var(--paper-warm-2);}
#node-referenzen_uebersicht #galerie .views-row .video-container video,
#node-referenzen_uebersicht #galerie .views-row .video-container img{position:absolute;inset:0;
  width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);}
#node-referenzen_uebersicht #galerie .views-row .link:hover .video-container video,
#node-referenzen_uebersicht #galerie .views-row .link:hover .video-container img{transform:scale(1.05);}
#node-referenzen_uebersicht #galerie .views-row:nth-child(5n+2){margin-top:clamp(36px,7vw,108px);}
#node-referenzen_uebersicht #galerie .views-row:nth-child(5n+3){margin-top:clamp(26px,5vw,76px);}
#node-referenzen_uebersicht #galerie .views-row:nth-child(5n+2) .video-container,
#node-referenzen_uebersicht #galerie .views-row:nth-child(5n+3) .video-container{aspect-ratio:16/10;}
#node-referenzen_uebersicht #galerie .views-row:nth-child(5n+5){grid-column:auto;}
#node-referenzen_uebersicht #galerie .views-row:nth-child(5n+5) .video-container{aspect-ratio:16/10;}
#node-referenzen_uebersicht #galerie .content-html{padding-top:clamp(12px,1vw,18px);}
#node-referenzen_uebersicht #galerie .content-html .kunde{font-size:.72rem;text-transform:uppercase;
  letter-spacing:.14em;color:var(--muted);margin-bottom:5px;}
#node-referenzen_uebersicht #galerie .content-html .title{font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.05rem,1.5vw,1.4rem);line-height:1.18;letter-spacing:-.01em;color:var(--ink);}
@media(max-width:760px){
  #node-referenzen_uebersicht #galerie .galerie{grid-template-columns:1fr;gap:30px;}
  #node-referenzen_uebersicht #galerie .views-row{margin-top:0!important;}
  #node-referenzen_uebersicht #galerie .views-row .video-container,
  #node-referenzen_uebersicht #galerie .views-row:nth-child(5n+5) .video-container{aspect-ratio:16/10;}
}

/* ===== Konvergenz-Feinschliff (Review-Pass) ===== */

/* #mission (Agentur): zweispaltiger Statement-Text wie auf der Startseite */
#node-agentur #mission .mission .text{max-width:none;column-count:2;column-gap:clamp(34px,4vw,64px);}
#node-agentur #mission .mission .text p{break-inside:auto;font-size:19px;}
@media(max-width:760px){#node-agentur #mission .mission .text{column-count:1;}}

/* #galerie (Agentur „Über uns"): zwei unabhängige Spalten, Originalformate, Parallax */
#node-agentur #galerie{overflow:hidden;padding-top:clamp(24px,4.5vw,80px);}
#node-agentur #galerie .galerie{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:clamp(34px,4vw,64px);align-items:start;}
#node-agentur #galerie .galerie .bg{display:none;}
#node-agentur #galerie .gcol{display:flex;flex-direction:column;gap:clamp(34px,4vw,64px);will-change:transform;}
#node-agentur #galerie .galerie .item{margin:0;}
#node-agentur #galerie .galerie .item .image-wrapper{overflow:hidden;border-radius:var(--r-md);}
#node-agentur #galerie .galerie .item .image-wrapper img{display:block;width:100%;height:auto;transition:transform .6s var(--ease);}
#node-agentur #galerie .galerie .item:hover .image-wrapper img{transform:scale(1.04);}
#node-agentur #galerie .galerie .item .text{display:flex;align-items:center;justify-content:center;text-align:center;
  font-family:var(--font-display);font-weight:500;font-size:clamp(1.05rem,1.6vw,1.55rem);line-height:1.34;
  letter-spacing:-.01em;color:var(--ink);}
/* Gründer-Block: eigener designter Block — Sand-Karte, Porträt + Statement als Zitat */
#node-agentur #galerie .mm-founder{display:grid;grid-template-columns:minmax(0,300px) 1fr;gap:clamp(30px,4.5vw,68px);align-items:center;
  margin-top:clamp(44px,6vw,90px);margin-bottom:clamp(-84px,-7vw,-44px);margin-inline:calc(clamp(14px,1.8vw,30px) - clamp(20px,5vw,140px));padding:clamp(30px,4vw,60px);background:var(--paper-warm);border-radius:var(--r-lg);}
#node-agentur #galerie .mm-founder .item{margin:0;}
#node-agentur #galerie .mm-founder .mm-portrait-square{border-radius:var(--r-md);box-shadow:0 26px 60px -30px rgba(21,20,15,.45);}
#node-agentur #galerie .mm-founder .text{position:relative;padding-left:clamp(18px,2vw,28px);border-left:2px solid var(--ink);
  font-family:var(--font-display);font-weight:500;font-size:clamp(1.2rem,1.7vw,1.65rem);line-height:1.46;letter-spacing:-.012em;color:var(--ink);max-width:none;}
#node-agentur #galerie .mm-founder .text .mm-leitsatz{font-weight:700;color:var(--ink);}
@media(max-width:680px){
  #node-agentur #galerie .galerie{grid-template-columns:1fr;}
  #node-agentur #galerie .gcol{gap:clamp(16px,4vw,28px);}
  #node-agentur #galerie .mm-founder{grid-template-columns:1fr;gap:clamp(20px,5vw,28px);padding:clamp(22px,5vw,30px);margin-top:clamp(60px,18vw,80px);margin-bottom:clamp(-80px,-18vw,-60px);margin-inline:0;}
  #node-agentur #galerie .mm-founder .text{font-size:clamp(1rem,4vw,1.18rem);}
}

/* Agentur-Hero: zweispaltiger Einleitungstext unter der Headline */
#node-agentur #einleitung{padding-bottom:0;}
#node-agentur #einleitung .einl-intro{column-count:2;column-gap:clamp(34px,4vw,64px);column-fill:balance;
  max-width:none;margin-top:clamp(34px,4.5vw,64px);text-align:justify;-webkit-hyphens:auto;hyphens:auto;}
#node-agentur #einleitung .einl-intro p{break-inside:avoid-column;margin:0 0 1em;color:var(--ink-2);
  font-size:19px;line-height:1.7;}
#node-agentur #einleitung .einl-intro p:last-child{margin-bottom:0;}
@media(max-width:760px){#node-agentur #einleitung .einl-intro{column-count:1;}}
#node-agentur #kunden .untertitel{max-width:var(--container);margin-left:auto;margin-right:auto;padding-inline:var(--pad);width:100%;}
#node-agentur #kunden .kunden{width:100vw;margin-left:calc(-1 * (100vw - 100%)/2);margin-top:clamp(18px,2.4vw,38px);gap:clamp(4px,.8vw,14px);}
#node-agentur #kunden .kunden .row{-webkit-mask-image:none;mask-image:none;overflow:hidden;}
#node-agentur #kunden .kunden .item{color:transparent;-webkit-text-stroke:0.5px var(--ink);
  font-size:clamp(2.4rem,4.6vw,4.4rem);font-weight:700;letter-spacing:-.015em;padding:0;gap:0;
  transition:color .3s var(--ease),-webkit-text-stroke-color .3s var(--ease);}
#node-agentur #kunden .kunden .item::after{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;
  border:0.5px solid var(--ink);background:transparent;opacity:1;flex:0 0 auto;margin:0 clamp(18px,1.9vw,36px);align-self:center;}
#node-agentur #kunden .kunden .item a{color:inherit;-webkit-text-stroke:inherit;}
#node-agentur #kunden .kunden:hover .row .items{animation-play-state:running;}
#node-agentur #kunden .kunden .item:hover,#node-agentur #kunden .kunden .item a:hover{color:var(--ink);-webkit-text-stroke-color:var(--ink);}

/* Zweispalten-Statement: Headline über volle Breite beider Spalten */
#node-agentur #mission .mission .h1{max-width:none;}

/* Leistungs-FAQ: einspaltig + identisches .faq-item-Styling wie Referenz-Detailseite */
#node-landingpage_2023 #werte .werte{display:block;}
#node-landingpage_2023 #werte .text-wrapper{position:static;max-width:62ch;}
#node-landingpage_2023 #werte .text-wrapper .h3{font-size:clamp(1.9rem,3.6vw,3.2rem);}
#node-landingpage_2023 #werte .wrapper{border-top:0;}
#node-landingpage_2023 #werte .faq-list{margin-top:clamp(34px,4.5vw,60px);}

/* ---------- Leistungs-Detailseiten: Positions-/Ankermenü (fixed, erscheint beim Scrollen wie 2. Header) ---------- */
.lp-anchornav{position:fixed;left:0;right:0;top:0;z-index:899;width:100%;
  background:rgba(255,255,255,.82);
  -webkit-backdrop-filter:saturate(1.4) blur(16px);backdrop-filter:saturate(1.4) blur(16px);
  border-bottom:1px solid var(--line);
  transform:translateY(-110%);opacity:0;pointer-events:none;
  transition:transform .42s cubic-bezier(.22,.61,.36,1),opacity .3s var(--ease),top .42s cubic-bezier(.22,.61,.36,1);}
.lp-anchornav.is-visible{transform:translateY(0);opacity:1;pointer-events:auto;}
html[data-mode="dark"] .lp-anchornav{background:rgba(21,20,15,.8);}
.lpa-inner{max-width:var(--container);margin:0 auto;padding:clamp(9px,1vw,13px) var(--pad);
  display:flex;align-items:center;gap:clamp(16px,2.6vw,44px);}
.lpa-crumb{display:flex;align-items:center;gap:.55em;font-size:12px;letter-spacing:.06em;
  text-transform:uppercase;white-space:nowrap;flex:0 0 auto;}
.lpa-crumb a{color:var(--muted);text-decoration:none;transition:color .2s var(--ease);}
.lpa-crumb a:hover{color:var(--ink);}
.lpa-sep{color:var(--muted-2);}
.lpa-cur{color:var(--ink);font-weight:600;}
.lpa-links{display:flex;align-items:center;gap:clamp(14px,1.8vw,28px);
  overflow-x:auto;scrollbar-width:none;flex:1 1 auto;}
.lpa-links::-webkit-scrollbar{display:none;}
.lpa-link{font-size:.9rem;color:var(--muted);text-decoration:none;white-space:nowrap;
  padding:6px 1px;position:relative;background:none;transition:color .22s var(--ease);}
.lpa-link::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--ink);
  transform:scaleX(0);transform-origin:left;transition:transform .28s var(--ease);}
.lpa-link:hover{color:var(--ink);}
.lpa-link.is-active{color:var(--ink);}
.lpa-link.is-active::after{transform:scaleX(1);}
html[data-accent]:not([data-accent="kein"]) .lpa-link.is-active::after{background:var(--accent);}
/* Breadcrumb „Leistungen": Hover-Megamenü zum schnellen Wechsel */
.lpa-leist{position:relative;display:inline-flex;align-items:center;}
.lpa-mega{position:absolute;top:100%;left:0;padding-top:12px;z-index:6;
  opacity:0;visibility:hidden;transform:translateY(6px);pointer-events:none;
  transition:opacity .2s var(--ease),transform .2s var(--ease),visibility .2s;}
.lpa-leist:hover .lpa-mega,.lpa-mega:hover{opacity:1;visibility:visible;transform:none;pointer-events:auto;}
.lpa-mega-in{background:rgba(255,255,255,.97);-webkit-backdrop-filter:saturate(1.4) blur(18px);backdrop-filter:saturate(1.4) blur(18px);
  border:1px solid var(--line);border-radius:var(--r-md);box-shadow:0 22px 54px rgba(20,18,10,.18);
  padding:10px;display:grid;grid-template-columns:1fr 1fr;gap:2px 6px;}
html[data-mode="dark"] .lpa-mega-in{background:rgba(28,26,20,.97);}
.lpa-mega-link{display:block;font-size:.88rem;letter-spacing:0;text-transform:none;color:var(--ink-2);
  text-decoration:none;padding:9px 14px;border-radius:8px;white-space:nowrap;
  transition:background .18s var(--ease),color .18s var(--ease);}
.lpa-mega-link:hover{background:var(--paper-warm-2);color:var(--ink);}
.lpa-mega-link.is-current{color:var(--ink);font-weight:600;background:var(--paper-warm);}
@media(max-width:720px){.lpa-mega{display:none;}}
/* Anker-Sprungziele: Offset unter fixem Header + Ankermenü */
#node-landingpage_2023 #einleitung,#node-landingpage_2023 #galerie,#node-landingpage_2023 #mission,
#node-landingpage_2023 #lp-prozess,#node-landingpage_2023 #werte,#node-landingpage_2023 #vision{scroll-margin-top:clamp(112px,16vh,152px);}
@media(max-width:720px){.lpa-crumb .lpa-cur,.lpa-crumb .lpa-sep{display:none;}}

/* Case-Study Bild-Slider (.slider-container) — auf Hero-Breite (kleiner Abstand zu den
   Bildschirmrändern, nichts ragt bis zum Rand), echte Navigation */
.row.slider .slider-container,.slider-container{position:relative;width:100vw;margin-left:calc(50% - 50vw);max-width:none;padding-inline:0;box-sizing:border-box;}
/* Smartphone: full-bleed wie #lp-prozess; aktive Karte = Inhaltsbreite, zentriert, Nachbarn bis zum Rand angeschnitten */
@media(max-width:640px){.row.slider .slider-container,.slider-container{width:100vw;margin-left:calc(50% - 50vw);max-width:none;padding-inline:0;}}
.slider-container .slider-viewport{overflow:hidden;border-radius:0;background:var(--paper);}
.slider-container .slider{display:flex;transition:transform .55s var(--ease);will-change:transform;}
.slider-container .slider-item{flex:0 0 100%;min-width:0;background:var(--paper);}
.slider-container .slider-item img{width:100%;height:auto;display:block;aspect-ratio:16/9;object-fit:cover;}
/* Endlos-/Peek-Slider: aktive Kachel groß & scharf, Nachbarn leicht gedimmt; Video-Steuerung */
.slider-container .slider-item{position:relative;border-radius:var(--r-md);overflow:hidden;transition:opacity .4s var(--ease);}
.slider-container .slider-item video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.slider-container .slider-item:not(.is-active){opacity:.5;}
.slider-container .slider-item > a{display:none;}
.sl-vctrl{position:absolute;right:clamp(10px,1.4vw,16px);bottom:clamp(10px,1.4vw,16px);display:flex;gap:8px;z-index:5;
  opacity:0;transition:opacity .3s var(--ease);}
.slider-container .slider-item.is-active .sl-vctrl{opacity:1;}
.sl-vbtn{width:42px;height:42px;border-radius:50%;border:0;cursor:pointer;background:rgba(21,20,15,.55);color:#fff;
  display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);
  transition:background .2s var(--ease);}
.sl-vbtn:hover{background:var(--ink);}
.sl-vbtn svg{width:20px;height:20px;display:block;}
@media(hover:none){.sl-vctrl{opacity:1;}}
/* Punkte-Navigation */
.slider-container .slider-dots{display:flex;justify-content:flex-start;gap:10px;margin-top:clamp(18px,2vw,28px);margin-bottom:clamp(40px,6vw,88px);padding-inline:max(var(--pad),calc((100vw - var(--container))/2 + var(--pad)));}
.slider-container .slider-dot{width:9px;height:9px;border-radius:50%;border:0;padding:0;cursor:pointer;
  background:var(--line-strong);opacity:.5;transition:opacity .25s var(--ease),transform .25s var(--ease);}
.slider-container .slider-dot:hover{opacity:.8;}
.slider-container .slider-dot.active{opacity:1;background:var(--ink);transform:scale(1.25);}
/* Custom-Cursor */
.slc-cursor{position:fixed;top:0;left:0;z-index:9999;width:84px;height:84px;margin:-42px 0 0 -42px;
  border-radius:50%;background:var(--ink);color:#fff;box-shadow:0 8px 30px rgba(21,20,15,.34);
  display:flex;align-items:center;justify-content:center;pointer-events:none;
  opacity:0;transform:scale(.55);transition:opacity .22s var(--ease),transform .22s var(--ease),background .22s var(--ease);}
.slc-cursor.show{opacity:1;transform:scale(1);}
.slc-cursor .ic{position:absolute;inset:0;margin:auto;width:40px;height:40px;opacity:0;transform:scale(.6);
  transition:opacity .2s var(--ease),transform .2s var(--ease);}
.slc-cursor.z-prev .ic-prev,.slc-cursor.z-next .ic-next,.slc-cursor.z-mid .ic-mid{opacity:1;transform:scale(1);}
.slc-cursor.z-prev{animation:slc-nudge-l 1s var(--ease) infinite;}
.slc-cursor.z-next{animation:slc-nudge-r 1s var(--ease) infinite;}
.slc-cursor.z-mid{background:#fff;color:var(--ink);box-shadow:0 8px 30px rgba(21,20,15,.28),0 0 0 1px var(--line) inset;}
@keyframes slc-nudge-l{0%,100%{margin-left:-42px;}50%{margin-left:-49px;}}
@keyframes slc-nudge-r{0%,100%{margin-left:-42px;}50%{margin-left:-35px;}}
@media(prefers-reduced-motion:reduce){.slc-cursor.z-prev,.slc-cursor.z-next{animation:none;}}
.slider-container .slider-navigation{position:absolute;top:calc(50% - 26px);left:14px;right:14px;
  display:flex;justify-content:space-between;transform:translateY(-50%);pointer-events:none;}
.slider-container .slider-navigation a{pointer-events:auto;width:54px;height:54px;border-radius:50%;
  background:rgba(21,20,15,.5);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:background .25s var(--ease);font-size:1.2rem;}
.slider-container .slider-navigation a:hover{background:var(--ink);}

/* ---------- Legal / Info-Seiten (Datenschutz, Barrierefreiheit, AGB) ---------- */
#node-legal #einleitung,#node-legal #einleitungNeu{padding-bottom:clamp(40px,6vw,90px);}
#node-legal .legal{display:block;padding-bottom:clamp(96px,14vh,180px);}
#node-legal .legal-nav{display:none;}
#node-legal .legal-body{max-width:none;column-count:2;column-gap:clamp(40px,5vw,84px);column-fill:balance;}
#node-legal .legal-body section{break-inside:avoid;}
/* Langform-Rechtstext (Datenschutz): höhen-balancierte zwei Spalten */
#node-legal .legal-body.is-longform{column-count:2;column-gap:clamp(40px,5vw,88px);max-width:none;}
/* Lead-/Intro-Absatz: volle Breite über beiden Spalten + klarer Abstand nach unten (wie zwischen den Abschnitten) */
#node-legal .legal-body.is-longform .legal-lead{column-span:all;font-size:clamp(1.05rem,1.2vw,1.2rem);
  line-height:1.7;color:var(--ink-2);max-width:82ch;margin:0 0 clamp(34px,4vw,60px);}
/* Langform: Sektionen DÜRFEN über die Spaltengrenze fließen, sonst erzwingt ein
   sehr langer Abschnitt (z. B. „Pflichtinformationen") ungleich hohe Spalten.
   Headings behalten break-after:avoid → keine verwaisten Überschriften am Spaltenende.
   So verteilt column-fill:balance den Inhalt gleichmäßig auf beide Spalten. */
#node-legal .legal-body.is-longform section{margin:0 0 clamp(34px,4vw,60px);break-inside:auto;}
/* Deterministische Spalten (Barrierefreiheit etc.): gleiche Starthöhe, jede Spalte beginnt mit Headline + Trennlinie */
#node-legal .legal-body.is-cols{column-count:auto;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));
  gap:0 clamp(40px,5vw,84px);align-items:start;}
#node-legal .legal-body.is-cols .ds-col{min-width:0;}
/* Rechtsseiten: keine Trennlinien zwischen den Punkten (Abstand bleibt) */
#node-legal .legal-body.is-cols .ds-col>section{border-top:0;
  padding:clamp(20px,2.2vw,27px) 0 clamp(16px,1.8vw,22px);margin:0;break-inside:avoid;}
/* in jeder Spalte: oberster Punkt ohne Linie darüber, unterster ohne Linie/Abstand darunter */
#node-legal .legal-body.is-cols .ds-col>section:first-child{border-top:0;padding-top:0;}
#node-legal .legal-body.is-cols .ds-col>section:last-child{margin-bottom:0;}
#node-legal .legal-body.is-cols .legal-lead{grid-column:1/-1;font-size:clamp(1rem,1.1vw,1.15rem);line-height:1.7;
  color:var(--ink-2);max-width:82ch;margin:0 0 clamp(18px,2.2vw,30px);}
#node-legal .legal-body.is-cols .legal-meta{grid-column:1/-1;font-size:.85rem;color:var(--muted);
  margin:clamp(16px,2vw,26px) 0 0;}
#node-legal .legal-body.is-longform h2{font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.5rem,2.6vw,2.2rem);letter-spacing:-.02em;line-height:1.12;color:var(--ink);
  margin:0 0 .8em;padding-bottom:.45em;border-bottom:1px solid var(--line);break-after:avoid;break-inside:avoid;}
#node-legal .legal-body.is-longform h3{font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.15rem,1.7vw,1.4rem);letter-spacing:-.01em;color:var(--ink);margin:1.8em 0 .5em;break-after:avoid;break-inside:avoid;}
#node-legal .legal-body.is-longform h3:first-child,
#node-legal .legal-body.is-longform h2 + h3{margin-top:0;}
#node-legal .legal-body.is-longform h4{font-family:var(--font-ui);font-weight:600;
  font-size:1rem;color:var(--ink);margin:1.3em 0 .4em;break-after:avoid;break-inside:avoid;}
#node-legal .legal-body.is-longform p{margin:0 0 1em;color:var(--ink-2);line-height:1.7;}
#node-legal .legal-body.is-longform ul{margin:0 0 1em;padding-left:1.2em;color:var(--ink-2);line-height:1.7;}
#node-legal .legal-body.is-longform li{margin-bottom:.5em;}
#node-legal .legal-body.is-longform a{color:var(--ink);text-decoration:underline;
  text-underline-offset:3px;text-decoration-color:var(--line-strong);word-break:break-word;}
#node-legal .legal-body.is-longform .legal-address{color:var(--ink);font-weight:500;}
#node-legal .legal-body.is-longform .legal-caps{font-size:.82rem;letter-spacing:.01em;
  color:var(--muted);background:var(--paper-warm);border-radius:var(--r-md);padding:1.1em 1.3em;line-height:1.6;}
#node-legal .legal-body.is-longform .meta{font-size:.85rem;color:var(--muted);margin-top:1.4em;}
@media(max-width:860px){#node-legal .legal-body.is-longform{column-count:1;}
  #node-legal .legal-body.is-cols{grid-template-columns:1fr;}
  /* einspaltig: durchgehende Trennlinien — nur ganz oben keine, ganz unten keine */
  #node-legal .legal-body.is-cols .ds-col:last-child>section:first-child{border-top:1px solid var(--line);padding-top:clamp(14px,1.6vw,20px);}
  #node-legal .legal-body.is-cols .ds-col:first-child>section:last-child{margin-bottom:clamp(14px,1.6vw,20px);}}
#node-legal .legal-body:not(.is-longform) section{padding-bottom:clamp(34px,4vw,58px);}
#node-legal .legal-body:not(.is-longform) section+section{border-top:1px solid var(--line);padding-top:clamp(34px,4vw,58px);}
#node-legal .legal-body.is-longform section{padding-bottom:0;}
#node-legal .legal-body.is-longform section+section{border-top:0;padding-top:0;}
#node-legal .legal-body h2{font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.4rem,2.4vw,2.05rem);letter-spacing:-.02em;margin-bottom:.55em;color:var(--ink);}
#node-legal .legal-body h3{font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.05rem,1.4vw,1.28rem);letter-spacing:-.01em;margin:1.5em 0 .45em;color:var(--ink);}
#node-legal .legal-body p,#node-legal .legal-body li{font-size:clamp(1rem,1.02vw,1.1rem);
  line-height:1.76;color:var(--ink-2);}
#node-legal .legal-body p+p{margin-top:1em;}
#node-legal .legal-body ul{margin:.7em 0 0;display:grid;gap:.5em;}
#node-legal .legal-body ul li{position:relative;padding-left:1.3em;}
#node-legal .legal-body ul li::before{content:"";position:absolute;left:0;top:.66em;width:6px;height:6px;
  border-radius:50%;background:var(--muted-2);}
#node-legal .legal-body a{color:var(--ink);text-decoration:underline;text-underline-offset:3px;
  text-decoration-color:var(--line-strong);}
#node-legal .legal-body a:hover{text-decoration-color:currentColor;}
#node-legal .legal-body .ref-line{display:grid;grid-template-columns:minmax(0,180px) 1fr;gap:6px 24px;
  margin-top:1.5em;}
#node-legal .legal-body .ref-line dt{color:var(--muted);font-size:.95rem;}
#node-legal .legal-body .ref-line dd{margin:0;color:var(--ink);}
#node-legal .legal-body .meta{font-size:.85rem;color:var(--muted);margin-top:2.4em;}
@media(max-width:860px){
  #node-legal .section:has(.imp-card){grid-template-columns:1fr;}
  #node-legal .imp-card{position:static;}
  #node-legal .legal-body{column-count:1;}
  #node-legal .legal-body .ref-line{grid-template-columns:1fr;gap:0;}
  #node-legal .legal-body .ref-line dt{margin-top:.6em;}
}

/* Impressum als kompakte Karte */
#node-legal .section:has(.imp-card){display:grid;grid-template-columns:repeat(2,minmax(0,1fr));
  gap:clamp(30px,5vw,84px);align-items:start;padding-bottom:clamp(96px,14vh,180px);}
#node-legal .imp-card{max-width:none;margin:0;background:none;border:0;border-radius:0;padding:0;position:static;}
#node-legal .imp-eyebrow{font-size:.7rem;text-transform:uppercase;letter-spacing:.16em;color:var(--muted);margin:0 0 12px;}
#node-legal .imp-name{font-family:var(--font-display);font-weight:700;font-size:clamp(1.8rem,3.4vw,2.6rem);
  letter-spacing:-.02em;margin:0 0 clamp(18px,2.4vw,28px);color:var(--ink);}
#node-legal .imp-data{display:grid;gap:0;}
#node-legal .imp-data>div{display:grid;grid-template-columns:minmax(0,140px) 1fr;gap:6px 24px;
  padding:clamp(11px,1.3vw,15px) 0;border-top:1px solid var(--line);}
#node-legal .imp-data dt{color:var(--muted);font-size:.95rem;}
#node-legal .imp-data dd{margin:0;color:var(--ink);font-size:1.02rem;line-height:1.5;}
#node-legal .imp-data a{color:var(--ink);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--line-strong);}
#node-legal .imp-legal{max-width:74ch;margin:0;}
#node-legal .imp-legal section{padding:clamp(20px,2.2vw,27px) 0 clamp(16px,1.8vw,22px);}
#node-legal .imp-legal section:first-child{border-top:0;padding-top:0;}
#node-legal .imp-legal h3{font-family:var(--font-display);font-weight:700;font-size:clamp(1.4rem,2.4vw,2.05rem);
  letter-spacing:-.02em;margin:0 0 .55em;color:var(--ink);}
#node-legal .imp-legal p{color:var(--ink-2);line-height:1.75;font-size:1rem;}
#node-legal .imp-legal a{color:var(--ink);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--line-strong);}
#node-legal .imp-stand{font-size:.85rem;color:var(--muted);margin-top:2.2em;}
/* Impressum: zwei Spalten ab Smartphone/kleineren Breiten untereinander
   (muss NACH der Basis-Grid-Regel stehen, sonst überschreibt diese die Stapelung) */
@media(max-width:1024px){
  #node-legal .section:has(.imp-card){grid-template-columns:1fr;padding-bottom:clamp(64px,12vh,120px);}
  #node-legal .imp-card{position:static;}
}

/* Agentur-Galerie: Textkacheln im selben Format wie die Bilder (gleichmäßiges Raster) */
#node-agentur #galerie .galerie .item:has(>.text){align-items:stretch;}
#node-agentur #galerie .galerie .item>.text{width:100%;height:100%;max-width:none;margin:0;aspect-ratio:4/3;
  background:var(--paper-warm);border-radius:var(--r-md);padding:clamp(24px,2.8vw,48px);
  align-items:center;font-size:clamp(1.1rem,1.7vw,1.6rem);line-height:1.34;}
/* Smartphone: Textkacheln hoch genug (kein festes 4:3, Höhe wächst mit dem Text) */
@media(max-width:760px){
  #node-agentur #galerie .galerie .item>.text{aspect-ratio:auto;height:auto;min-height:0;
    font-size:clamp(1.05rem,4.6vw,1.3rem);padding:clamp(22px,6vw,32px);}
}

/* ============================================================
   SMARTPHONE-OPTIMIERUNG (≤760px)
   kompaktere Typo · Silbentrennung · kein Sticky-Header ·
   runder Burger · Bottom-Sheet-Navigation · zentrierte Rechtsmenü
   ============================================================ */
@media(max-width:760px){
  /* — lange Wörter (z. B. „Datenschutzerklärung") nie über den Rand — */
  h1,h2,h3,h4,.h1,.h3,.title,.untertitel,.subtitle,p,li,dt,dd,strong,a,
  .lpa-cur,.ed-eyebrow,.ht-eyebrow{ -webkit-hyphens:auto;hyphens:auto;overflow-wrap:break-word;word-break:normal; }

  /* — Typo eine Spur kleiner, Fließtext enger, etwas mehr Rand — */
  :root{ --pad:clamp(28px,7.6vw,46px); }
  body{ font-size:15px; }
  /* Einheitlicher Abstand Header → erster Block (Eyebrow) auf ALLEN Seiten (Smartphone) */
  #intro,#einleitung,#einleitungNeu,#leistungenNeu,
  #node-landingpage_2023 #einleitung{ padding-top:clamp(88px,24vw,112px); }
  /* Fließtext site-weit einheitlich: gleiche Schriftgröße + Zeilenabstand wie der
     Intro-Lead (1.15rem / 1.5). Hoch-spezifische Komponenten-Selektoren explizit
     gelistet, damit der Zeilenabstand wirklich überall identisch ist. */
  .text p,.body p,.text,.body,
  .row.text .body p,
  #node-landingpage_2023 #einleitung .einl-intro p,
  #node-agentur #einleitung .einl-intro p,
  #node-landingpage_2023 #mission .text p,
  #node-landingpage_2023 #mission .lp-lead,
  #node-landingpage_2023 #mission .lp-topic p,
  #node-landingpage_2023 #mission .lp-topic:has(ul) > p,
  #leistungenNeu .leist-intro p,
  .page-insights-article .art-body p,
  .lo-body,.lo-body p,
  #node-legal .legal-body p,#node-legal .imp-legal p{ font-size:1.15rem;line-height:1.5; }
  #node-landingpage_2023 #mission .text ul li,
  #node-landingpage_2023 #mission .lp-topic li{ line-height:1.45; }
  /* Display-Headlines eine Spur kleiner */
  #einleitung h1,#einleitungNeu h1,#leistungenNeu h1,#intro>.section>.title,#kontakt h1.title{
    font-size:clamp(2.1rem,8.4vw,3rem);line-height:1.04;letter-spacing:-.02em; }
  #node-landingpage_2023 #mission .mission>h2.h1{ font-size:clamp(1.5rem,6vw,2.1rem);line-height:1.22; }
  #node-landingpage_2023 #mission .text h2,
  #node-landingpage_2023 #werte .h3{ font-size:clamp(1.45rem,5.6vw,2rem); }

  /* — kein Sticky-Header: Logo scrollt normal mit nach oben — */
  #header{ position:absolute; }
  #header.hide{ transform:none!important; }
  #header.small{ background:transparent!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;
    border-bottom-color:transparent!important;box-shadow:none!important; }

  /* Logo weiter nach unten — vertikal mittig mit dem runden Burger-Button */
  #header .section{ padding-top:27px;padding-bottom:14px;align-items:center; }

  /* — nur runder Burger-Button bleibt fixiert (ohne Wort „Menü") — */
  body.hdr-hide:not(.nav-open) #menu-icon{ transform:none; }
  #menu-icon{ top:13px;right:13px;width:56px;height:56px;border-radius:50%;justify-content:center;gap:0;
    background:rgba(255,255,255,.9);-webkit-backdrop-filter:blur(13px) saturate(1.5);backdrop-filter:blur(13px) saturate(1.5);
    border:1px solid var(--line);box-shadow:0 7px 22px rgba(20,18,10,.2); }
  #menu-icon .menu-label{ display:none!important; }
  #menu-icon #burger{ transform:scale(.6); }
  #menu-icon #burger span,
  body.menu-white:not(.hdr-small) #menu-icon #burger span{ background:var(--ink)!important; }
  body.nav-open #menu-icon{ background:transparent;border-color:transparent;box-shadow:none; }
  body.nav-open #menu-icon #burger span{ background:#fff!important; }
  html[data-mode="dark"] #menu-icon{ background:rgba(28,26,20,.9); }
  html[data-mode="dark"] #menu-icon #burger span{ background:var(--ink)!important; }

  /* — Menüpunkte im Overlay so groß wie möglich, aber per JS automatisch auf die
     Bildschirmbreite skaliert, damit der längste Punkt nie zweizeilig umbricht — */
  #navigation-wrapper #main-menu a{ font-size:clamp(2.6rem, var(--nav-fs, 12vw), 5rem); }

  /* — Kontaktblock näher an den unteren Rand — */
  #navigation-wrapper{ padding-bottom:calc(env(safe-area-inset-bottom,0px) + clamp(14px,2.6vh,26px)); }

  /* — Kontakt-Button kompakt (rund) damit er den Bottom-Trigger nicht stört — */
  #mm-contact.mm-contact--label{ width:60px;height:60px;padding:0;border-radius:50%;justify-content:center; }
  #mm-contact.mm-contact--label .mm-c-label{ display:none; }
  #mm-contact.mm-contact--label .mm-c-ico{ width:24px;height:24px; }

  /* — obere Sticky-Leisten (Anker/Filter) am Smartphone aus — Ersatz: Bottom-Sheet — */
  .lp-anchornav{ display:none!important; }
  .ed-filter,.page-node-285 .faq-filter{ display:none!important; }
  /* Anker-Sprungziele: kein Sticky-Header → kleiner Offset */
  #node-landingpage_2023 #einleitung,#node-landingpage_2023 #galerie,#node-landingpage_2023 #mission,
  #node-landingpage_2023 #lp-prozess,#node-landingpage_2023 #werte,#node-landingpage_2023 #vision{ scroll-margin-top:18px; }
}

/* — Footer „Rechtliches": am Smartphone untereinander + zentriert, Social-Icons zentriert darüber — */
@media(max-width:760px){
  #footer .ft-col.ft-legal{ flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:clamp(16px,4vw,24px); }
  #footer .ft-legal__menu ul.menu{ display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px; }
  #footer .ft-legal__menu ul.menu li{ width:100%; }
  #footer .ft-legal__social{ order:-1;justify-content:center; }
}

/* ---------- Bottom-Sheet (Anker- & Filter-Navigation) ---------- */
/* ---------- Bottom-Dock: Anker-Navigation + Filter + Kontakt + Zurück (vereint) ---------- */
/* alte Inline-Leisten + schwebender Kontaktbutton werden durch das Dock ersetzt */
.lp-anchornav{ display:none!important; }
.ed-filter,.page-node-285 .faq-filter{ display:none!important; }
#mm-contact.mm-contact--docked{ display:none!important; }

.mm-dock{ position:fixed;left:50%;transform:translateX(-50%);z-index:1000;
  bottom:calc(30px + env(safe-area-inset-bottom));
  display:flex;align-items:center;gap:5px;padding:7px;border-radius:var(--r-pill);
  max-width:calc(100vw - 24px);
  background:rgba(247,245,240,.66);-webkit-backdrop-filter:blur(22px) saturate(1.7);backdrop-filter:blur(22px) saturate(1.7);
  border:1px solid var(--line);box-shadow:0 16px 44px rgba(20,18,10,.22);
  transition:opacity .3s var(--ease),visibility .3s,transform .3s var(--ease); }
html[data-mode="dark"] .mm-dock{ background:rgba(28,26,20,.62); }
body.nav-open .mm-dock,body.mm-cov-open .mm-dock{ opacity:0;visibility:hidden;pointer-events:none;transform:translateX(-50%) translateY(14px); }
body.nav-open .mm-pop,body.mm-cov-open .mm-pop,
body.nav-open .mm-pop-scrim,body.mm-cov-open .mm-pop-scrim{ opacity:0!important;visibility:hidden!important;pointer-events:none!important; }
.mm-dock.is-hidden{ opacity:0;visibility:hidden;pointer-events:none;transform:translateX(-50%) translateY(20px); }
.mm-dock-sep{ width:1px;align-self:stretch;margin:6px 2px;background:var(--line);flex:0 0 auto; }
.mm-dock-btn{ display:inline-flex;align-items:center;gap:10px;border:0;cursor:pointer;background:none;color:var(--ink);
  font-family:var(--font-ui);font-weight:600;font-size:1.02rem;line-height:1;white-space:nowrap;
  padding:14px 20px;border-radius:var(--r-pill);transition:background .2s var(--ease),color .2s var(--ease),opacity .2s var(--ease); }
.mm-dock-btn:hover{ background:var(--paper-warm-2); }
.mm-dock-btn .mm-dock-ic{ display:inline-flex; }
.mm-dock-btn .mm-dock-ic svg{ width:20px;height:20px;display:block; }
.mm-dock-label{ overflow:hidden;text-overflow:ellipsis;max-width:42vw; }
.mm-caret{ width:15px;height:15px;flex:0 0 auto;transform:rotate(180deg);transition:transform .25s var(--ease); }
.mm-dock-pop.is-open .mm-caret{ transform:rotate(0deg); }
.mm-dock-pop.is-open{ background:var(--paper-warm-2); }
.mm-dock-btn.is-contact{ background:var(--ink);color:var(--paper); }
.mm-dock-btn.is-contact:hover{ background:var(--ink);opacity:.9; }
html[data-accent]:not([data-accent="kein"]) .mm-dock-btn.is-contact{ background:var(--accent);color:var(--accent-ink); }
.mm-dock-ico{ display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;flex:0 0 auto;
  border-radius:50%;color:var(--ink);text-decoration:none;transition:background .2s var(--ease); }
.mm-dock-ico:hover{ background:var(--paper-warm-2); }
.mm-dock-ico svg{ width:22px;height:22px; }

/* kontextuelles Popover über dem Dock — kontainiert, NICHT volle Breite */
.mm-pop-scrim{ position:fixed;inset:0;z-index:1000;background:rgba(20,18,10,.12);
  opacity:0;visibility:hidden;transition:opacity .25s var(--ease),visibility .25s; }
.mm-pop-scrim.open{ opacity:1;visibility:visible; }
.mm-pop{ position:fixed;left:50%;z-index:1001;
  bottom:calc(104px + env(safe-area-inset-bottom));
  transform:translateX(-50%) translateY(10px);
  width:min(440px,calc(100vw - 24px));max-height:min(58vh,520px);overflow-y:auto;
  background:rgba(247,245,240,.72);-webkit-backdrop-filter:blur(24px) saturate(1.7);backdrop-filter:blur(24px) saturate(1.7);
  border:1px solid var(--line);border-radius:18px;padding:12px;
  box-shadow:0 24px 64px rgba(20,18,10,.28);
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .26s var(--ease),transform .26s var(--ease),visibility .26s; }
.mm-pop.open{ opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0); }
html[data-mode="dark"] .mm-pop{ background:rgba(28,26,20,.7); }
.mm-pop__title{ font-family:var(--font-display);font-weight:700;font-size:1.05rem;letter-spacing:-.01em;
  color:var(--ink);margin:6px 8px 10px; }
.mm-pop__list{ display:flex;flex-direction:column;gap:2px; }
.mm-pop__item{ display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;
  text-align:left;border:0;background:none;cursor:pointer;border-radius:11px;
  font-family:var(--font-ui);font-size:1.02rem;color:var(--ink-2);padding:13px 12px;transition:background .18s var(--ease),color .18s var(--ease); }
.mm-pop__item:hover{ background:var(--paper-warm-2);color:var(--ink); }
.mm-pop__item.is-active{ color:var(--ink);font-weight:600; }
.mm-pop__item.is-active::after{ content:"";width:8px;height:8px;border-radius:50%;flex:0 0 auto;background:var(--accent,var(--ink)); }

.mm-pop__t{flex:1 1 auto;min-width:0;}
.mm-pop__n{flex:0 0 auto;min-width:2em;height:2em;padding:0 .55em;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:.82rem;font-weight:600;background:var(--paper-warm-2);color:var(--ink);}
html[data-accent]:not([data-accent="kein"]) .mm-pop__item.is-active .mm-pop__n{background:var(--accent);color:var(--accent-ink);}
.mm-pop__item{gap:16px;}
@media(max-width:640px){
  .mm-dock{ gap:3px;padding:6px;bottom:calc(18px + env(safe-area-inset-bottom)); }
  .mm-dock-btn{ padding:12px 15px;font-size:.95rem; }
  .mm-dock-pop .mm-dock-label{ display:none; }
  .mm-pop{ bottom:calc(88px + env(safe-area-inset-bottom)); }
}
@media(max-width:430px){ .mm-dock-btn.is-contact .mm-dock-label{ display:none; } }

/* Kontakt-CTA am Smartphone zentriert */
@media(max-width:760px){
  #block-kontakt .wrapper{flex-direction:column;align-items:center!important;text-align:center;gap:26px;}
  #block-kontakt h4.title{text-align:center;}
  #block-kontakt .contact{justify-content:center;}
}

/* ============================================================
   Einspaltig ab „dieser Breite" (Tablet/kleiner): site-weit werden ALLE
   mehrspaltigen Inhaltsblöcke (Galerie-Raster, zweispaltiger Fließtext,
   Bildraster) zu einer einzigen Spalte. Steht bewusst am Dateiende, damit es
   die (unkonditionierten) Mehrspalten-Grundregeln zuverlässig überschreibt.
   ============================================================ */
@media(max-width:1024px){
  /* Galerie-/Projektraster → eine Spalte (Standard-2-Spalten-Raster;
     die Referenzübersicht hat ein eigenes Justified-Layout und bleibt unberührt) */
  .galerie,
  #node-landingpage_2023 #galerie .galerie,
  #node-agentur #galerie .galerie{grid-template-columns:1fr;}
  #node-agentur #galerie .gcol{gap:clamp(20px,4vw,40px);}
  /* Bildraster in Case-Studies → eine Spalte */
  .row.grid-2 .wrapper,.row.grid-3 .wrapper{grid-template-columns:1fr;}
  /* Zweispaltiger Fließtext → eine Spalte */
  #text-block .body,
  .row.text:not(.howto-flow) .body,
  #node-landingpage_2023 #einleitung .einl-intro,
  #node-agentur #einleitung .einl-intro,
  #node-agentur #mission .mission .text,
  #node-landingpage_2023 #mission .lp-topics,
  #node-landingpage_2023 #mission .lp-mm-box > p:not(.ht-eyebrow),
  #leistungenNeu .leist-intro,
  .page-node-285 #einleitung .faq-einl,
  #node-legal .legal-body,
  #node-legal .legal-body.is-longform{column-count:1;}
}

