/* ============================================================
   MOREMEDIA® — Editorial layer (Awwwards-inspired: Locomotive / Metalab)
   Loaded AFTER theme.css on every important page.
   Content-compatible: re-skins existing markup, no content rework.
   ============================================================ */

/* ---------- Editorial section header: oversized index + hairline ---------- */
.region-content #services > .section > .subtitle,
.region-content #services > .section > .untertitel,
#leistungenNeu > .section > .subtitle,
#referenzen_slider > .section > .subtitle,
#fakten > .section > .subtitle,
#mission > .section > .subtitle{ position:relative; }

/* Generic editorial "rule + eyebrow" applied to key section labels */
.ed-eyebrow{display:flex;align-items:center;gap:18px;margin-bottom:clamp(28px,4vw,52px);
  font-family:var(--font-ui);font-weight:500;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);}
.ed-eyebrow .idx{font-variant-numeric:tabular-nums;color:var(--muted);}
.ed-eyebrow .ttl{flex:1;}
.ed-eyebrow .cnt{color:var(--muted);font-variant-numeric:tabular-nums;}

/* ============================================================
   TYPE & SPACING SYSTEM — golden ratio (φ = 1.618)
   Few sizes: eyebrow · section headline · sub-headline · body
   ============================================================ */
:root{
  --gr-1:.618rem; --gr-2:1rem; --gr-3:1.618rem; --gr-4:2.618rem; --gr-5:4.236rem; --gr-6:6.854rem;
  --fs-section:clamp(2.2rem,3.7vw,3.6rem);   /* H2 — section headlines */
  --fs-sub:clamp(1.35rem,1.9vw,1.9rem);    /* H3 — card / list titles */
}
/* consistent eyebrow everywhere: leading strich + label */
.ed-eyebrow{margin-bottom:clamp(20px,2.4vw,32px);}
.ed-eyebrow::before,
.subtitle:not(.kunde):not(.label)::before,
.untertitel::before{content:"";width:38px;height:1px;background:currentColor;
  flex:0 0 auto;display:inline-block;}
.subtitle:not(.kunde):not(.label),.untertitel{display:inline-flex;align-items:center;gap:16px;}
/* one unified section-headline size + golden gap to the body */
#services h3.title,
#mission .h1,#mission .title,
#customers > .section > .title,
#referenzen_slider .h1,#referenzen_slider .title,
#fakten .h1,
.node-referenzen-uebersicht #einleitungNeu .title{
  font-size:var(--fs-section);line-height:1.08;letter-spacing:-.025em;max-width:24ch;
  margin-bottom:var(--gr-3);}
/* unified sub-headline size (project cards, leistungen items, catalog) */
.references .views-row .content-html .title,
.node-referenzen-uebersicht .content-html .title{font-size:var(--fs-sub);}
/* golden section rhythm */
#services,#customers,#mission,#referenzen_slider,#fakten{
  padding-block:clamp(var(--gr-5),9vh,var(--gr-6));}

/* all content shares the (narrower) container width; only preview videos extend past it */
:root{--content-inset:0px;}

/* leistungen list: "+" flush to the right edge of each column */
#services .leistungen .item a.link{display:flex;align-items:center;justify-content:space-between;width:100%;gap:1em;position:relative;}
#services .leistungen .item .read-more{margin-left:auto;flex:0 0 auto;}
#services .leistungen .item h4.title{transition:transform .35s var(--ease);}
#services .leistungen .item a.link:hover h4.title{transform:translateX(12px);}
#services .leistungen .item .read-more{transition:background .4s var(--ease),color .4s,transform .7s cubic-bezier(.65,0,.2,1);}
#services .leistungen .item a.link:hover .read-more{background:var(--ink);color:#fff;transform:rotate(360deg);}

/* Agentur → detail link (like "Alle Projekte", left-aligned) */
.ed-cursor{position:fixed;z-index:9000;top:0;left:0;pointer-events:none;
  transform:translate(-50%,-50%) scale(.6);opacity:0;
  transition:opacity .25s var(--ease),transform .3s var(--ease);
  background:var(--ink);color:#fff;border-radius:999px;padding:.75em 1.25em;
  font-family:var(--font-ui);font-weight:500;font-size:.92rem;white-space:nowrap;
  display:inline-flex;align-items:center;gap:.5em;}
.ed-cursor.show{opacity:1;transform:translate(-50%,-50%) scale(1);}
.ed-cursor-zone{cursor:pointer;}
/* Kontakt-Cursor: animiertes Kontaktsymbol (Kontaktseite + Footer-Email) */
.ed-cursor.is-contact{padding:0!important;width:64px;height:64px;border-radius:50%;justify-content:center;
  background:var(--ink);color:#fff;}
/* über dunklen Flächen (Footer, Menü-Overlay, Kontakt-Overlay): helle Pille, damit sichtbar */
.ed-cursor.is-contact.on-dark{background:#F7F5F0;color:#15140F;}
html[data-accent]:not([data-accent="kein"]) .ed-cursor.is-contact{background:var(--accent);color:var(--accent-ink);}
.ed-cursor.is-contact svg{width:27px;height:27px;animation:mm-contact-spin 3.4s linear infinite;}
/* Mail-Cursor: identische Animation wie das Kontaktsymbol (sanfter Puls, kein Drehen) */
.ed-cursor.is-contact.is-mail svg{animation:mm-chat-pulse 2.6s ease-in-out infinite;transform-origin:center;}
@keyframes mm-contact-spin{to{transform:rotate(360deg);}}
@media(prefers-reduced-motion:reduce){.ed-cursor.is-contact svg{animation:none;}}
/* Route-Cursor (Footer-Adresse → Google Maps) */
.ed-cursor.is-route{padding:0!important;width:62px;height:62px;border-radius:50%;justify-content:center;background:var(--ink);color:#fff;}
.ed-cursor.is-route.on-dark{background:#F7F5F0;color:#15140F;}
html[data-accent]:not([data-accent="kein"]) .ed-cursor.is-route{background:var(--accent);color:var(--accent-ink);}
.ed-cursor.is-route svg{width:26px;height:26px;}
a.ft-adr{display:inline-block;text-decoration:none;color:var(--on-dark-muted);transition:color .25s var(--ease);}
a.ft-adr:hover{color:#fff;}
@media(hover:hover){.ed-route,.ed-route *{cursor:none;}}
/* Kontakt-Symbol (Dock-Button + schwebender FAB) dezent animiert */
@keyframes mm-chat-pulse{0%,100%{transform:scale(1);}45%{transform:scale(1.14);}70%{transform:scale(.98);}}
.mm-dock-btn.is-contact .mm-dock-ic svg,#mm-contact .mm-c-ico svg{animation:mm-chat-pulse 2.6s ease-in-out infinite;transform-origin:center;}
@media(prefers-reduced-motion:reduce){.mm-dock-btn.is-contact .mm-dock-ic svg,#mm-contact .mm-c-ico svg{animation:none;}}
/* Bottom-Dock: einmalige „Schau-her"-Animation beim ersten Erscheinen */
@keyframes mm-dock-attn{
  0%{transform:translateX(-50%) translateY(0) scale(1);box-shadow:0 16px 44px rgba(20,18,10,.22);}
  12%{transform:translateX(-50%) translateY(-16px) scale(1.05);box-shadow:0 30px 66px rgba(20,18,10,.32),0 0 0 5px rgba(217,119,87,.32);}
  28%{transform:translateX(-50%) translateY(0) scale(1);box-shadow:0 16px 44px rgba(20,18,10,.22);}
  40%{transform:translateX(-50%) translateY(-9px) scale(1.03);box-shadow:0 24px 56px rgba(20,18,10,.28),0 0 0 4px rgba(217,119,87,.22);}
  54%{transform:translateX(-50%) translateY(0) scale(1);box-shadow:0 16px 44px rgba(20,18,10,.22);}
  66%{transform:translateX(-50%) translateY(-4px) scale(1.015);}
  100%{transform:translateX(-50%) translateY(0) scale(1);box-shadow:0 16px 44px rgba(20,18,10,.22);}
}
.mm-dock.mm-dock-attn{animation:mm-dock-attn 1.7s cubic-bezier(.34,1.56,.64,1) 1 both;will-change:transform;}
@keyframes mm-dock-attn-cta{0%,100%{transform:scale(1);}30%{transform:scale(1.08);}60%{transform:scale(.99);}}
.mm-dock.mm-dock-attn .mm-dock-btn.is-contact{animation:mm-dock-attn-cta 1.7s ease-in-out 1 both;}
@media(prefers-reduced-motion:reduce){.mm-dock.mm-dock-attn,.mm-dock.mm-dock-attn .mm-dock-btn.is-contact{animation:none;}}
/* „Weiterlesen" für längere Fließtexte — dezente Trennlinie + Chevron, nur am Smartphone.
   .mm-more-rest am Desktop display:contents → kein eigener Kasten, Mehrspalten-/Justify-
   Layout bleibt exakt erhalten. */
.mm-more-rest{display:contents;}
.mm-more-toggle{display:none;}
@media(max-width:760px){
  .mm-more .mm-more-rest{display:none;}
  .mm-more.mm-more-open .mm-more-rest{display:block;}
  .mm-more.mm-more-open .mm-more-rest>*:first-child{margin-top:1em;}
  /* Aufgeklappt: Toggle-Linie verschwindet (kein Strich mitten im Text) */
  .mm-more.mm-more-open .mm-more-toggle{display:none;}
  .mm-more-toggle{display:flex;align-items:center;gap:16px;width:100%;border:0;background:none;cursor:pointer;
    padding:4px 0;margin-top:1em;color:var(--muted);-webkit-tap-highlight-color:transparent;}
  .mm-more-toggle::before,.mm-more-toggle::after{content:"";height:1px;flex:1;background:var(--line);}
  .mm-more-ic{flex:0 0 auto;width:32px;height:32px;border:1px solid var(--line);border-radius:50%;
    display:flex;align-items:center;justify-content:center;color:var(--ink);
    transition:transform .35s var(--ease),background .25s var(--ease),color .25s var(--ease);}
  .mm-more-ic svg{width:16px;height:16px;display:block;}
  .mm-more-toggle:hover .mm-more-ic,.mm-more-toggle:focus-visible .mm-more-ic{background:var(--paper-warm-2);}
  .mm-more-toggle[aria-expanded="true"] .mm-more-ic{transform:rotate(180deg);}
}
@media(prefers-reduced-motion:reduce){.mm-more-ic{transition:none;}}
/* CTA „Kostenloses Erstgespräch sichern": auf schmalen Screens „Kostenloses" ausblenden */
@media(max-width:600px){a.typeform .tf-opt{display:none;}}
@media(hover:none){.ed-cursor{display:none;}.ed-cursor-zone{cursor:auto;}}
/* "Alle Projekte zeigen"-Block ganz entfernen (Link ist unsichtbar; Referenzen-Raster ist selbst der Cursor-Link) */
#intro .button-wrapper{display:none!important;}
/* follow-cursor arrow mode over project cards + braking/desaturating preview video */
.ed-cursor.arrow{padding:0!important;width:56px;height:56px;border-radius:50%;justify-content:center;
  background:var(--ink);color:#fff;}
.ed-cursor.arrow svg{width:22px;height:22px;animation:ed-arrow-nudge 1.4s ease-in-out infinite;}
@keyframes ed-arrow-nudge{0%,100%{transform:scale(1);}50%{transform:scale(1.16);}}
/* the card "+" read-more is replaced by the follow-cursor */
.references .views-row .content-html .read-more{display:none!important;}
@keyframes ed-arrow-nudge{0%,100%{transform:scale(1);}50%{transform:scale(1.16);}}
.references .views-row .bild video{transition:transform .7s var(--ease),filter .5s var(--ease);}
.references .views-row .link:hover .bild video{filter:blur(2px);transform:none!important;}
/* Tweak: darken variant (pure black overlay) instead of blur + light cursor */
.references .views-row .bild::after{content:"";position:absolute;inset:0;z-index:2;background:#000;
  opacity:0;transition:opacity .45s var(--ease);pointer-events:none;}
html[data-videohover="dark"] .references .views-row .link:hover .bild video{filter:none;}
html[data-videohover="dark"] .references .views-row .link:hover .bild::after{opacity:.38;}
html[data-videohover="dark"] .ed-cursor.onvid{background:var(--paper);color:var(--ink);}
html[data-videohover="dark"][data-curstyle="frost"] .ed-cursor.onvid{background:rgba(255,255,255,.05)!important;
  backdrop-filter:blur(8px) saturate(1.6)!important;-webkit-backdrop-filter:blur(8px) saturate(1.6)!important;
  color:#fff!important;border:1px solid rgba(255,255,255,.5);text-shadow:0 1px 6px rgba(0,0,0,.4);}
/* Tweak: CTA centered variant */
html[data-cta="center"] #block-kontakt a.wrapper{flex-direction:column;align-items:center;text-align:center;gap:clamp(30px,4vw,56px);}
html[data-cta="center"] #block-kontakt h4.title{text-align:center;}
/* Tweak: footer "Statement" — huge mailto as the hero, rest small beneath */
html[data-foot="big"] #footer .section{grid-template-columns:1fr;gap:clamp(26px,3.5vw,52px);}
html[data-foot="big"] .ft-col{border-left:0!important;padding-left:0!important;}
html[data-foot="big"] .ft-kontakt{order:-1;}
html[data-foot="big"] .ft-kontakt .ft-eyebrow{display:none;}
html[data-foot="big"] .ft-kontakt .ft-mail{font-size:clamp(2.4rem,7vw,5.8rem)!important;line-height:.98;letter-spacing:-.03em;}
html[data-foot="big"] .ft-kontakt .ft-tel{font-size:clamp(1.1rem,1.4vw,1.35rem);}
html[data-foot="big"] .ft-standort,html[data-foot="big"] .ft-legal{display:inline-block;vertical-align:top;width:auto;margin-right:clamp(40px,6vw,90px);}
/* Tweak: footer "Zentriert" — minimal, centered */
html[data-foot="minimal"] #footer .section{grid-template-columns:1fr;text-align:center;gap:clamp(20px,2.6vw,34px);justify-items:center;}
html[data-foot="minimal"] .ft-col{border-left:0!important;padding-left:0!important;}
html[data-foot="minimal"] .ft-eyebrow{display:none;}
html[data-foot="minimal"] .ft-kontakt .ft-mail{font-size:clamp(1.7rem,3.4vw,2.6rem)!important;}
html[data-foot="minimal"] .ft-legal ul{flex-direction:row;flex-wrap:wrap;justify-content:center;gap:10px 26px;}
/* Tweak: footer "Social zentriert" — Social-Icons mittig oben, darunter die Rechtliches-Leiste zentriert */
html[data-foot="stacked"] .ft-col.ft-legal{flex-direction:column;align-items:center;justify-content:center;
  text-align:center;gap:clamp(20px,2.4vw,30px);}
html[data-foot="stacked"] .ft-legal__social{order:-1;justify-content:center;}
html[data-foot="stacked"] .ft-legal__menu{justify-content:center;}
html[data-foot="stacked"] .ft-legal ul{flex-direction:row;flex-wrap:wrap;justify-content:center;gap:12px 26px;}
/* Tweak: no hover effect on preview videos */
html[data-videohover="none"] .references .views-row .link:hover .bild video{filter:none;}
html[data-videohover="none"] .references .views-row .link:hover .bild::after{opacity:0;}
/* Touch/Smartphone: keine Hover-Abdunkelung/Blur bei den Vorschauvideos */
@media(hover:none){
  .references .views-row .link:hover .bild video,
  .views-row .link:hover .bild video,
  .swiper-slide .link:hover .bild video,
  .node-referenzen-uebersicht .views-row .link:hover video{filter:none!important;transform:none!important;}
  .references .views-row .bild::after,
  #block-weitere-slider .swiper-slide .link:hover .bild::after{opacity:0!important;background:transparent!important;}
  .references .views-row .link:hover .ref-arrow{opacity:0!important;}
}
.ed-agentur{cursor:pointer;}
/* per-card preview hint: animated arrow over the (braking) video → detail page */
.references .views-row .bild{position:relative;}
.references .views-row .bild .ref-arrow{position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%) scale(.7);z-index:3;
  width:clamp(54px,5vw,78px);height:clamp(54px,5vw,78px);border-radius:50%;
  background:var(--paper);color:var(--ink);display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .35s var(--ease),transform .45s var(--ease);pointer-events:none;}
.references .views-row .bild .ref-arrow svg{width:42%;height:42%;}
.references .views-row .link:hover .ref-arrow{opacity:1;transform:translate(-50%,-50%) scale(1);}
.references .views-row .link:hover .ref-arrow svg{animation:ref-nudge 1.3s ease-in-out infinite;}
@keyframes ref-nudge{0%,100%{transform:translate(0,0);}50%{transform:translate(3px,-3px);}}
/* marquee separator dots as visible contour rings (not only on hover) */
#customers .kunden .item::after{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;
  border:0.5px solid var(--ink);background:transparent!important;opacity:1!important;flex:0 0 auto;
  margin:0 clamp(18px,1.9vw,36px);align-self:center;}
.ed-morelink{margin-top:clamp(30px,3.4vw,48px);}
.ed-morelink a{position:relative;display:inline-flex;align-items:center;gap:.4em;
  font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;line-height:1;
  font-size:clamp(1.5rem,2.4vw,2.1rem);color:var(--ink);}
.ed-morelink a .ar{transition:transform .35s var(--ease);}
.ed-morelink a:hover .ar{transform:translate(5px,-5px);}
.ed-morelink a::before{content:"";position:absolute;left:0;bottom:-.04em;width:0;height:2px;
  background:var(--ink);transition:width .4s var(--ease);}
.ed-morelink a:hover::before{width:100%;}

/* Leistungen block header — clear separation from Agentur intro */
.ed-leist-head{margin-top:clamp(60px,7vw,100px);border-top:1px solid var(--line);
  padding-top:clamp(40px,5vw,72px);}
.ed-leist-title{font-family:var(--font-display);font-weight:700;font-size:var(--fs-section);
  letter-spacing:-.025em;line-height:1.08;margin:0 0 clamp(30px,3.6vw,50px);color:var(--ink);}

/* clients — slow full-bleed marquee, uniform size, edge to edge */
#customers .kunden{width:100vw;margin-left:calc(-1 * (100vw - 100%) / 2);
  margin-top:clamp(56px,7vw,112px);display:flex;flex-direction:column;gap:clamp(4px,.8vw,14px);}
#customers .kunden .row{-webkit-mask-image:none!important;mask-image:none!important;overflow:hidden;}
#customers .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);}
#customers .kunden .item a{color:inherit;-webkit-text-stroke:inherit;cursor:pointer;}
#customers .kunden{margin-bottom:clamp(48px,7vw,104px);}
#customers .kunden:hover .row .items{animation-play-state:running!important;}
/* dividers only BETWEEN same-background sections, at content width (centered) */
#customers,#footer{position:relative;}
#customers::before,#footer::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:calc(min(100%, var(--container)) - 2 * var(--pad));height:1px;}
#customers::before{background:var(--line);}
#footer::before{background:rgba(255,255,255,.12);}

/* rotating badge — shared by hero scrolldown AND bottom CTA */
.turning-svg{position:absolute;inset:0;width:100%;height:100%;}
.turning-svg .ring{transform-box:view-box;transform-origin:center;animation:spin 24s linear infinite;}
/* outline rotating badge (no filled disc) — previous look, hover animation kept */
.turning-svg .disc{fill:none;}
.turning-text{fill:currentColor;font-family:var(--font-ui);font-weight:500;font-size:8.4px;letter-spacing:1.2px;}
.turning-svg .arrow{stroke:currentColor;}
/* hover: badge spins faster + the arrow changes */
.turning-svg .arrow{transform-box:fill-box;transform-origin:center;transition:transform .45s cubic-bezier(.16,1,.3,1);}
#intro .scrolldown:hover .turning-svg .ring,
#block-kontakt .contact:hover .turning-svg .ring{animation-duration:5s;}
#intro .scrolldown:hover .turning-svg .arrow{animation:arr-bob .85s var(--ease) infinite;}
@keyframes arr-bob{0%{transform:translateY(-4px);}50%{transform:translateY(5px);}100%{transform:translateY(-4px);}}
#block-kontakt .contact:hover .turning-svg .arrow{transform:translate(4px,-4px) scale(1.08);}
@media(prefers-reduced-motion:reduce){#intro .scrolldown:hover .turning-svg .arrow{animation:none;}}
@media(prefers-reduced-motion:reduce){.turning-svg .ring{animation:none;}}

/* bottom CTA — badge matches the hero badge */
#block-kontakt a.wrapper{align-items:center;}
#block-kontakt h4.title{transition:color .6s var(--ease);transform-origin:left center;animation:cta-breathe 6.5s ease-in-out infinite;}
@keyframes cta-breathe{0%,100%{transform:scale(1);}50%{transform:scale(1.012);}}
@media(prefers-reduced-motion:reduce){#block-kontakt h4.title{animation:none;}}
#block-kontakt a.wrapper:hover h4.title{color:var(--muted-2);}
#block-kontakt .contact{position:relative;width:min(200px,46vw);height:min(200px,46vw);
  color:#fff;flex:0 0 auto;}
#block-kontakt .contact .turning-svg{width:min(200px,46vw)!important;height:min(200px,46vw)!important;}
/* CTA headline: continuous subtle breathe; hover only fades colour */
#block-kontakt .contact{transition:transform .45s var(--ease);}
#block-kontakt .contact:hover{transform:scale(1.07);}

/* cooler footer: refined grid (no oversized wordmark) */
#footer{background:var(--dark-soft);}
.ft-eyebrow{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--on-dark-muted);
  margin-bottom:clamp(16px,1.6vw,24px);}
/* footer: three equal columns with vertical dividers + larger type */
#footer .section{display:block;}
#footer .region-footer{display:flex;flex-direction:column;width:100%;}
.ft-top{display:flex;flex-direction:column;align-items:center;text-align:center;gap:clamp(18px,2.6vw,34px);}
.ft-top .ft-col{border-left:0;padding-left:0;}
.ft-top .ft-kontakt{order:1;}
.ft-top .ft-standort{order:2;}
/* footer top columns centered — no vertical divider */
.ft-adr{color:var(--on-dark-muted);font-size:clamp(1.05rem,1.2vw,1.22rem);line-height:1.85;margin:0;}
.ft-kontakt .ft-mail{display:block;font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.5rem,2.2vw,2.1rem)!important;letter-spacing:-.015em;color:#fff;line-height:1.15;}
.ft-kontakt .ft-mail:hover{color:var(--muted-2);}
.ft-kontakt .ft-tel{display:block;margin-top:.7em;font-size:clamp(1.1rem,1.4vw,1.35rem);color:var(--on-dark-muted);}
.ft-kontakt .ft-tel:hover{color:#fff;}
.ft-social{display:flex;gap:12px;margin-top:clamp(24px,2.6vw,40px);}
.ft-col.ft-legal{width:100%;border-left:0;padding-left:0;display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:16px clamp(20px,3vw,40px);border-top:1px solid rgba(255,255,255,.12);
  margin-top:clamp(34px,5vw,60px);padding-top:clamp(20px,2.4vw,30px);}
.ft-col.ft-legal .ft-eyebrow{display:none;}
.ft-legal__menu{display:flex;flex-wrap:wrap;gap:clamp(14px,2vw,30px);}
/* Footer-Rechtliches-Links in der Größe der Spalten-Labels (z. B. STANDORT) */
#footer .ft-legal__menu a,#footer .ft-legal__menu .redir-link{font-size:11px;letter-spacing:.16em;text-transform:uppercase;}
.ft-legal ul{display:flex;flex-direction:row;flex-wrap:wrap;gap:clamp(14px,2vw,30px);margin:0;}
.ft-legal__social{display:flex;gap:10px;}
#footer .ft-legal__social a{width:40px;height:40px;border:1px solid var(--on-dark-muted)!important;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;color:var(--on-dark-muted)!important;font-size:.95rem;transition:background .3s,color .3s,border-color .3s;}
#footer .ft-legal__social a:hover{background:#fff;color:var(--dark-soft)!important;border-color:#fff!important;}
#footer .ft-legal__social a span{display:none;}
.ft-legal a,.ft-legal .redir-link{color:var(--on-dark-muted);font-size:clamp(1.02rem,1.1vw,1.16rem);cursor:pointer;}
.ft-legal a:hover,.ft-legal .redir-link:hover{color:#fff;}

/* Projekt-Videos: Vollbild-/Ton-Button als dezente Ecken-Steuerung (nicht über dem Video) */
.mm-fs-btn{position:absolute;right:clamp(12px,1.4vw,20px);bottom:clamp(12px,1.4vw,20px);z-index:4;
  display:inline-flex;align-items:center;gap:8px;border:0;cursor:pointer;
  padding:10px 15px;border-radius:var(--r-pill);
  background:rgba(20,18,10,.5);color:#fff;
  -webkit-backdrop-filter:blur(8px) saturate(1.3);backdrop-filter:blur(8px) saturate(1.3);
  box-shadow:0 6px 20px rgba(20,18,10,.3);
  font-family:var(--font-ui);font-weight:600;font-size:.9rem;line-height:1;
  opacity:.82;transition:opacity .25s var(--ease),transform .25s var(--ease),background .25s var(--ease);}
.mm-fs-btn:hover{background:rgba(20,18,10,.7);opacity:1;transform:translateY(-2px);}
.mm-fs-btn svg{width:18px;height:18px;flex:0 0 auto;}
.mm-fs-btn .mm-fs-label{white-space:nowrap;}
.mm-fs-btn:fullscreen{display:none;}
/* Copy-to-clipboard (z. B. UID-Nummer im Impressum) */
.mm-copy{display:inline-flex;align-items:center;gap:.45em;}
.mm-copybtn{appearance:none;-webkit-appearance:none;border:0;background:none;cursor:pointer;color:var(--muted);
  width:34px;height:34px;flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;margin-left:-2px;
  opacity:0;transition:opacity .2s var(--ease),background .2s var(--ease),color .2s var(--ease);}
.mm-copybtn svg{width:17px;height:17px;}
.mm-copy:hover .mm-copybtn,.mm-copybtn:focus-visible{opacity:1;}
.mm-copybtn:hover{background:var(--paper-warm);color:var(--ink);}
.mm-copybtn.copied{opacity:1;color:var(--ink);}
@media(hover:none){.mm-copybtn{opacity:1;}}
@media(max-width:760px){.mm-fs-btn{padding:11px;}.mm-fs-btn .mm-fs-label{display:none;}}

/* Alte Ton-/Mute-Buttons entfernt — ersetzt durch „Vollbild & Ton" */
.mute-button{display:none!important;}

/* Custom-Vollbild-Overlay für Projekt-Videos (zuverlässig auf Desktop + Smartphone) */
.mm-vov{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;
  background:rgba(8,7,4,.95);padding:clamp(10px,3vw,48px);
  opacity:0;visibility:hidden;transition:opacity .3s var(--ease),visibility .3s;}
.mm-vov.open{opacity:1;visibility:visible;}
.mm-vov__video{max-width:100%;max-height:100%;width:auto;height:auto;border-radius:8px;background:#000;
  box-shadow:0 30px 90px rgba(0,0,0,.5);}
.mm-vov__close{position:fixed;top:18px;right:18px;width:50px;height:50px;border-radius:50%;border:0;cursor:pointer;
  background:rgba(255,255,255,.16);color:#fff;display:flex;align-items:center;justify-content:center;
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:background .2s var(--ease);}
.mm-vov__close:hover{background:rgba(255,255,255,.3);}
.mm-vov__close svg{width:24px;height:24px;}
@media(max-width:760px){#footer .section{grid-template-columns:1fr;}.ft-col + .ft-col{border-left:0;padding-left:0;}}
/* CTA: cooler reveal when scrolled into view — words rise out of a mask, then badge spins in */
#block-kontakt h4.title{opacity:1;transform:none;font-size:clamp(2.8rem,8.5vw,7.4rem);line-height:.98;}
.cta-w{display:inline-block;overflow:hidden;vertical-align:top;padding-bottom:.1em;margin-bottom:-.1em;}
.cta-w>span{display:inline-block;transform:translateY(110%);transition:transform .5s cubic-bezier(.16,1,.3,1);}
#block-kontakt.in .cta-w>span{transform:translateY(0);}
#block-kontakt .contact{opacity:0;transform:scale(.55) rotate(-25deg);transition:opacity .55s var(--ease) .12s,transform .7s var(--ease) .12s;}
#block-kontakt.in .contact{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){.cta-w>span{transform:none!important;}#block-kontakt .contact{opacity:1!important;transform:none!important;}}
.ft-bottom{grid-column:1 / -1;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1em;
  margin-top:clamp(40px,5vw,72px);padding-top:clamp(20px,2vw,28px);border-top:1px solid rgba(255,255,255,.12);
  font-size:.85rem;color:var(--on-dark-muted);letter-spacing:.02em;}
#footer .block-social-media{display:flex;gap:12px;}
#footer #block-block-8{display:flex;gap:12px;align-items:flex-start;}
#footer a.facebook,#footer a.instagram,#footer a.twitter,#footer a.tumblr{
  width:46px;height:46px;border:1.5px solid rgba(255,255,255,.28);border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:1.05rem;
  transition:background .3s var(--ease),color .3s,border-color .3s;}
#footer a.facebook:hover,#footer a.instagram:hover,#footer a.twitter:hover,#footer a.tumblr:hover{
  background:#fff;color:var(--dark-soft);border-color:#fff;}
#footer a.facebook span,#footer a.instagram span,#footer a.twitter span,#footer a.tumblr span{display:none;}

/* ---------- HERO editorial meta line (home) ---------- */
/* "Alle Projekte" — big centered editorial link instead of a small pill */
#intro .button-wrapper{margin-top:clamp(18px,2.4vw,40px);display:flex;justify-content:flex-start;
  padding-block:clamp(12px,1.5vw,24px);}
#intro .button-wrapper a.show{position:relative;display:inline-flex;align-items:center;gap:.4em;
  font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;line-height:1;
  font-size:clamp(1.5rem,2.4vw,2.1rem);color:var(--ink);background:none;border:0;border-radius:0;
  padding:.25em 0;transition:gap .3s var(--ease);}
#intro .button-wrapper a.show:hover{background:none;color:var(--ink);gap:.6em;}
#intro .button-wrapper a.show::after{content:"\2197";font-size:.78em;transition:transform .35s var(--ease);}
#intro .button-wrapper a.show:hover::after{transform:translate(5px,-5px);}
#intro .button-wrapper a.show::before{content:"";position:absolute;left:0;bottom:.06em;width:0;height:2px;
  background:var(--ink);transition:width .4s var(--ease);}
#intro .button-wrapper a.show:hover::before{width:100%;}
/* #services editorial text block: headline + ONE uniform body size, two columns */
body.front #services{padding-bottom:clamp(28px,4vw,60px);}
body.front #services .subtitle{display:none;}
body.front #services h3.title{max-width:none;margin-bottom:clamp(36px,4.5vw,64px);}
body.front #services .text{max-width:none;columns:2;column-gap:clamp(40px,5vw,88px);
  text-align:justify;hyphens:auto;-webkit-hyphens:auto;}
body.front #services .text p{break-inside:auto;}
@media(max-width:760px){body.front #services .text{columns:1;}}
/* home references — robust grid: feature full width, then 2 / 1 / 1 columns */
.references{display:grid;grid-template-columns:repeat(4,1fr);
  gap:clamp(24px,3vw,52px) clamp(16px,2vw,32px);align-items:start;
  margin-top:clamp(64px,9vw,130px);}
.references .views-row{margin:0;min-width:0;}
.references .views-row:nth-child(1){grid-column:1 / -1;margin-bottom:clamp(8px,1.5vw,20px);}
.references .views-row:nth-child(1) .bild{margin-inline:calc(clamp(14px,1.8vw,30px) - clamp(20px,5vw,140px));}
.references .views-row:nth-child(2){grid-column:span 2;}
.references .views-row:nth-child(3){grid-column:span 1;}
.references .views-row:nth-child(4){grid-column:span 1;}
/* feature media: scroll zoom to full screen (fixed overlay, layout preserved) */
.references .views-row:first-child .bild{aspect-ratio:16/9;overflow:hidden;will-change:width,height,top,left;}
.references .views-row:first-child .bild video,
.references .views-row:first-child .bild img{width:100%;height:100%;object-fit:cover;}
.references .views-row:not(:first-child) .bild{aspect-ratio:1/1;}
@media(max-width:760px){
  /* Hero + 2. Projekt quadratisch, volle Inhaltsbreite; 3. + 4. kleiner zwei nebeneinander */
  .references{grid-template-columns:repeat(2,1fr);gap:26px 16px;}
  .references .views-row:nth-child(1),
  .references .views-row:nth-child(2){grid-column:1 / -1;}
  .references .views-row:nth-child(3),
  .references .views-row:nth-child(4){grid-column:span 1;}
  .references .views-row:first-child .bild,
  .references .views-row:not(:first-child) .bild{aspect-ratio:1/1;}
  /* Hero nicht über den Inhaltsrand hinaus bluten lassen */
  .references .views-row:nth-child(1) .bild{margin-inline:0;}
}
/* editorial reference card meta: kunde eyebrow on top, title below, + on the right */
.references .views-row .content-html{display:grid;grid-template-columns:1fr auto;
  column-gap:1.2em;row-gap:.5em;align-items:start;
  margin-top:clamp(14px,1.4vw,20px);padding-inline:clamp(8px,1.4vw,24px);}
.references .views-row .content-html .kunde{grid-column:1;grid-row:1;order:0;
  font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);align-self:center;}
.references .views-row .content-html .title{grid-column:1;grid-row:2;order:0;
  font-family:var(--font-display);font-weight:700;letter-spacing:-.015em;line-height:1.16;
  font-size:clamp(1.2rem,1.7vw,1.55rem);color:var(--ink);text-transform:none;}
.references .views-row:first-child .content-html .title{font-size:clamp(1.6rem,2.8vw,2.4rem);}
.references .views-row:not(:first-child) .content-html .title{font-size:clamp(1.02rem,1.25vw,1.28rem);}
.references .views-row .content-html .read-more{grid-column:2;grid-row:1 / span 2;align-self:center;
  margin:0;width:44px;height:44px;border:1.5px solid var(--line-strong);border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:1.3rem;font-weight:300;color:var(--ink);
  transition:background .4s var(--ease),color .4s,transform .7s cubic-bezier(.65,0,.2,1);flex:0 0 auto;}
.references .views-row .link:hover .read-more{background:var(--ink);color:#fff;transform:rotate(360deg);}
html[data-accent]:not([data-accent="kein"]) .references .views-row .link:hover .read-more{background:var(--accent);border-color:var(--accent);color:var(--accent-ink);}
/* hero pre-headline: no dash */
body.front #intro .subtitle{display:inline-flex;align-items:center;gap:14px;border:0;}

/* ---------- Editorial display tightening ---------- */
.h1,h1.title,h2.title,#intro>.section>.title,#einleitung h1{letter-spacing:-.03em;}

/* ============================================================
   REFERENCES — Editorial catalog (Locomotive-style index + filter)
   Applies on referenzen.html. Re-skins the .views grid.
   ============================================================ */
body.page-referenzen #block-system-main,
.node-referenzen-uebersicht{--cat-gap:clamp(2px,.4vw,6px);}

/* filter bar — wie auf der FAQ-Seite: Glasleiste erscheint erst, wenn sie oben andockt */
.ed-filter{display:flex;flex-wrap:wrap;gap:10px;align-items:center;
  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(30px,4.5vw,64px);}
.ed-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"] .ed-filter.is-stuck{background:rgba(21,20,15,.8);}
.ed-filter__lbl{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-right:8px;}
.ed-chip{font-family:var(--font-ui);font-weight:500;font-size:.9rem;color:var(--ink);
  border:1.5px solid var(--line-strong);background:transparent;border-radius:var(--r-pill);
  padding:.55em 1.15em;cursor:pointer;transition:background .25s var(--ease),color .25s,border-color .25s;
  display:inline-flex;align-items:center;gap:.5em;}
.ed-chip .n{font-size:.72rem;color:var(--muted);font-variant-numeric:tabular-nums;transition:color .25s;}
.ed-chip:hover{border-color:var(--ink);}
.ed-chip.active{background:var(--ink);color:#fff;border-color:var(--ink);}
.ed-chip.active .n{color:rgba(255,255,255,.6);}

/* catalog grid: editorial 2-col with metadata rows + hairlines */
/* ---------- Tweak: Referenzen-Slider auf der Startseite (data-refstyle="slider") ---------- */
html[data-refstyle="slider"] #intro .references,
html[data-refstyle="slider"] #intro .button-wrapper{display:none!important;}
.ref-marquee{display:none;}
html[data-refstyle="slider"] .ref-marquee{display:block;width:100vw;margin-left:calc(50% - 50vw);
  overflow:hidden;margin-top:clamp(40px,6vw,96px);}
.ref-mq-scroll{overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;cursor:grab;}
.ref-mq-scroll::-webkit-scrollbar{display:none;}
.ref-mq-scroll:active{cursor:grabbing;}
.ref-mq-track{display:flex;gap:clamp(16px,2vw,34px);width:max-content;}
.ref-marquee{margin-top:clamp(40px,6vw,90px);}
.ref-mq-card{flex:0 0 37vw;min-width:300px;color:inherit;}
.ref-mq-dots{display:flex;gap:9px;justify-content:flex-start;margin-top:clamp(22px,2.6vw,34px);
  max-width:var(--container);margin-inline:auto;padding-inline:var(--pad);}
.ref-mq-dot{width:8px;height:8px;border-radius:99px;background:var(--line-strong);border:0;padding:0;
  cursor:pointer;transition:width .3s var(--ease),background .3s var(--ease);}
.ref-mq-dot.active{background:var(--ink);width:26px;}
.ref-mq-vid{aspect-ratio:16/9;border-radius:var(--r-md);overflow:hidden;background:var(--paper-warm-2);}
.ref-mq-vid video{width:100%;height:100%;object-fit:cover;display:block;}
.ref-mq-card:hover .ref-mq-vid video{transform:scale(1.04);transition:transform .8s var(--ease);}
.ref-mq-meta{display:flex;flex-direction:column;gap:3px;margin-top:14px;}
.ref-mq-meta .k{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);}
.ref-mq-meta .t{font-family:var(--font-display);font-weight:700;font-size:clamp(1.1rem,1.6vw,1.5rem);
  letter-spacing:-.01em;color:var(--ink);line-height:1.16;}
@media(prefers-reduced-motion:reduce){.ref-mq-track{animation:none;}}
/* ---------- Tweak: Blog-Vorschau-Slider (data-blog="slider") ---------- */
.blog-slider{display:none;}
html[data-blog="slider"] .blog-slider{display:block;padding-block:clamp(48px,7vw,110px);}
html[data-blog="slider"] #services .section>h2,
html[data-blog="slider"] #services .section>h3,
html[data-blog="slider"] #services .section>.text{display:none!important;}
.blog-head{max-width:var(--container);margin:0 auto clamp(24px,3vw,42px);padding-inline:var(--pad);}
.blog-eyebrow{font-family:var(--font-ui);font-weight:500;text-transform:uppercase;letter-spacing:.16em;font-size:.74rem;color:var(--muted);}
.blog-h{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;font-size:clamp(1.8rem,3.4vw,2.8rem);color:var(--ink);margin-top:10px;}
.blog-scroll{overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;cursor:grab;scroll-snap-type:x mandatory;
  max-width:var(--container);margin-inline:auto;padding-inline:var(--pad);}
.blog-scroll::-webkit-scrollbar{display:none;}
.blog-scroll:active{cursor:grabbing;}
.blog-track{display:flex;gap:clamp(16px,2vw,28px);width:max-content;}
.blog-card{flex:0 0 clamp(290px,32vw,420px);scroll-snap-align:start;background:var(--paper);
  border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(24px,2.4vw,34px);
  display:flex;flex-direction:column;gap:14px;color:inherit;min-height:clamp(260px,24vw,330px);
  transition:border-color .3s var(--ease),transform .3s var(--ease);}
.blog-card:hover{border-color:var(--line-strong);transform:translateY(-3px);}
.blog-cat{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:500;}
.blog-t{font-family:var(--font-display);font-weight:700;font-size:clamp(1.2rem,1.8vw,1.55rem);
  letter-spacing:-.01em;line-height:1.2;color:var(--ink);}
.blog-x{font-size:.98rem;line-height:1.55;color:var(--ink-2);flex:1;}
.blog-more{font-family:var(--font-ui);font-weight:500;font-size:.95rem;color:var(--ink);}
.blog-dots{display:flex;gap:9px;justify-content:flex-start;margin-top:clamp(22px,2.6vw,34px);
  max-width:var(--container);margin-inline:auto;padding-inline:var(--pad);}
.blog-dot{width:8px;height:8px;border-radius:99px;background:var(--line-strong);border:0;padding:0;
  cursor:pointer;transition:width .3s var(--ease),background .3s var(--ease);}
.blog-dot.active{background:var(--ink);width:26px;}
/* ---------- Tweak: Agentur-Block → Intro-Text unter der Headline (data-agentur="intro") ---------- */
.intro-lead{display:none;}
html[data-agentur="intro"] .intro-lead{display:block;font-family:var(--font-ui);font-weight:400;
  font-size:clamp(1.15rem,1.7vw,1.55rem);line-height:1.5;letter-spacing:0;color:var(--ink-2);
  max-width:62ch;margin-top:clamp(18px,2.2vw,30px);text-wrap:pretty;}
html[data-agentur="intro"] #services .section>h2,
html[data-agentur="intro"] #services .section>h3,
html[data-agentur="intro"] #services .section>.text{display:none!important;}
.intro-showreel{display:none;}
.intro-showreel .sr-label{position:absolute;left:14px;top:14px;font-family:var(--font-ui);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;background:rgba(0,0,0,.32);padding:5px 11px;border-radius:99px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:2;}
.intro-showreel .sr-ctrls{position:absolute;right:14px;bottom:14px;display:flex;gap:8px;z-index:2;}
.intro-showreel .sr-ctrls button{width:42px;height:42px;border-radius:50%;border:0;background:rgba(0,0,0,.4);color:#fff;display:grid;place-items:center;cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);}
.intro-showreel .sr-ctrls button:hover,.intro-showreel .sr-ctrls button.on{background:rgba(0,0,0,.7);}
.intro-showreel .sr-ctrls svg{width:18px;height:18px;}
html[data-agentur="showreel"] .intro-showreel{display:block;position:relative;
  width:calc(100% + 2 * clamp(20px,5vw,140px));margin-inline:calc(-1 * clamp(20px,5vw,140px));
  aspect-ratio:16/9;background:var(--ink);overflow:hidden;border-radius:var(--r-md);margin-top:clamp(24px,3vw,46px);}
html[data-agentur="showreel"] .intro-showreel video{width:100%;height:100%;object-fit:cover;display:block;transition:filter .45s var(--ease);}
html[data-agentur="showreel"] .intro-showreel:hover video{filter:brightness(.66) saturate(.9);}
html[data-agentur="showreel"] .intro-showreel .sr-spin{position:absolute;inset:0;z-index:1;display:grid;place-items:center;background:var(--ink);pointer-events:none;transition:opacity .55s var(--ease);}
html[data-agentur="showreel"] .intro-showreel.sr-ready .sr-spin{opacity:0;}
.intro-showreel .sr-spin-ring{width:34px;height:34px;border-radius:50%;border:2px solid rgba(255,255,255,.22);border-top-color:#fff;animation:sr-spin .8s linear infinite;}
@keyframes sr-spin{to{transform:rotate(360deg);}}
@media(hover:hover){html[data-refs="slider"] .ref-mq-card.ed-cursor-zone,html[data-refs="slider"] .ref-mq-card.ed-cursor-zone *{cursor:none !important;}}
html[data-agentur="showreel"] #services .section>h2,
html[data-agentur="showreel"] #services .section>h3,
html[data-agentur="showreel"] #services .section>.text{display:none!important;}
html[data-agentur="showreel"] .intro-lead{display:block;font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.9rem,3.8vw,3.4rem);line-height:1.08;letter-spacing:-.02em;color:var(--ink);
  max-width:none;margin:clamp(52px,6.5vw,104px) 0 clamp(32px,4vw,56px);text-wrap:balance;}
.intro-cta{display:none;}
.ins-dock{position:fixed;left:50%;bottom:18px;transform:translateX(-50%);z-index:1000;display:flex;gap:6px;align-items:center;background:var(--ink);color:#fff;border-radius:var(--r-pill);padding:6px;box-shadow:0 18px 50px -16px rgba(0,0,0,.55);max-width:calc(100vw - 28px);}
.ins-dock-back{font-family:var(--font-ui);font-weight:500;font-size:.88rem;color:#fff;padding:.6em 1.05em;border-radius:var(--r-pill);white-space:nowrap;flex:0 0 auto;}
.ins-dock-back:hover{background:rgba(255,255,255,.14);}
.ins-dock-sep{width:1px;height:20px;background:rgba(255,255,255,.18);flex:0 0 auto;}
.ins-dock-jump{display:flex;gap:2px;overflow-x:auto;scrollbar-width:none;}
.ins-dock-jump::-webkit-scrollbar{display:none;}
.ins-dock-jump a{font-family:var(--font-ui);font-size:.84rem;color:rgba(255,255,255,.72);padding:.6em .85em;border-radius:var(--r-pill);white-space:nowrap;}
.ins-dock-jump a:hover{color:#fff;background:rgba(255,255,255,.14);}
@media(max-width:640px){.ins-dock-jump{max-width:46vw;}.ins-dock-back{font-size:.82rem;}}
.ins-card.is-hidden{display:none;}
.art-acc{margin-top:6px;}
/* Artikel-Meta: an „·" umbrechen (Segmente unzertrennbar, „·" bleibt am Zeilenende) */
.art-meta[data-seg]{display:flex;flex-wrap:wrap;align-items:baseline;}
.art-meta[data-seg] .am-seg{white-space:nowrap;}
.art-meta[data-seg] .am-sep{white-space:nowrap;padding:0 .6em;}
/* Layout-Zucken vermeiden: die statische FAQ-Liste (alle Antworten offen) NICHT zeigen,
   bis JS das eingeklappte Akkordeon (.art-acc) daraus gebaut hat. JS liest den Inhalt
   trotz display:none. Kein Aufklapp-→-Einklapp-Sprung mehr nach dem Laden. */
.page-insights-article .art-faq dl{display:none;}
.art-acc-item{border-top:1px solid var(--line);}
.art-acc-item:last-child{border-bottom:1px solid var(--line);}
.art-acc-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:1em;background:none;border:0;padding:clamp(18px,2vw,26px) 0;cursor:pointer;text-align:left;font-family:var(--font-display);font-weight:700;font-size:clamp(1.05rem,1.5vw,1.3rem);color:var(--ink);letter-spacing:-.01em;line-height:1.25;}
.art-acc-ic{position:relative;width:18px;height:18px;flex:0 0 auto;}
.art-acc-ic::before,.art-acc-ic::after{content:"";position:absolute;background:var(--ink);transition:transform .3s var(--ease);}
.art-acc-ic::before{left:0;top:8px;width:18px;height:2px;}
.art-acc-ic::after{left:8px;top:0;width:2px;height:18px;}
.art-acc-item.open .art-acc-ic::after{transform:scaleY(0);}
.art-acc-a{display:grid;grid-template-rows:0fr;overflow:hidden;transition:grid-template-rows .42s var(--ease);}
.art-acc-a>*{min-height:0;}
.art-acc-item.open .art-acc-a{grid-template-rows:1fr;padding-bottom:clamp(18px,2vw,24px);}
/* Höhere Spezifität als „.art-body p" (sonst bringt dessen margin-bottom die Marge zurück
   und das geschlossene Akkordeon bleibt ~21px offen). */
.page-insights-article .art-faq .art-acc-a>*{margin:0;}
.page-insights-article .art-faq .art-acc-a p{font-size:1.05rem;line-height:1.65;color:var(--ink-2);margin:0;}
.page-insights-article .art-faq .art-acc-a p + p{margin-top:clamp(12px,1.4vw,18px);}
html[data-agentur="showreel"] .intro-cta,html[data-agentur="intro"] .intro-cta{display:inline-flex;align-items:center;
  margin-top:clamp(22px,2.6vw,32px);font-family:var(--font-ui);font-weight:500;font-size:1rem;
  background:none;color:var(--ink);border:1.5px solid var(--line-strong);padding:calc(1em - 1.5px) calc(2em - 1.5px);border-radius:var(--r-pill);transition:background .3s var(--ease),color .3s var(--ease),border-color .3s var(--ease),transform .2s var(--ease);}
html[data-agentur="showreel"] .intro-cta:hover,html[data-agentur="intro"] .intro-cta:hover{background:var(--ink);color:#fff;border-color:var(--ink);transform:translateY(-2px);}
.node-referenzen-uebersicht #galerie{padding-top:clamp(8px,1.5vw,24px);}
.node-referenzen-uebersicht .galerie{
  display:grid;grid-template-columns:repeat(10,1fr);gap:clamp(28px,3.4vw,56px) clamp(26px,3.4vw,72px);
  max-width:none;margin:0;padding:0;}

.node-referenzen-uebersicht .views-row{margin:0;position:relative;}
.node-referenzen-uebersicht .views-row.is-hidden{display:none;}
.node-referenzen-uebersicht .views-row .link{display:block;color:inherit;}
.node-referenzen-uebersicht .views-row .bild{position:relative;overflow:hidden;border-radius:var(--r-md);
  background:var(--paper-warm-2);aspect-ratio:16/10;}
.node-referenzen-uebersicht .views-row video,
.node-referenzen-uebersicht .views-row .bild img{width:100%;height:100%;object-fit:cover;
  transition:transform .9s var(--ease),filter .6s var(--ease);}
.node-referenzen-uebersicht .views-row .link:hover video,
.node-referenzen-uebersicht .views-row .link:hover img{transform:scale(1.04);}

/* metadata row under media — wie auf der Startseite (Kunde-Eyebrow oben, Titel darunter, keine Trennlinie) */
.node-referenzen-uebersicht .content-html{display:grid;grid-template-columns:1fr;
  align-items:start;gap:.5em;padding:0 clamp(2px,1.4vw,24px);
  margin-top:clamp(14px,1.4vw,20px);border-top:0;}
.node-referenzen-uebersicht .content-html .kunde{order:0;grid-column:1;grid-row:1;
  font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);text-align:left;white-space:normal;}
.node-referenzen-uebersicht .content-html .title{order:0;grid-column:1;grid-row:2;
  font-family:var(--font-display);font-weight:700;font-size:clamp(1.2rem,1.7vw,1.55rem);
  letter-spacing:-.015em;line-height:1.16;color:var(--ink);text-transform:none;}
.node-referenzen-uebersicht .content-html .ed-cat{order:0;grid-column:1;grid-row:3;
  font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:.35em;}

/* feature (Hero) — wie der Gföllner-Hero auf der Startseite: 16/9, gerundet, über die Inhaltsbreite hinaus */
.node-referenzen-uebersicht .views-row.ed-feature{grid-column:1 / -1;margin-bottom:clamp(8px,1.5vw,20px);}
.node-referenzen-uebersicht .views-row.ed-feature .bild{width:calc(100% + 2 * (clamp(20px,5vw,140px) - clamp(14px,1.8vw,30px)))!important;margin-inline:calc(clamp(14px,1.8vw,30px) - clamp(20px,5vw,140px));aspect-ratio:16/9;border-radius:var(--r-md);overflow:hidden;}
.node-referenzen-uebersicht .views-row.ed-feature .video-container{aspect-ratio:16/9!important;border-radius:var(--r-md);}
/* einheitliche Seitenverhältnisse: Hero 16/9, alle übrigen 1/1; Medien immer „cover" */
.node-referenzen-uebersicht #galerie .galerie{grid-template-columns:repeat(10,1fr)!important;grid-auto-flow:row!important;}
/* Positionsbasiertes 5er-Modul auf 10-Spalten-Raster (filterstabil via applyRaster):
   p1 quer 70% · p2 quadratisch 30% (versetzt) · p3/p4 quadratisch 50/50 · p5 Hero voll */
.node-referenzen-uebersicht #galerie .galerie .views-row{grid-column:span 5!important;}
.node-referenzen-uebersicht #galerie .galerie .views-row.ed-p1{grid-column:span 7!important;}
.node-referenzen-uebersicht #galerie .galerie .views-row.ed-p2{grid-column:span 3!important;margin-top:clamp(40px,7vw,130px);}
.node-referenzen-uebersicht #galerie .galerie .views-row.ed-p3{grid-column:span 5!important;}
.node-referenzen-uebersicht #galerie .galerie .views-row.ed-p4{grid-column:span 5!important;}
.node-referenzen-uebersicht #galerie .galerie .views-row.ed-feature{grid-column:1 / -1!important;}
/* Box-Format folgt dem Video (nicht der Position) */
.node-referenzen-uebersicht #galerie .galerie .views-row.ed-ar-land .bild{aspect-ratio:16/9;overflow:hidden;border-radius:var(--r-md);}
.node-referenzen-uebersicht #galerie .galerie .views-row.ed-ar-land .video-container{aspect-ratio:16/9!important;}
.node-referenzen-uebersicht #galerie .galerie .views-row.ed-ar-sq .bild{aspect-ratio:1/1;overflow:hidden;border-radius:var(--r-md);}
.node-referenzen-uebersicht #galerie .galerie .views-row.ed-ar-sq .video-container{aspect-ratio:1/1!important;}
.node-referenzen-uebersicht .galerie .bild img,
.node-referenzen-uebersicht .galerie .bild video,
.node-referenzen-uebersicht .galerie .bild picture,
.node-referenzen-uebersicht .galerie .bild .lottie{width:100%!important;height:100%!important;object-fit:cover;display:block;}
.node-referenzen-uebersicht .galerie .bild .video-container{width:100%;height:100%;padding:0!important;}
.node-referenzen-uebersicht .views-row.ed-feature .content-html{padding-inline:0;margin-top:clamp(14px,1.4vw,20px);}
.node-referenzen-uebersicht .views-row.ed-feature .content-html .title{font-size:clamp(1.6rem,2.8vw,2.4rem);}

/* Die 10-Spalten-Optik skaliert via 1fr fluide nach unten (bleibt bis ~480px erhalten).
   Darunter Smartphone-Variante mit gleichem Rhythmus (versetztes Quadrat, 2er-Reihe, Hero). */
/* Die 10-Spalten-Optik bleibt nur in größeren Breiten; ab Tablet/„dieser Breite"
   (≤1024px) bereits die nächstkleinere Variante (Smartphone-Rhythmus) verwenden:
   versetztes Quadrat, 2er-Reihe, Hero. */
@media(max-width:1024px){
  .node-referenzen-uebersicht #galerie .galerie{grid-template-columns:repeat(2,1fr)!important;gap:clamp(16px,2.4vw,30px) clamp(12px,1.8vw,24px);}
  .node-referenzen-uebersicht #galerie .galerie .views-row.ed-p1{grid-column:1 / -1!important;margin-top:0;}
  .node-referenzen-uebersicht #galerie .galerie .views-row.ed-p2{grid-column:1 / -1!important;margin-top:0;}
  .node-referenzen-uebersicht #galerie .galerie .views-row.ed-p2 .bild{width:64%;margin-left:auto;}
  .node-referenzen-uebersicht #galerie .galerie .views-row.ed-p3,
  .node-referenzen-uebersicht #galerie .galerie .views-row.ed-p4{grid-column:span 1!important;}
  .node-referenzen-uebersicht #galerie .galerie .views-row.ed-p1 .bild,
  .node-referenzen-uebersicht #galerie .galerie .views-row.ed-p1 .video-container,
  .node-referenzen-uebersicht #galerie .galerie .views-row.ed-feature .bild,
  .node-referenzen-uebersicht #galerie .galerie .views-row.ed-feature .video-container{aspect-ratio:16/10!important;}
  /* alle 2-up-Kacheln (nicht voll-breite Hero/p1/p2) quadratisch, damit nebeneinander
     keine Kachel kleiner wirkt als ihre Nachbarin */
  .node-referenzen-uebersicht #galerie .galerie .views-row:not(.ed-p1):not(.ed-p2):not(.ed-feature) .bild,
  .node-referenzen-uebersicht #galerie .galerie .views-row:not(.ed-p1):not(.ed-p2):not(.ed-feature) .video-container{aspect-ratio:1/1!important;}
}

/* index intro headline on referenzen */
.node-referenzen-uebersicht #einleitung .title,
.node-referenzen-uebersicht .einleitung .title{letter-spacing:-.03em;}

/* dark-mode catalog hairlines already handled by --line token */

/* ============================================================
   KONTAKTSEITE — matches the contact overlay, light scheme
   ============================================================ */
body.node-type-kontakt #kontakt.kc{background:var(--paper-warm);color:var(--ink);min-height:100svh;
  display:flex;align-items:center;padding:clamp(120px,18vh,200px) 0 clamp(50px,8vh,90px);}
.kc-inner{max-width:var(--container);width:100%;margin:0 auto;padding:0 var(--pad);display:flex;flex-direction:column;}
.kc-eyebrow{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin:0 0 1.3em;}
.kc-mail{font-family:var(--font-display);font-weight:700;letter-spacing:-.03em;line-height:1;
  font-size:clamp(2.2rem,7vw,5.8rem);color:var(--ink);text-decoration:none;display:inline-block;align-self:flex-start;
  transition:color .55s var(--ease);}
.kc-mail:hover{color:var(--muted);}
.kc-rows{display:flex;flex-wrap:wrap;gap:clamp(24px,5vw,80px);margin-top:clamp(34px,5vw,58px);}
.kc-row{display:flex;flex-direction:column;gap:.3em;}
.kc-row .k{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);}
.kc-row a,.kc-row span:not(.k){font-family:var(--font-display);font-weight:700;letter-spacing:-.01em;
  font-size:clamp(1.3rem,2.4vw,2rem);color:var(--ink);line-height:1.15;transition:color .55s var(--ease);}
.kc-row a:hover{color:var(--muted);}
.kc-ctas{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-top:clamp(34px,5vw,56px);}
.kc-vcard-btn{width:clamp(50px,3.6vw,58px);height:clamp(50px,3.6vw,58px);border-radius:50%;
  border:1.5px solid var(--ink);background:none;color:var(--ink);cursor:pointer;display:inline-flex;
  align-items:center;justify-content:center;transition:background .4s var(--ease),color .4s var(--ease);}
.kc-vcard-btn:hover{background:var(--ink);color:var(--paper);}
.kc-vcard-btn svg{width:30px;height:30px;}
html[data-accent]:not([data-accent="kein"]) .kc-mail{color:var(--accent);}
@media(max-width:760px){
  body.node-type-kontakt #kontakt.kc{padding-top:clamp(110px,16vh,150px);}
  .kc-rows{gap:24px clamp(30px,8vw,60px);}
}

/* ============================================================
   Menu open: header is left COMPLETELY untouched. The overlay
   (z-index 1001) simply lies over it; the menu-icon (z-index 1002)
   stays above the overlay so it can close. No recolour, no fade.
   ============================================================ */

/* cooler contact info inside the menu overlay */
#navigation-wrapper .region-header{align-items:flex-start;gap:clamp(34px,6vw,96px);}
#navigation-wrapper .region-header .email::before{content:"Schreiben Sie uns";display:block;
  font-family:var(--font-ui);font-weight:500;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--on-dark-muted);margin-bottom:.9em;}
#navigation-wrapper .region-header .email a{font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.5rem,3vw,2.7rem);letter-spacing:-.02em;color:#fff;line-height:1;
  display:inline-flex;align-items:center;gap:.32em;}
#navigation-wrapper .region-header .email a::after{content:"\2197";font-size:.62em;
  transition:transform .35s var(--ease);}
#navigation-wrapper .region-header .email a:hover::after{transform:translate(6px,-6px);}
#navigation-wrapper .region-header .contact-data::before{content:"Anrufen & Besuchen";display:block;
  font-family:var(--font-ui);font-weight:500;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--on-dark-muted);margin-bottom:.9em;}
#navigation-wrapper .region-header .contact-data{font-size:calc(clamp(1.05rem,1.3vw,1.28rem) * var(--nav-scale-menu,1));
  line-height:1.85;color:var(--on-dark-muted);}
#navigation-wrapper .region-header .contact-data a{color:#fff;}
#navigation-wrapper .region-header .contact-data a:hover{color:var(--muted-2);}

/* ============================================================
   Replace Typeform sidebar with our own contact element
   ============================================================ */
[data-tf-sidetab],[data-tf-popover],.tf-v1-sidetab,.tf-v1-popover,
.tf-v1-sidetab-button,.tf-v1-popover-button,iframe[src*="typeform"]{display:none!important;}

/* contact FAB — circular, bottom-right, all viewports, subtly animated */
#mm-contact{position:fixed;z-index:1000;right:clamp(18px,2.4vw,34px);bottom:clamp(18px,2.4vw,34px);
  width:clamp(58px,5vw,72px);height:clamp(58px,5vw,72px);border-radius:50%;border:0;cursor:pointer;padding:0;
  background:var(--ink);color:var(--paper);display:flex;align-items:center;justify-content:center;
  box-shadow:0 12px 34px rgba(20,18,10,.28);transition:transform .4s var(--ease),opacity .35s var(--ease),background .3s;}
#mm-contact:hover{transform:scale(1.08);}
#mm-contact .mm-c-ico{position:relative;z-index:2;display:flex;width:44%;height:44%;transform-origin:center;animation:mm-c-wave 6.5s var(--ease) infinite;}
#mm-contact .mm-c-ico svg{width:100%;height:100%;}
@keyframes mm-c-wave{0%,82%,100%{transform:translate(0,0) rotate(0);}87%{transform:translate(3px,-3px) rotate(6deg);}91%{transform:translate(-1px,1px) rotate(-2deg);}95%{transform:translate(0,0) rotate(0);}}
html[data-accent]:not([data-accent="kein"]) #mm-contact{background:var(--accent);color:var(--accent-ink);}
body.nav-open #mm-contact,body.mm-cov-open #mm-contact,body.mm-hide-contact #mm-contact{opacity:0;pointer-events:none;transform:scale(.6);}
@media(prefers-reduced-motion:reduce){#mm-contact .mm-c-ico{animation:none;}}

/* Leistungsseiten: prominenter, rechteckiger Conversion-Button statt runder FAB */
#mm-contact.mm-contact--label{width:auto;height:auto;border-radius:var(--r-pill);
  padding:clamp(15px,1.3vw,19px) clamp(22px,1.9vw,30px);gap:11px;
  font-family:var(--font-ui);box-shadow:0 18px 48px rgba(20,18,10,.34);}
#mm-contact.mm-contact--label .mm-c-ico{width:21px;height:21px;flex:0 0 auto;}
#mm-contact.mm-contact--label .mm-c-label{font-size:clamp(1rem,1.05vw,1.12rem);font-weight:600;
  letter-spacing:-.005em;white-space:nowrap;color:inherit;line-height:1;}
#mm-contact.mm-contact--label:hover{transform:translateY(-3px);box-shadow:0 22px 56px rgba(20,18,10,.4);}
body.nav-open #mm-contact.mm-contact--label,body.mm-cov-open #mm-contact.mm-contact--label,
body.mm-hide-contact #mm-contact.mm-contact--label{transform:translateY(14px) scale(.94);}
@media(max-width:560px){#mm-contact.mm-contact--label{padding:14px 20px;}
  #mm-contact.mm-contact--label .mm-c-label{font-size:.98rem;}}

/* Cookie-Einstellungen-Dialog */
.mm-cookie{position:fixed;inset:0;z-index:1300;display:flex;align-items:center;justify-content:center;
  padding:var(--pad);opacity:0;visibility:hidden;transition:opacity .3s var(--ease),visibility .3s;}
.mm-cookie.open{opacity:1;visibility:visible;}
.mm-cookie__scrim{position:absolute;inset:0;background:rgba(20,18,10,.5);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);}
.mm-cookie__card{position:relative;z-index:2;background:var(--paper);color:var(--ink);border-radius:var(--r-lg);
  max-width:520px;width:100%;padding:clamp(28px,4vw,46px);box-shadow:0 30px 80px rgba(20,18,10,.34);
  transform:translateY(14px) scale(.98);transition:transform .35s var(--ease);}
.mm-cookie.open .mm-cookie__card{transform:none;}
.mm-cookie__close{position:absolute;top:14px;right:14px;width:38px;height:38px;border:0;background:none;cursor:pointer;
  color:var(--muted);display:flex;align-items:center;justify-content:center;}
.mm-cookie__close svg{width:20px;height:20px;}
.mm-cookie__eyebrow{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:0 0 .8em;}
.mm-cookie__title{font-family:var(--font-display);font-weight:700;font-size:clamp(1.4rem,2.4vw,1.9rem);
  letter-spacing:-.02em;line-height:1.15;margin:0 0 .6em;color:var(--ink);}
.mm-cookie__lead{font-size:1rem;line-height:1.6;color:var(--ink-2);margin:0 0 clamp(16px,2.2vw,26px);}
.mm-cookie__row{display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:15px 0;border-top:1px solid var(--line);}
.mm-cookie__row strong{display:block;font-weight:600;font-size:1rem;color:var(--ink);}
.mm-cookie__row>div span{display:block;margin-top:2px;font-size:.88rem;color:var(--muted);line-height:1.45;}
.mm-cookie__tag{font-size:.8rem;color:var(--muted);white-space:nowrap;}
.mm-cookie__toggle{flex:0 0 auto;width:46px;height:26px;border-radius:var(--r-pill);border:0;cursor:pointer;
  background:var(--line-strong);position:relative;transition:background .25s var(--ease);}
.mm-cookie__toggle::after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;
  background:#fff;transition:transform .25s var(--ease);box-shadow:0 1px 3px rgba(0,0,0,.3);}
.mm-cookie__toggle.on{background:var(--ink);}
.mm-cookie__toggle.on::after{transform:translateX(20px);}
.mm-cookie__actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:clamp(18px,2.4vw,28px);}
.mm-cookie__btn{flex:1 1 auto;border:0;border-radius:var(--r-pill);padding:14px 22px;font-family:var(--font-ui);
  font-weight:600;font-size:.98rem;cursor:pointer;background:var(--ink);color:var(--paper);transition:opacity .2s var(--ease);}
.mm-cookie__btn:hover{opacity:.88;}
.mm-cookie__btn.ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line-strong);}
html[data-accent]:not([data-accent="kein"]) .mm-cookie__btn:not(.ghost){background:var(--accent);color:var(--accent-ink);}

/* full-page contact overlay — clip-path reveal from the FAB (like the menu) */
.mm-cov{position:fixed;inset:0;z-index:1190;background:var(--dark);color:#fff;
  display:flex;align-items:center;justify-content:center;padding:clamp(60px,10vw,130px) var(--pad);
  clip-path:circle(0% at calc(100% - 52px) calc(100% - 52px));pointer-events:none;
  transition:clip-path .82s cubic-bezier(.76,0,.24,1);}
body.mm-cov-open .mm-cov{clip-path:circle(230% at calc(100% - 52px) calc(100% - 52px));pointer-events:auto;}
.mm-cov__close{position:absolute;bottom:clamp(18px,2.4vw,34px);right:clamp(18px,2.4vw,34px);
  width:clamp(58px,5vw,72px);height:clamp(58px,5vw,72px);
  border-radius:50%;border:1px solid rgba(255,255,255,.4);background:none;color:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:background .3s,color .3s;}
.mm-cov__close:hover{background:#fff;color:var(--dark);}
.mm-cov__close svg{width:24px;height:24px;}
/* Wenn das Bottom-Dock aktiv ist: Kontakt-Overlay aus der Mitte (vom Dock) öffnen, Schließen-X mittig auf Dock-Höhe */
body[data-mm-dock] .mm-cov{clip-path:circle(0% at 50% calc(100% - 56px));}
body[data-mm-dock].mm-cov-open .mm-cov{clip-path:circle(240% at 50% calc(100% - 56px));}
body[data-mm-dock] .mm-cov__close{right:auto;left:50%;transform:translateX(-50%);
  bottom:calc(24px + env(safe-area-inset-bottom));}
.mm-cov__in{max-width:var(--container);width:100%;margin:0 auto;display:flex;flex-direction:column;}
.mm-cov__in>*{opacity:0;transform:translateY(26px);transition:opacity .6s var(--ease),transform .6s var(--ease);}
body.mm-cov-open .mm-cov__in>*{opacity:1;transform:none;}
body.mm-cov-open .mm-cov__in>*:nth-child(1){transition-delay:.28s;}
body.mm-cov-open .mm-cov__in>*:nth-child(2){transition-delay:.35s;}
body.mm-cov-open .mm-cov__in>*:nth-child(3){transition-delay:.42s;}
body.mm-cov-open .mm-cov__in>*:nth-child(4){transition-delay:.49s;}
.mm-cov__eyebrow{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--on-dark-muted);margin:0 0 1.3em;}
.mm-cov__mail{font-family:var(--font-display);font-weight:700;letter-spacing:-.03em;line-height:1.0;
  font-size:calc(clamp(2.2rem,7vw,5.8rem) * var(--nav-scale,1));color:#fff;text-decoration:none;display:inline-flex;align-items:center;transition:color .6s var(--ease);}
.mm-cov__mail:hover{color:var(--muted-2);}
.mm-cov__mail::after{content:"\2192";display:inline-block;margin-left:.32em;font-size:.5em;vertical-align:baseline;
  opacity:0;transform:translateX(-16px);transition:opacity .5s var(--ease),transform .5s var(--ease);}
.mm-cov__mail:hover::after{opacity:1;transform:translateX(0);}
/* Ganz kleine Screens: E-Mail-Adresse IMMER einzeilig (kein Umbruch) — Größe skaliert
   mit der Viewport-Breite, sodass die ~21 Zeichen passen; Hover-Pfeil ausgeblendet
   (Touch hat keinen Hover und er würde sonst Breite belegen). */
@media(max-width:560px){
  .mm-cov__mail{white-space:nowrap;font-size:clamp(1.2rem,6.6vw,2.9rem);letter-spacing:-.035em;}
  .mm-cov__mail::after{display:none;}
}
/* custom email follow-cursor */
@media(pointer:fine){.mm-cov__mail,.kc-mail{cursor:none;}}
#mm-mailcur{position:fixed;z-index:1400;left:0;top:0;width:66px;height:66px;border-radius:50%;
  background:#fff;color:#15140F;display:flex;align-items:center;justify-content:center;
  transform:translate(-50%,-50%) scale(.4);opacity:0;pointer-events:none;
  transition:opacity .3s var(--ease),transform .35s cubic-bezier(.16,1,.3,1);}
#mm-mailcur.dark{background:#15140F;color:#fff;}
#mm-mailcur.on{opacity:1;transform:translate(-50%,-50%) scale(1);}
#mm-mailcur svg{width:28px;height:28px;}
#mm-mailcur .flap{transform-origin:center;animation:mm-mailflap 1.5s ease-in-out infinite;}
@keyframes mm-mailflap{0%,100%{transform:translateY(0);}50%{transform:translateY(-2px) scaleY(.82);}}
@media(prefers-reduced-motion:reduce){#mm-mailcur .flap{animation:none;}}

/* animated gradient glow — both menus, more visible + drifting */
#navigation-wrapper::before{background:radial-gradient(52% 44% at 66% 24%,rgba(255,255,255,.08),transparent 62%)!important;
  animation:navglow 12s ease-in-out infinite alternate!important;}
.mm-cov::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(52% 44% at 66% 24%,rgba(255,255,255,.08),transparent 62%);
  animation:navglow 12s ease-in-out infinite alternate;}
.mm-cov__in{position:relative;z-index:1;}
.mm-cov__close{z-index:2;}

/* (Cross-document View Transitions intentionally omitted: in VT-capable
   browsers the auto navigation emits a noisy "Transition was skipped"
   rejection. The JS "close menu, then navigate" delay gives the smooth feel.) */

/* ===== Effekte-Vorschau-Panel + Mikro-Interaktionen ===== */
#mm-fx-btn{position:fixed;left:18px;bottom:18px;z-index:99990;display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--font-ui);font-weight:500;font-size:.82rem;letter-spacing:.04em;color:#fff;background:var(--ink);
  border:0;border-radius:var(--r-pill);padding:.7em 1.1em;cursor:pointer;box-shadow:0 8px 26px rgba(20,18,10,.25);}
#mm-fx-btn .mm-fx-dot{width:7px;height:7px;border-radius:50%;background:#7CD992;}
#mm-fx-panel{position:fixed;left:18px;bottom:64px;z-index:99990;width:300px;max-width:calc(100vw - 36px);
  background:#fff;color:#15140F;border:1px solid rgba(21,20,15,.14);border-radius:14px;box-shadow:0 18px 50px rgba(20,18,10,.22);
  padding:14px;opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .3s,transform .3s,visibility .3s;}
body.mm-fx-open #mm-fx-panel{opacity:1;visibility:visible;transform:none;}
.mm-fx-h{font-family:var(--font-ui);font-weight:700;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:#15140F;margin:4px 4px 12px;}
.mm-fx-row{display:flex;align-items:center;justify-content:space-between;gap:1em;padding:9px 4px;font-size:.9rem;border-top:1px solid rgba(21,20,15,.08);cursor:pointer;}
.mm-fx-row input{width:38px;height:22px;-webkit-appearance:none;appearance:none;background:rgba(21,20,15,.18);border-radius:11px;position:relative;cursor:pointer;transition:background .25s;flex:0 0 auto;}
.mm-fx-row input:checked{background:#15140F;}
.mm-fx-row input::after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .25s;}
.mm-fx-row input:checked::after{transform:translateX(16px);}
.mm-fx-note{font-size:.72rem;color:#8A847B;margin:12px 4px 4px;line-height:1.5;}
#mm-progress{position:fixed;top:0;left:0;width:100%;height:2px;background:var(--ink);z-index:1005;transform:scaleX(0);transform-origin:0 50%;}
html:not([data-fx-progress]) #mm-progress{display:none;}
html[data-accent]:not([data-accent="kein"]) #mm-progress{background:var(--accent);}
#mm-fx-cursor{position:fixed;left:0;top:0;width:16px;height:16px;border-radius:50%;border:1.5px solid #fff;z-index:99980;pointer-events:none;opacity:0;transition:width .25s,height .25s,background .25s,opacity .25s;mix-blend-mode:difference;}
#mm-fx-cursor.big{width:46px;height:46px;background:rgba(255,255,255,.16);}
html:not([data-fx-cursor]) #mm-fx-cursor{display:none;}
html[data-fx-focus] :focus-visible{outline:2px solid var(--ink);outline-offset:3px;border-radius:3px;}
html[data-fx-heroreveal] .fx-hero-rv{opacity:0;transform:translateY(28px);animation:fx-rise .9s cubic-bezier(.16,1,.3,1) forwards;animation-delay:var(--fx-d,0s);}
@keyframes fx-rise{to{opacity:1;transform:none;}}
html[data-fx-stagger] .kc-inner>*{opacity:0;transform:translateY(20px);animation:fx-rise .7s cubic-bezier(.16,1,.3,1) forwards;}
html[data-fx-stagger] .kc-inner>*:nth-child(1){animation-delay:.05s;}
html[data-fx-stagger] .kc-inner>*:nth-child(2){animation-delay:.14s;}
html[data-fx-stagger] .kc-inner>*:nth-child(3){animation-delay:.23s;}
html[data-fx-stagger] .kc-inner>*:nth-child(4){animation-delay:.32s;}
html[data-fx-marquee] #customers .kunden:hover .row .items{animation-play-state:paused!important;}
html[data-fx-marquee] #customers .kunden .item:hover{color:var(--ink);-webkit-text-stroke-color:var(--ink);}

/* case-study intro: headline + two-column justified text (like home Agentur) */
#text-block .content{display:block!important;max-width:var(--container);margin:0 auto;padding-inline:var(--pad);}
#text-block h2.title{max-width:none;margin-bottom:clamp(44px,5.5vw,82px);}
#text-block .content>:nth-child(n+2){grid-column:auto;}
#text-block .body{columns:2;column-gap:clamp(40px,5vw,80px);column-fill:balance;text-align:justify;hyphens:auto;-webkit-hyphens:auto;max-width:none;}
#text-block .body p{break-inside:auto;}
#text-block a.website{margin-top:clamp(26px,3vw,44px);}
@media(max-width:760px){#text-block .body{columns:1;}}

/* customer review — full-bleed tonal band (kein Kasten, ganze Breite) */
.row.kunde_bewertung{background:var(--paper-warm);}
.row.kunde_bewertung .bg-fixed{display:none!important;}
.row.kunde_bewertung .item{max-width:var(--container);margin:0 auto;padding:clamp(70px,10vw,150px) var(--pad);}
.row.kunde_bewertung .item>div{max-width:62ch;margin:0 auto;text-align:center;}
.row.kunde_bewertung .item>div::before{content:"\201C";display:block;font-family:var(--font-display);font-weight:700;font-size:clamp(4rem,8vw,7rem);line-height:.62;color:var(--muted-2);margin-bottom:.05em;}
html[data-accent]:not([data-accent="kein"]) .row.kunde_bewertung .item>div::before{color:var(--accent);}
.row.kunde_bewertung .icon-heart{display:none;}
.row.kunde_bewertung .text{font-family:var(--font-display);font-weight:500;font-style:italic;font-size:clamp(1.25rem,2.2vw,1.9rem);letter-spacing:-.01em;line-height:1.42;color:var(--ink);}
.review-stars{color:var(--ink);letter-spacing:.22em;font-size:clamp(1.05rem,1.5vw,1.35rem);margin-bottom:clamp(20px,2.4vw,30px);}
html[data-accent]:not([data-accent="kein"]) .review-stars{color:var(--accent);}
.row.kunde_bewertung .review-info{margin-top:clamp(24px,3vw,40px);display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.2em .7em;
  font-family:var(--font-ui);font-size:.95rem;letter-spacing:.04em;color:var(--muted);font-style:normal;}
.row.kunde_bewertung .review-info .line{display:inline-block;width:34px;height:1px;background:var(--line-strong);margin-right:.4em;}
.row.kunde_bewertung .review-info a{color:var(--ink);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--line-strong);}
.row.kunde_bewertung .review-info a:hover{text-decoration-color:var(--ink);}

/* case-study FAQ — gleicher Container wie der Seiteninhalt; Ivory voll-bleed via ::before; Trennlinien als Inhaltsbreite-Elemente */
#case-faq{max-width:var(--container);margin:0 auto;padding:clamp(54px,8vw,100px) var(--pad);position:relative;}
#case-faq::before{content:"";position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);width:100vw;background:var(--paper-warm);z-index:-1;}
#case-faq>*{max-width:none;margin-inline:0;padding-inline:0;}
#case-faq .cf-sep{height:1px;background:var(--line);margin:0;}
#case-faq .cf-sep-top{margin-bottom:clamp(40px,6vw,80px);}
#case-faq{padding-bottom:clamp(30px,4vw,56px)!important;}
/* Trennlinie zwischen FAQ und „Weitere Referenzen": Inhaltsbreite, direkt über dem Eyebrow */
#block-weitere-slider{padding-top:clamp(40px,6vw,80px)!important;}
/* Abstand ÜBER der Linie = Abstand DARUNTER (symmetrisch): FAQ-Block liefert denselben
   unteren Abstand wie die .ws-topsep-Marge darunter. */
#case-faq:has(+ #block-weitere-slider){padding-bottom:clamp(40px,6vw,80px)!important;}
#block-weitere-slider .ws-topsep{height:1px;background:var(--line);
  width:calc(var(--container) - 2*var(--pad));max-width:calc(100% - 2*var(--pad));
  margin:0 auto clamp(40px,6vw,80px);}
#case-faq h2.h1{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:0;}
#case-faq .faq-intro{color:var(--ink-2);font-size:clamp(1rem,1.2vw,1.15rem);line-height:1.7;max-width:60ch;margin:1em 0 0;}
#case-faq .faq-list{margin-top:clamp(34px,4.5vw,60px);}

/* HowTo "Wie wir gearbeitet haben" → process flow (numbered step columns) */
.howto-flow{margin:0;}
.howto-flow h3.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);}
.howto-flow .body{display:block;margin-top:clamp(28px,3.4vw,48px);}
.howto-flow .body>p:first-child{margin:0;color:var(--ink-2);font-size:clamp(1.05rem,1.4vw,1.25rem);max-width:60ch;}
.howto-flow .ht-steps{display:flex;flex-direction:column;gap:clamp(72px,6.5vw,92px);margin-top:clamp(28px,3.4vw,48px);}
.howto-flow .ht-steps>p{position:relative;display:flex;gap:clamp(18px,2.4vw,40px);align-items:center;margin:0;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);padding:clamp(24px,2.8vw,40px);color:var(--ink-2);font-size:clamp(.98rem,1.1vw,1.1rem);line-height:1.62;}
.howto-flow .ht-num{flex:0 0 auto;font-family:var(--font-display);font-weight:700;line-height:1;
  font-size:clamp(2.6rem,5vw,4.4rem);letter-spacing:-1.4px;color:var(--ink);min-width:1.7em;}
.howto-flow .ht-content{flex:1;min-width:0;}
.howto-flow .ht-title{display:block;font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.05rem,1.4vw,1.35rem);letter-spacing:-.01em;color:var(--ink);line-height:1;margin:0 0 .4em;}
.howto-flow .ht-txt{display:block;color:var(--ink-2);}
.howto-flow .ht-steps>p:not(:last-child)::after{content:"";position:absolute;left:50%;
  bottom:calc(-1 * (clamp(72px,6.5vw,92px) / 2) - 20px);width:40px;height:40px;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='2.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") center/18px no-repeat;
  transform:translateX(-50%);z-index:4;box-shadow:0 5px 16px rgba(21,20,15,.24);}
.howto-flow .ht-steps>p strong.ht-title{display:block;}
@media(max-width:760px){.howto-flow .ht-steps>p{flex:0 0 78%;aspect-ratio:auto;}
  /* mehr Luft zwischen Pfeil und Boxen am Smartphone */
  .howto-flow .ht-steps{gap:74px;}
  /* Schritt-Beschreibung am Smartphone exakt wie normaler Fließtext */
  .howto-flow .ht-txt{font-size:19px;line-height:1.7;}
  .howto-flow .ht-steps>p:not(:last-child)::after{bottom:-57px;}}
.howto-flow .ht-nav{display:none;}
/* How-to-Ablauf (#ref-howto) — DESIGN IDENTISCH zum Vorgehensweise-Slider (#lp-prozess):
   full-bleed, Karten clamp(300px,38%,440px) → immer Slider mit Anschnitt (kein Zusammenschieben). */
.howto-flow .ht-steps{flex-direction:row;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)));
  margin-top:clamp(28px,3.4vw,48px);padding-bottom:4px;}
.howto-flow .ht-steps::-webkit-scrollbar{display:none;}
.howto-flow .ht-steps>p{display:flex;flex-direction:column;justify-content:flex-start;align-items:stretch;gap:clamp(12px,1.6vw,18px);
  flex:0 0 clamp(300px,38%,440px);min-height:clamp(200px,24vw,300px);min-width:0;scroll-snap-align:start;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);padding:clamp(22px,2.4vw,34px);margin:0;box-sizing:border-box;}
@media(max-width:860px){.howto-flow .ht-steps>p{flex:0 0 clamp(280px,58%,400px);}}
.howto-flow .ht-steps>p:not(:last-child)::after{display:none!important;}
.howto-flow .ht-num{min-width:0;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);}
.howto-flow .ht-content{flex:0 1 auto;border-top:1px solid var(--line);padding-top:clamp(12px,1.6vw,18px);}
/* Howto-Slider: Punkte-Navigation wie beim Vorgehensweise-/Galerie-Slider */
.howto-flow .ht-dots{display:flex;justify-content:flex-start;gap:9px;margin-top:clamp(20px,2.6vw,34px);}
.howto-flow .ht-dots button{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);}
.howto-flow .ht-dots button:hover{opacity:.8;}
.howto-flow .ht-dots button.active{opacity:1;background:var(--ink);transform:scale(1.25);}
html[data-accent]:not([data-accent="kein"]) .howto-flow .ht-dots button.active{background:var(--accent);}
/* iPad-Mockup mit scrollendem Website-Bild im Display (Bild hinter dem Rahmen,
   der Rahmen-Steg beschneidet den Überstand → robust gegen kleine Inset-Abweichungen) */
#rows .row.mockup .mockup{position:relative;max-width:var(--container);margin:0 auto;}
#rows .row.mockup .mockup .mockup-bg{display:block;width:100%;height:auto;position:relative;z-index:2;pointer-events:none;}
#rows .row.mockup .mockup .image-container{position:absolute;z-index:1;overflow:hidden;
  top:6%;bottom:7%;left:5%;right:5%;background:#fff;}
#rows .row.mockup .mockup .image-container img{position:absolute;top:0;left:0;width:100%;height:auto;display:block;will-change:transform;}
/* Detailleistungs-Overlay (Klick auf eine Leistung) */
#node-landingpage_2023 #mission .lp-topic:not(.lp-mm-box) ul li.lo-trigger{cursor:pointer;}
.lo-overlay{position:fixed;inset:0;z-index:4000;display:none;}
.lo-overlay.open{display:block;}
.lo-scrim{position:absolute;inset:0;background:rgba(21,20,15,.55);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);
  opacity:0;transition:opacity .3s var(--ease);}
.lo-overlay.open .lo-scrim{opacity:1;}
.lo-panel{position:absolute;top:50%;left:50%;transform:translate(-50%,-46%);width:min(92vw,640px);max-height:88vh;overflow:hidden;
  display:flex;flex-direction:column;
  background:var(--paper-warm);border:1px solid var(--line);border-radius:var(--r-lg);
  opacity:0;transition:opacity .3s var(--ease),transform .35s var(--ease);box-shadow:0 30px 80px -30px rgba(20,18,10,.5);}
/* eigener Scrollbereich: Panel-Shell + Schließen-Button bleiben fix, nur der Inhalt scrollt */
.lo-scrollarea{overflow-y:auto;-webkit-overflow-scrolling:touch;padding:clamp(28px,4vw,56px);overscroll-behavior:contain;}
.lo-overlay.open .lo-panel{opacity:1;transform:translate(-50%,-50%);}
.lo-close{position:absolute;top:14px;right:14px;z-index:2;width:42px;height:42px;border-radius:50%;border:1px solid var(--line);
  background:var(--paper-warm);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink);transition:background .2s var(--ease);}
.lo-close:hover{background:var(--paper-warm-2);}
.lo-close svg{width:20px;height:20px;}
.lo-eyebrow{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin:0 0 .6em;}
.lo-title{font-family:var(--font-display);font-weight:700;font-size:clamp(1.6rem,3vw,2.4rem);letter-spacing:-.02em;line-height:1.1;color:var(--ink);margin:0 0 clamp(16px,2vw,24px);max-width:none;}
.lo-body{color:var(--ink-2);font-size:18px;line-height:1.7;}
.lo-body p{margin:0 0 1em;}
.lo-body ul{list-style:none;padding:0;margin:.4em 0 0;}
.lo-body li{position:relative;padding-left:1.4em;margin-bottom:.5em;}
.lo-body li::before{content:"";position:absolute;left:0;top:.62em;width:6px;height:6px;border-radius:50%;background:var(--muted-2);}
.lo-cta{display:inline-flex;margin-top:clamp(20px,2.6vw,32px);padding:1em 2em;border-radius:var(--r-pill);background:var(--ink);color:#fff;font-family:var(--font-ui);font-weight:500;text-decoration:none;transition:opacity .2s var(--ease);}
.lo-cta:hover{opacity:.9;}
html[data-accent]:not([data-accent="kein"]) .lo-cta{background:var(--accent);color:var(--accent-ink);}
@media(prefers-reduced-motion:reduce){.lo-scrim,.lo-panel{transition:none;}}
@media(max-width:640px){
  /* wie #lp-prozess am Smartphone: aktive Karte über die volle Inhaltsbreite, zentriert,
     Nachbarn links & rechts gleich angeschnitten bis zu den Fensterrändern */
  .howto-flow .ht-steps{scroll-snap-type:x mandatory;padding-inline:var(--pad)!important;scroll-padding-inline:var(--pad);margin-top:clamp(24px,5vw,36px);}
  .howto-flow .ht-steps>p{flex:0 0 calc(100vw - 2*var(--pad))!important;scroll-snap-align:center;min-height:clamp(180px,60vw,260px);}
  /* Slider-Punkte nicht abschneiden */
  .howto-flow>div{padding-bottom:clamp(26px,6vw,44px)!important;}
}
.howto-flow .ht-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);}
.howto-flow .ht-nav a:hover{background:var(--ink);color:#fff;border-color:var(--ink);}
/* case-study: separate review / howto / faq + emphasise the process block */
/* review divider replaced by full-bleed tonal band */
/* faq divider removed — adjacent block (sand process panel) has a different background */
.howto-flow{background:var(--paper-warm);max-width:none;margin:0;border-radius:0;padding:0!important;}
.howto-flow>div{max-width:var(--container)!important;margin:0 auto!important;padding:clamp(52px,7.5vw,96px) var(--pad) clamp(24px,3vw,40px)!important;position:relative;}
.howto-flow>div::before{content:"";position:absolute;top:0;left:var(--pad);right:var(--pad);height:1px;background:var(--line);}
#rows .howto-flow .text,#rows .howto-flow .text>div,#rows .howto-flow .body{max-width:none;}
.howto-flow .ht-eyebrow{margin:0 0 clamp(18px,2.4vw,30px);}

/* „Weitere Referenzen“ Slider: heading + dots + 3–4 square previews + hover partner */
#block-weitere-slider h4.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);max-width:none;margin-bottom:clamp(28px,3.5vw,52px);}
#block-weitere-slider .ws-eyebrow{display:flex;align-items:center;gap:16px;justify-content:flex-start;max-width:var(--container);margin-left:auto;margin-right:auto;padding-inline:var(--pad);margin-bottom:clamp(18px,2.4vw,30px);}
#block-weitere-slider .slider-navigation{display:none!important;}
#block-weitere-slider .swiper-slide{flex:0 0 clamp(200px,23vw,300px)!important;margin-right:clamp(14px,1.6vw,24px)!important;}
#block-weitere-slider .swiper-slide .bild{aspect-ratio:1/1;border-radius:var(--r-md);overflow:hidden;background:var(--paper-warm-2);}
#block-weitere-slider .swiper-slide video,#block-weitere-slider .swiper-slide img{width:100%;height:100%;object-fit:cover;}
#block-weitere-slider .swiper-slide .link{position:relative;display:block;}
#block-weitere-slider .swiper-slide .wr-cap{position:absolute;left:0;bottom:0;width:100%;padding:14px 16px;display:flex;align-items:center;justify-content:space-between;gap:1em;background:linear-gradient(0deg,rgba(0,0,0,.55),transparent);color:#fff;opacity:0;transform:translateY(8px);transition:opacity .4s var(--ease),transform .4s var(--ease);border-radius:0 0 var(--r-md) var(--r-md);z-index:2;}
#block-weitere-slider .swiper-slide .bild{position:relative;}
#block-weitere-slider .swiper-slide .bild::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,0);transition:background .4s var(--ease);pointer-events:none;z-index:1;}
#block-weitere-slider .swiper-slide .link:hover .bild::after{background:rgba(0,0,0,.2);}
#block-weitere-slider .swiper-slide .link:hover .wr-cap{opacity:1;transform:none;}
#block-weitere-slider .wr-cap .t{font-family:var(--font-display);font-weight:700;font-size:1rem;letter-spacing:-.01em;}
#block-weitere-slider .wr-cap .a{width:30px;height:30px;border:1.5px solid rgba(255,255,255,.6);border-radius:50%;display:flex;align-items:center;justify-content:center;flex:0 0 auto;font-size:1rem;}
#block-weitere-slider .swiper-pagination{display:flex;gap:8px;justify-content:flex-start;margin-top:clamp(26px,3vw,42px);}
/* full-bleed sand slider — edge to edge, taller squares, more space to footer */
#block-weitere-slider{background:var(--paper-warm);width:100vw;margin-left:calc(50% - 50vw);
  padding-block:clamp(72px,11vh,150px);margin-bottom:0;}
#block-weitere-slider .section{max-width:none;padding:0;}
#block-weitere-slider .content-wrapper{max-width:none;}
#block-weitere-slider h4.title{max-width:var(--container);margin-left:auto;margin-right:auto;padding-inline:var(--pad);}
#block-weitere-slider h4.title br{display:none;}
#block-weitere-slider .block-weitere-slider{padding-left:0;}
#block-weitere-slider .swiper-slide{flex:0 0 clamp(300px,42vw,560px)!important;}
#block-weitere-slider .swiper-pagination{max-width:var(--container);margin-left:auto;margin-right:auto;padding-inline:var(--pad);justify-content:flex-start;position:relative;z-index:6;}
#block-weitere-slider .swiper-wrapper::before{content:"";flex:0 0 max(var(--pad), calc((100vw - var(--container)) / 2 + var(--pad)));}
#block-weitere-slider .swiper-wrapper::after{content:"";flex:0 0 max(var(--pad), calc((100vw - var(--container)) / 2 + var(--pad)));}
/* Smartphone: aktive Kachel zentriert, gleicher Abstand/Anschnitt links wie rechts.
   Gescrollt wird der overflow-hidden .swiper-container (per JS-Drag) → Snap dorthin. */
@media(max-width:760px){
  /* wie der Galerie-/Vorgehensweise-Slider der Leistungsseiten: Anschnitt an der
     Inhaltsflucht über padding-inline am Track (robust mit der Drag-JS), keine ::before-Platzhalter */
  #block-weitere-slider .swiper-slide{flex:0 0 calc((100vw - 2*var(--pad)) * 0.84)!important;margin-right:clamp(20px,2.4vw,40px)!important;}
  #block-weitere-slider .swiper-wrapper{padding-inline:var(--pad);box-sizing:border-box;}
  #block-weitere-slider .swiper-wrapper::before,
  #block-weitere-slider .swiper-wrapper::after{display:none!important;}
}
@media(max-width:640px){
  /* wie der Galerie-Slider ≤640: genau EINE Karte über die volle Inhaltsbreite („bis zum Rand") */
  #block-weitere-slider .swiper-slide{flex:0 0 calc(100vw - 2*var(--pad))!important;}
}
@media(prefers-reduced-motion:reduce){html[data-fx-heroreveal] .fx-hero-rv,html[data-fx-stagger] .kc-inner>*{animation:none;opacity:1;transform:none;}}
@keyframes navglow{0%{transform:translate(-7%,-5%) scale(1);opacity:.5;}100%{transform:translate(8%,6%) scale(1.22);opacity:.8;}}
@media(prefers-reduced-motion:reduce){.mm-cov::before,#navigation-wrapper::before{animation:none!important;}}
.mm-cov__rows{display:flex;flex-wrap:wrap;gap:clamp(24px,5vw,80px);margin-top:clamp(34px,5vw,58px);}
.mm-cov__row{display:flex;flex-direction:column;gap:.3em;color:var(--on-dark-muted);font-size:1.1rem;line-height:1.6;}
.mm-cov__row .k{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.4);}
.mm-cov__row a,.mm-cov__row span:not(.k){font-family:var(--font-display);font-weight:700;letter-spacing:-.01em;font-size:calc(clamp(1.3rem,2.4vw,2rem) * var(--nav-scale,1));line-height:1.15;color:#fff;}
.mm-cov__row a:hover{color:var(--muted-2);}
.mm-cov__ctas{display:flex;flex-wrap:wrap;gap:12px;margin-top:clamp(34px,5vw,56px);}
.mm-cov__cta{display:inline-flex;align-items:center;gap:.6em;
  border:1.5px solid rgba(255,255,255,.4);border-radius:var(--r-pill);padding:.95em 1.9em;color:#fff;
  font-family:var(--font-ui);font-weight:500;font-size:.95rem;text-decoration:none;transition:background .3s var(--ease),color .3s;}
.mm-cov__cta:hover{background:#fff;color:var(--dark);}
.mm-cov__cta svg{width:16px;height:16px;}
html[data-accent]:not([data-accent="kein"]) .mm-cov__mail{color:var(--accent);}
@media(prefers-reduced-motion:reduce){.mm-cov{transition:none;}.mm-cov__in>*{transition:none;}}

/* ---- gentler hover transitions site-wide ---- */a,button,.button,.read-more,.ed-chip,#secondary-menu a,#footer a,.kc-mail,.kc-plus,
.mm-cov__cta,.mm-cov__close,.mm-cov__vcard-btn,#mm-contact,.k-div__go,
.references .views-row .link .read-more,#services .leistungen .item h4.title,
#leistungenNeu .leistung h4.title,.kunden .item,.mm-vcard__save{
  transition-duration:.55s!important;transition-timing-function:cubic-bezier(.33,1,.68,1)!important;}
/* soften the spinniest hover (project arrow) */
.references .views-row .link:hover .read-more{transform:rotate(90deg);}

/* contact FAB vCard button + business-card modal */
.mm-cov__vcard-btn{width:clamp(50px,3.6vw,58px);height:clamp(50px,3.6vw,58px);border-radius:50%;
  border:1.5px solid rgba(255,255,255,.4);background:none;color:#fff;cursor:pointer;display:inline-flex;
  align-items:center;justify-content:center;flex:0 0 auto;transition:background .3s,color .3s;}
.mm-cov__vcard-btn:hover{background:#fff;color:var(--dark);}
.mm-cov__vcard-btn svg{width:26px;height:26px;}
.mm-vcard{position:fixed;inset:0;z-index:1300;display:flex;align-items:center;justify-content:center;padding:24px;
  opacity:0;visibility:hidden;transition:opacity .35s var(--ease),visibility .35s;}
.mm-vcard.open{opacity:1;visibility:visible;}
.mm-vcard__scrim{position:absolute;inset:0;background:rgba(8,8,6,.62);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);}
.mm-vcard__card{position:relative;z-index:1;width:min(92vw,430px);background:var(--paper-warm);color:var(--ink);
  border-radius:var(--r-lg);padding:clamp(30px,3.6vw,44px);box-shadow:0 40px 100px rgba(0,0,0,.45);
  transform:translateY(18px) scale(.96);transition:transform .5s cubic-bezier(.16,1,.3,1);overflow:hidden;}
.mm-vcard.open .mm-vcard__card{transform:none;}
.mm-vcard__card::before{content:none;}
html[data-accent]:not([data-accent="kein"]) .mm-vcard__card::before{background:var(--accent);}
.mm-vcard__close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;
  border:1px solid var(--line-strong);background:none;color:var(--ink);cursor:pointer;display:flex;align-items:center;justify-content:center;}
.mm-vcard__close svg{width:18px;height:18px;}
.mm-vcard__logo{font-family:var(--font-display);font-weight:700;font-size:1.55rem;letter-spacing:-.01em;color:var(--ink);display:block;}
.mm-vcard__role{font-size:.8rem;letter-spacing:.05em;color:var(--muted);margin-top:.45em;display:block;}
.mm-vcard__lines{margin:clamp(22px,3vw,32px) 0;display:flex;flex-direction:column;gap:1.05em;
  border-top:1px solid var(--line);padding-top:clamp(20px,2.4vw,28px);}
.mm-vcard__lines>div{display:flex;flex-direction:column;gap:.2em;}
.mm-vcard__lines .k{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);}
.mm-vcard__lines a,.mm-vcard__lines span:not(.k){font-size:1.06rem;color:var(--ink);}
.mm-vcard__lines a:hover{text-decoration:underline;text-underline-offset:3px;}
.mm-vcard__save{margin-top:.4em;width:100%;display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  background:var(--ink);color:var(--paper);border:0;border-radius:var(--r-pill);padding:1.05em 1.5em;
  font-family:var(--font-ui);font-weight:500;font-size:.98rem;cursor:pointer;transition:transform .3s var(--ease),background .3s;}
.mm-vcard__save:hover{transform:translateY(-2px);}
html[data-accent]:not([data-accent="kein"]) .mm-vcard__save{background:var(--accent);color:var(--accent-ink);}
.mm-vcard__save svg{width:18px;height:18px;}
@media(prefers-reduced-motion:reduce){.mm-vcard__card{transition:none;}}

/* ============================================================
   Leistungen block — Tweak variants (Awwwards-inspired)
   liste (default) · karten · gross · raster
   ============================================================ */
html[data-leist="karten"] #services .leistungen{grid-template-columns:1fr;}
html[data-leist="karten"] #services .leistungen .items{display:grid;
  grid-template-columns:repeat(auto-fill,minmax(min(100%,250px),1fr));gap:14px;}
html[data-leist="karten"] #services .leistungen .item{border:1px solid var(--line);border-radius:var(--r-md);
  transition:background .35s var(--ease);}
html[data-leist="karten"] #services .leistungen .item a.link{padding:clamp(20px,2vw,30px);border-bottom:0;
  flex-direction:column;align-items:flex-start;gap:2.4em;min-height:150px;justify-content:space-between;}
html[data-leist="karten"] #services .leistungen .item:hover{background:var(--ink);}
html[data-leist="karten"] #services .leistungen .item a.link:hover h4.title{color:var(--paper);transform:none;}
html[data-leist="karten"] #services .leistungen .item:hover .read-more{border-color:rgba(255,255,255,.5);color:#fff;}

html[data-leist="gross"] #services .leistungen{grid-template-columns:1fr;}
html[data-leist="gross"] #services .leistungen .items{display:flex;flex-direction:column;}
html[data-leist="gross"] #services .leistungen .item h4.title{font-size:clamp(2rem,5.2vw,4.2rem);line-height:1;}
html[data-leist="gross"] #services .leistungen .item a.link{padding:clamp(18px,2.2vw,30px) 0;}
html[data-leist="gross"] #services .leistungen .item a.link:hover h4.title{transform:translateX(28px);}

html[data-leist="raster"] #services .leistungen{grid-template-columns:1fr;}
html[data-leist="raster"] #services .leistungen .items{display:grid;grid-template-columns:repeat(3,1fr);
  gap:0 clamp(30px,4vw,60px);}
html[data-leist="raster"] #services .leistungen .item h4.title{font-size:clamp(1rem,1.4vw,1.25rem);}
html[data-leist="raster"] #services .leistungen .item a.link{padding:clamp(11px,1.1vw,15px) 0;}
@media(max-width:760px){
  html[data-leist="karten"] #services .leistungen .items,
  html[data-leist="raster"] #services .leistungen .items{grid-template-columns:1fr;}
}

/* menu email: no arrow, soft colour fade on hover */
#navigation-wrapper .region-header .email a{transition:color .55s var(--ease)!important;gap:0!important;}
#navigation-wrapper .region-header .email a::after{content:none!important;}
#navigation-wrapper .region-header .email a:hover{color:var(--muted-2)!important;}

/* menu: smaller items so nothing scrolls (scales down to tablet portrait) */
#navigation-wrapper{padding:clamp(70px,10vh,120px) 0 clamp(34px,6vh,68px)!important;}
#navigation-wrapper #main-menu a{font-size:clamp(1.7rem,5vw,3.7rem)!important;}
#navigation-wrapper #main-menu .menu{gap:clamp(2px,.6vw,8px)!important;}
#navigation-wrapper .navigation-container{gap:clamp(24px,4vw,46px)!important;}
/* menu items: gently fade in an arrow on hover */
#navigation-wrapper #main-menu a{position:relative;}
#navigation-wrapper #main-menu a::after{content:"\2192";display:inline-block;margin-left:.4em;font-size:.62em;
  vertical-align:baseline;opacity:0;transform:translateX(-16px);
  transition:opacity .5s var(--ease),transform .5s var(--ease);}
#navigation-wrapper #main-menu a:hover::after{opacity:1;transform:translateX(0);}
/* menu icon: lines shift width on hover */
body:not(.nav-open) #menu-icon:hover #burger span:nth-child(1){width:58%;}
body:not(.nav-open) #menu-icon:hover #burger span:nth-child(2){width:100%;}
body:not(.nav-open) #menu-icon:hover #burger span:nth-child(3){width:80%;}
/* preview media: corners soften (rounder) on hover */
.views-row .bild,.swiper-slide .bild{transition:border-radius .32s var(--ease);}
.views-row .link:hover .bild,.swiper-slide .link:hover .bild{border-radius:clamp(11px,1.1vw,18px);}
/* two-column menu layout (tweak) */
html[data-menulayout="split"] #navigation-wrapper .navigation-container{display:grid;grid-template-columns:1.9fr 1fr;gap:clamp(40px,6vw,100px);align-items:center;}
html[data-menulayout="split"] #navigation-wrapper #main-menu a{font-size:clamp(2rem,6.5vw,5.4rem)!important;}
html[data-menulayout="split"] #navigation-wrapper .region-header{flex-direction:column;align-items:flex-start;gap:clamp(26px,3vw,42px);border-top:0;padding-top:0;}
@media(max-width:900px){html[data-menulayout="split"] #navigation-wrapper .navigation-container{grid-template-columns:1fr;}}

/* ============================================================
   INSIGHTS-ARTIKEL — Mid-Artikel-Referenz-Slider (themengefiltert)
   ============================================================ */
.art-refs{position:relative;width:100vw;margin-left:calc(50% - 50vw);margin-block:clamp(82px,9.5vw,134px);padding:0;}
.art-refs::before,.art-refs::after{content:"";position:absolute;left:50%;transform:translateX(-50%);
  width:calc(min(100vw, var(--container)) - 2 * var(--pad));height:1px;background:var(--line);}
.art-refs::before{top:calc(-1 * clamp(40px,4.75vw,66px));}
.art-refs::after{bottom:calc(-1 * clamp(40px,4.75vw,66px));}
/* Artikel über die ganze Inhaltsbreite (statt schmaler 880px-Spalte) */
/* Oberste Artikel-Headline auf die große Seiten-H1-Größe (wie Startseite/Leistungen) */
.page-insights-article .art h1{font-size:clamp(2.5rem,6vw,5.8rem);line-height:1.04;letter-spacing:-.03em;}
@media(max-width:760px){.page-insights-article .art h1{font-size:clamp(2.1rem,8.4vw,3rem);line-height:1.06;}}
/* ── Insights-Fließtext: editoriale Lesespalte (komfortables Maß statt voller Breite) ── */
.page-insights-article .art-body{max-width:none;font-feature-settings:"liga" 1,"kern" 1;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;}
.page-insights-article .art-body > p,
.page-insights-article .art-body > ul,
.page-insights-article .art-body > ol,
.page-insights-article .art-body > h2,
.page-insights-article .art-body > h3{max-width:70ch;}
.page-insights-article .art-faq{max-width:74ch;}
.page-insights-article .art-lead{max-width:52ch;font-size:clamp(1.25rem,1.5vw,1.45rem);font-weight:500;line-height:1.5;color:var(--ink);}
/* Fließtext: größer, ruhiger, wärmeres Ink */
.page-insights-article .art-body p,
.page-insights-article .art-faq dd{font-size:1.18rem;line-height:1.75;color:var(--ink-2);text-wrap:pretty;margin:0 0 1.1em;}
.page-insights-article .art-body li{font-size:1.18rem;line-height:1.65;color:var(--ink-2);}
/* Nur ZWEI Textgrößen (Lead + Fließtext); Hierarchie sonst über Schnitt/Farbe, kein extra Größenschritt für den Auftakt */
.page-insights-article .art-body > p:first-of-type{font-size:1.18rem;line-height:1.75;}
/* Zwischenüberschriften klarer abgesetzt */
.page-insights-article .art-body h2{margin-top:1.9em;letter-spacing:-.02em;}
.page-insights-article .art-body strong{color:var(--ink);font-weight:600;}
/* Inline-Links: dezente, hochwertige Unterstreichung */
.page-insights-article .art-body p a,.page-insights-article .art-body li a,.page-insights-article .art-faq dd a{
  color:var(--ink);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;
  text-decoration-color:var(--line-strong);transition:text-decoration-color .25s var(--ease);}
.page-insights-article .art-body a:hover,.page-insights-article .art-faq dd a:hover{text-decoration-color:var(--ink);}
/* Listen: einheitlicher Aufzählungspunkt (gefüllter Punkt) wie im restlichen Theme */
.page-insights-article .art-body ul{list-style:none;padding-left:0;margin:0 0 1.3em;}
.page-insights-article .art-body ul li{position:relative;padding-left:1.5em;margin-bottom:.55em;}
.page-insights-article .art-body ul li::before{content:"";position:absolute;left:.1em;top:.66em;width:6px;height:6px;background:var(--muted-2);border-radius:50%;}
.art-refs-head{display:flex;align-items:baseline;justify-content:space-between;gap:1em;flex-wrap:wrap;max-width:var(--container);margin:0 auto clamp(18px,2.2vw,28px);padding-inline:var(--pad);}
.art-refs .art-refs-eyebrow{font-family:var(--font-ui);font-weight:500;text-transform:uppercase;letter-spacing:.14em;font-size:.74rem;line-height:1.2;color:var(--muted);margin:0 0 6px;}
/* Eyebrow nicht vom Fließtext-p-Styling vergrößern lassen + mehr Abstand zur Headline */
.page-insights-article .art-refs .art-refs-eyebrow{font-size:.72rem;line-height:1.2;margin:0 0 14px;color:var(--muted);}
.page-insights-article .art-refs .art-refs-h{margin-top:0;}
.art-refs .art-refs-h{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;line-height:1.12;
  font-size:clamp(1.35rem,2.3vw,1.95rem);color:var(--ink);margin:0;max-width:none;}
.art-refs-all{font-family:var(--font-ui);font-weight:500;font-size:.92rem;color:var(--ink);display:inline-flex;align-items:center;gap:.35em;white-space:nowrap;}
.art-refs-all .ar{transition:transform .35s var(--ease);}
.art-refs-all:hover .ar{transform:translate(4px,-4px);}
.art-refs-scroll{overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;cursor:grab;}
.art-refs-scroll::-webkit-scrollbar{display:none;}
.art-refs-scroll:active{cursor:grabbing;}
.art-refs-track{display:flex;gap:clamp(16px,2vw,34px);width:max-content;padding-block:4px;}
/* Touch (Smartphone/Tablet): Finger-Swipe rastet Karte für Karte wie der
   „Weitere Referenzen"-Slider (kein Auto-Lauf). */
.art-refs.art-refs-touch .art-refs-scroll{scroll-snap-type:x mandatory;scroll-padding-inline:var(--pad);}
.art-refs.art-refs-touch .art-refs-card{scroll-snap-align:center;scroll-snap-stop:always;}
.art-refs.art-refs-touch .art-refs-track{padding-inline:var(--pad);}
.art-refs-card{flex:0 0 37vw;min-width:300px;color:inherit;}
.arf-vid{aspect-ratio:16/9;border-radius:var(--r-md);overflow:hidden;background:var(--paper-warm-2);position:relative;}
/* Smartphone: Artikel-Referenz-Slider mit größeren, quadratischen Karten (mehr Raum/Größe) */
@media(max-width:760px){
  html:not([data-artrefs="raster"]):not([data-artrefs="liste"]) .art-refs-track .art-refs-card{flex:0 0 68vw;min-width:0;}
  html:not([data-artrefs="raster"]):not([data-artrefs="liste"]) .art-refs-track .arf-vid{aspect-ratio:1/1;}
}
.arf-vid video,.arf-vid img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s var(--ease);}
.art-refs-card:hover .arf-vid video,.art-refs-card:hover .arf-vid img{transform:scale(1.045);}
.arf-meta{display:flex;flex-direction:column;gap:3px;margin-top:13px;}
.arf-k{font-size:.7rem;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);}
.arf-t{font-family:var(--font-display);font-weight:700;font-size:clamp(1.02rem,1.4vw,1.2rem);letter-spacing:-.01em;line-height:1.2;color:var(--ink);}
.arf-d{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:2px;}
.art-refs-dots{display:flex;gap:9px;justify-content:flex-start;margin-top:clamp(20px,2.4vw,30px);max-width:var(--container);margin-inline:auto;padding-inline:var(--pad);}
.art-refs-dot{width:8px;height:8px;border-radius:99px;background:var(--line-strong);border:0;padding:0;cursor:pointer;transition:width .3s var(--ease),background .3s var(--ease);}
.page-insights-article .art-refs-dot.active{background:var(--ink);width:26px;}
/* ── Blogartikel-Referenzen: Nicht-Slider-Varianten (Tweak data-artrefs) ── */
html[data-artrefs="raster"] .art-refs-scroll,
html[data-artrefs="liste"] .art-refs-scroll{overflow:visible;cursor:default;}
html[data-artrefs="raster"] .art-refs-dots,
html[data-artrefs="liste"] .art-refs-dots{display:none!important;}
html[data-artrefs="raster"] .art-refs-card.is-dupe,
html[data-artrefs="liste"] .art-refs-card.is-dupe{display:none!important;}
/* Raster: 3-spaltiges Grid in Inhaltsbreite */
html[data-artrefs="raster"] .art-refs-track{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2vw,30px);width:auto;max-width:var(--container);margin-inline:auto;padding-inline:var(--pad);}
html[data-artrefs="raster"] .art-refs-card{flex:none;min-width:0;width:auto;}
@media(max-width:760px){html[data-artrefs="raster"] .art-refs-track{grid-template-columns:1fr 1fr;}}
@media(max-width:480px){html[data-artrefs="raster"] .art-refs-track{grid-template-columns:1fr;}}
/* Liste: gestapelte Zeilen, Thumbnail links + Text rechts, in Inhaltsbreite */
html[data-artrefs="liste"] .art-refs-track{display:flex;flex-direction:column;gap:0;width:auto;max-width:var(--container);margin-inline:auto;padding-inline:var(--pad);}
html[data-artrefs="liste"] .art-refs-card{flex:none;min-width:0;width:auto;display:grid;grid-template-columns:clamp(110px,18%,190px) 1fr;align-items:center;gap:clamp(18px,2.4vw,34px);padding:clamp(15px,1.9vw,24px) 0;border-top:1px solid var(--line);}
html[data-artrefs="liste"] .art-refs-card:last-child{border-bottom:1px solid var(--line);}
html[data-artrefs="liste"] .arf-vid{aspect-ratio:1/1;}
html[data-artrefs="liste"] .arf-meta{margin-top:0;}
html[data-artrefs="liste"] .arf-t{font-size:clamp(1.1rem,1.9vw,1.55rem);}
/* Anker-Sprungziele (Bottom-Dock) unter den fixen Header setzen */
.page-insights-article .art h1[id],
.page-insights-article .art-body h2[id],
.page-insights-article .art-faq h2[id]{scroll-margin-top:clamp(100px,14vh,140px);}

/* ============================================================
   INSIGHTS-ARTIKEL — CTA-Box im „Strategiegespräch"-Stil (dunkel)
   ============================================================ */
/* Vision-Fließtext („Noch Fragen? … FAQ …") überall entfernen – er ist
   farblich kaum sichtbar und unerwünscht. Blogartikel nutzen .acta-box
   (kein #vision) und bleiben daher unberührt. */
#vision .text{display:none!important;}
/* FAQ „Weitere Fragen anzeigen" (>5 Elemente, außer FAQ-Seite) */
.faq-hidden{display:none!important;}
.faq-more-btn{display:inline-flex;align-items:center;gap:.5em;margin-top:clamp(18px,2.2vw,28px);
  font-family:var(--font-ui);font-weight:500;font-size:1rem;color:var(--ink);
  background:none;border:1.5px solid var(--line-strong);border-radius:var(--r-pill);
  padding:.82em 1.6em;cursor:pointer;transition:background .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease);}
.faq-more-btn::after{content:"+";font-size:1.15em;line-height:0;}
.faq-more-btn:hover{background:var(--ink);color:#fff;border-color:var(--ink);}
.page-insights-article .art-cta.acta-host{background:none!important;padding:0!important;text-align:left!important;border-radius:0!important;
  max-width:var(--container);margin:clamp(44px,6vw,84px) auto clamp(8px,1.5vw,20px);padding-inline:var(--pad)!important;}
/* CTA exakt auf „Hero-Breite": gleiche Bleed-Technik wie die Hero-Medien (.references .views-row:nth-child(1) .bild) */
.acta-host .acta-box{margin-inline:calc(clamp(14px,1.8vw,30px) - clamp(20px,5vw,140px));}
.acta-box{background:var(--dark);color:#fff;border-radius:clamp(18px,2.4vw,30px);position:relative;overflow:hidden;
  padding:clamp(28px,3.2vw,48px) clamp(28px,4vw,60px);display:flex;align-items:stretch;gap:clamp(30px,4vw,56px);}
.acta-box::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(60% 120% at 88% 0%,rgba(255,255,255,.1),transparent 60%);}
.acta-main{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;justify-content:center;position:relative;z-index:1;}
.acta-host .acta-eyebrow{font-family:var(--font-ui);font-weight:500;text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:rgba(255,255,255,.6);margin:0 0 .8em;}
.acta-host .acta-h{font-family:var(--font-display);font-weight:700;font-size:clamp(1.5rem,2.7vw,2.3rem);line-height:1.14;letter-spacing:-.02em;color:#fff;margin:0;max-width:24ch;text-wrap:balance;}
.acta-host .acta-p{color:rgba(255,255,255,.72);margin:.9em 0 0;max-width:52ch;line-height:1.6;font-size:1.04rem;}
.acta-host .acta-btns{display:flex;flex-wrap:wrap;gap:12px;margin-top:clamp(20px,2.4vw,30px);}
.acta-host .acta-btns a{font-family:var(--font-ui);font-weight:600;font-size:1.01rem;line-height:1;margin:0;padding:1.05em 2em;border-radius:var(--r-pill);
  display:inline-flex;align-items:center;gap:.5em;white-space:nowrap;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease),color .25s var(--ease);}
/* Primär-CTA: in sehr schmalen Versionen Kurz-Label, bevor der Button zweizeilig wird */
.acta-host .acta-btns a.primary .acta-lbl-short{display:none;}
@media(max-width:430px){
  .acta-host .acta-btns a.primary .acta-lbl-long{display:none;}
  .acta-host .acta-btns a.primary .acta-lbl-short{display:inline;}
}
.acta-host .acta-btns a.primary{background:#fff;color:var(--dark);border:0;}
.acta-host .acta-btns a.primary:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(0,0,0,.34);}
.acta-host .acta-btns a.ghost{background:transparent;border:1.5px solid rgba(255,255,255,.42);color:#fff;}
.acta-host .acta-btns a.ghost:hover{background:rgba(255,255,255,.1);border-color:#fff;}
html[data-accent]:not([data-accent="kein"]) .acta-host .acta-btns a.primary{background:var(--accent);color:var(--accent-ink);}
.acta-facts{flex:0 0 clamp(196px,27%,290px);align-self:stretch;position:relative;z-index:1;
  border-left:1px solid rgba(255,255,255,.18);padding-left:clamp(24px,3vw,46px);
  display:flex;flex-direction:column;justify-content:space-between;}
.acta-vf{padding:clamp(12px,1.5vw,18px) 0;border-top:1px solid rgba(255,255,255,.14);}
.acta-vf:first-child{border-top:0;padding-top:0;}
.acta-vf:last-child{padding-bottom:0;}
.acta-vn{display:block;font-family:var(--font-display);font-weight:700;font-size:clamp(2.1rem,3.4vw,3.2rem);line-height:.95;letter-spacing:-.03em;color:#fff;}
html[data-accent]:not([data-accent="kein"]) .acta-vn{color:var(--accent);}
.acta-vl{display:block;font-size:.88rem;line-height:1.35;color:rgba(255,255,255,.66);margin-top:4px;}
@media(max-width:820px){
  .acta-box{flex-direction:column;gap:clamp(22px,4vw,30px);}
  .acta-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);display:grid;grid-template-columns:1fr 1fr;gap:0 clamp(18px,4vw,28px);}
  .acta-vf{border-top:0;padding:10px 0;}
  .acta-vf:nth-child(n+3){border-top:1px solid rgba(255,255,255,.14);}
}

/* INSIGHTS-ARTIKEL — "Weitere Insights" (einheitlich, unabhängig vom Inline-CSS) */
.page-insights-article .art-rel{max-width:var(--container);margin:clamp(40px,6vw,80px) auto clamp(54px,8vh,110px);padding-inline:var(--pad);}
.page-insights-article .art-rel h2{font-family:var(--font-display);font-weight:700;font-size:clamp(1.3rem,2vw,1.7rem);margin-bottom:24px;}
.page-insights-article .art-rel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
@media(max-width:760px){.page-insights-article .art-rel-grid{grid-template-columns:1fr;}}
.page-insights-article .art-rel .ins-card{display:flex;flex-direction:column;gap:10px;padding:clamp(22px,2.2vw,30px);border:1px solid var(--line);border-radius:var(--r-lg);background:var(--paper);color:inherit;transition:border-color .3s var(--ease),transform .3s var(--ease);}
.page-insights-article .art-rel .ins-card:hover{border-color:var(--line-strong);transform:translateY(-3px);}
.page-insights-article .art-rel .ins-meta{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:500;}
.page-insights-article .art-rel .ins-t{font-family:var(--font-display);font-weight:700;font-size:clamp(1.1rem,1.5vw,1.35rem);letter-spacing:-.01em;line-height:1.22;color:var(--ink);}
.page-insights-article .art-rel .ins-more{font-family:var(--font-ui);font-weight:500;font-size:.95rem;color:var(--ink);margin-top:auto;}
