/* BIANCO — Page-Shell: Wrapper, Übergänge, Header/Nav/Sticky, Home-Intro */

/*
 * Kein padding-bottom am Wrapper: vermeidet einen zweiten „Streifen“ unter dem Footer.
 * Abstand zur Viewport-Unterkante: nur .site-footer padding-bottom (--site-footer-pad-bottom, i. d. R. --page-pad).
 */
.page-wrapper {
	padding-top: var(--page-pad);
	padding-left: var(--page-pad);
	padding-right: var(--page-pad);
	padding-bottom: 0;
	box-sizing: border-box;
	min-height: 0;
}

/*
 * Ohne doppeltes Ober-Padding: der Header bringt bereits max(--page-pad, safe-area) oben
 * (body:not(.page-home) .site-header). Sonst sitzt Logo/Nav zu weit unten (Service, About, Contact …).
 */
body:not(.page-home) .page-wrapper {
	padding-top: 0;
}

/* Page transitions deaktiviert (keine Exit/Enter Animationen). */

/*
 * Home: .home-scroll (Talents + dunkler Footer) — Header bleibt .site-header--light im Markup;
 * beim Scrollen Marke + Nav wie dark-fill (JS: .home--over-talents-dark).
 */
body.page-home.home--over-talents-dark .site-header,
body.page-home.home--focus-talents .site-header {
	color: var(--white);
	background: var(--black);
	transition: none;
}

body.page-home.home--over-talents-dark .site-header .site-header__loading,
body.page-home.home--focus-talents .site-header .site-header__loading {
	color: var(--white);
	transition: none;
}

body.page-home.home--over-talents-dark .site-header .site-nav a,
body.page-home.home--focus-talents .site-header .site-nav a {
	color: var(--white);
	transition: none;
}

body.page-home.home--over-talents-dark .site-header .site-nav a:hover,
body.page-home.home--over-talents-dark .site-header .site-nav a:focus,
body.page-home.home--focus-talents .site-header .site-nav a:hover,
body.page-home.home--focus-talents .site-header .site-nav a:focus {
	color: var(--white);
}

body.page-home.home--over-talents-dark .site-header .site-header__brand.logo-mega--svg,
body.page-home.home--focus-talents .site-header .site-header__brand.logo-mega--svg {
	position: relative;
	isolation: isolate;
	background-color: var(--white);
	-webkit-mask-image: var(--bianco-wordmark-mask);
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-position: center;
	-webkit-mask-size: 100% 100%;
	mask-image: var(--bianco-wordmark-mask);
	mask-repeat: no-repeat;
	mask-position: center;
	mask-size: 100% 100%;
}

body.page-home.home--over-talents-dark .site-header .logo-mega--svg img.site-header__wordmark,
body.page-home.home--focus-talents .site-header .logo-mega--svg img.site-header__wordmark {
	opacity: 0 !important;
	transition: none !important;
	filter: none;
	background: none;
	-webkit-mask-image: none;
	mask-image: none;
}

/* Subnav ist immer hell: keine "over-talents-dark" Overrides mehr */

/* Alte Exit/Enter Transition-Styles entfernt. */

/*
 * Zielseite: Logo + Header-Zeile bleiben sofort sichtbar (schwarzer Hero wie Ziel);
 * nur Hero-Inhalt (ohne Header/Sticky-Leiste) und Projekt-Body blenden von unten ein.
 */
/* (Page-Transitions entfernt) */

/* Erster Hero: volle Viewport-Breite; oben kein negativer Margin mehr nötig (Wrapper-Ober-Padding nur auf Home). */
.page-wrapper > .hero-dark:first-child,
.page-wrapper > main.page-detail > .hero-dark:first-child {
	margin-top: 0;
	margin-left: calc(-1 * var(--page-pad));
	margin-right: calc(-1 * var(--page-pad));
	width: calc(100% + 2 * var(--page-pad));
	max-width: none;
	padding-left: var(--page-pad);
	padding-right: var(--page-pad);
	box-sizing: border-box;
}

*,
*::before,
*::after {
	box-sizing: border-box;
}

.visually-hidden {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

html {
	font-size: 100%;
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
	scroll-padding-top: var(--anchor-scroll-padding);
	/* Verhindert Breiten-/vh-Sprünge wenn Scrollbalken ein-/ausblendet (Chromium, Brave, …) */
	scrollbar-gutter: stable;
}

body {
	margin: 0;
	background: var(--bg);
	color: var(--fg);
	font-family: var(--font-mono);
	font-size: var(--text-mono);
	font-weight: 400;
	line-height: 1.55;
}

/* Fließtext = Mono: keine fetten Schnitte durch CMS/Markup */
body :where(strong, b) {
	font-weight: 400;
}

/* Display-Schrift: Betonung übernimmt die Eltern-Stärke */
:is(
	.list-mega a,
	.page-article__title,
	.hero-dark__title,
	.logo-mega,
	.about-claim,
	.service-band__row-title,
	.service-impact__stat-value,
	.service-impact__statement,
	.contact-page__submit
) :where(strong, b) {
	font-weight: inherit;
}

@media (prefers-reduced-motion: reduce) {
	html {
		scroll-behavior: auto;
	}

	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
	}

	.home-intro {
		display: none !important;
	}

	body:is(.page-home, .page-service) .home-scroll {
		position: static !important;
		transform: none !important;
		transition: none !important;
		overflow: visible !important;
	}
}

a {
	color: inherit;
	text-decoration: none;
	border-bottom: 1px solid transparent;
	transition: border-color 0.15s ease, color 0.15s ease;
}

a:hover {
	border-bottom-color: currentColor;
}

.mono {
	font-family: var(--font-mono);
	font-size: var(--text-mono);
	font-weight: 400;
}

.small {
	font-size: var(--text-ui-sm);
}

.tiny {
	font-size: var(--text-lede);
	text-transform: uppercase;
}

.logo-mega {
	display: block;
	width: 100%;
	font-family: var(--font-display);
	font-size: var(--text-brand-logo);
	font-weight: 700;
	line-height: 0.92;
	text-transform: uppercase;
	text-align: center;
	border: 0;
	margin: 0 auto;
	padding: 0;
	transform: scaleX(1.04);
	transform-origin: center center;
}

.logo-mega--svg {
	transform: none;
	line-height: 0;
}

.logo-mega--svg img {
	display: block;
	width: 100%;
	height: auto;
}

.logo-mega--footer {
	margin-block: 0;
	margin-top: 3rem;
	padding-bottom: 0;
}

/* Großes BERLIN unter dem Footer-Inhalt (nicht abschneiden: kein neg. Margin, kein overflow hidden) */
.site-footer--dark .logo-mega--footer {
	margin-top: 1rem;
	margin-bottom: 0;
	padding-bottom: 0;
}

/* Header (document flow; kompakte Leiste = separates .site-sticky-bar) */
.site-header {
	position: relative;
	z-index: 5;
	padding: 0;
	max-width: none;
	margin: 0;
	width: 100%;
	box-sizing: border-box;
}

/* Mit Content-/Footer-Raster bündig (volle Breite bis --max) */
body:not(.page-home) .site-header {
	max-width: var(--max);
	margin-inline: auto;
	/* Früher: Abstand durch sichtbare Loading-Zeile; jetzt explizit wie .page-wrapper-Oberkante */
	padding-top: max(var(--page-pad), env(safe-area-inset-top, 0px));
}

.site-header--dark {
	color: var(--white);
}

.site-header--dark .logo-mega:not(.logo-mega--svg) {
	color: var(--white);
}

/*
 * Wordmark hell: Maske am <img> — nur wenn nicht .site-header__wordmark--mask-only (About/Case/Talent:
 * Maske am <a>, Bild opacity 0; sonst legt sich nach SVG-Decode die dunkle Vorlage über die Maske).
 */
.site-header--dark .logo-mega--svg img.site-header__wordmark:not(.site-header__wordmark--mask-only) {
	filter: none;
	background-color: var(--white);
	-webkit-mask-image: var(--bianco-wordmark-mask);
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-position: center;
	-webkit-mask-size: 100% 100%;
	mask-image: var(--bianco-wordmark-mask);
	mask-repeat: no-repeat;
	mask-position: center;
	mask-size: 100% 100%;
}

.site-header__brand.logo-mega--svg {
	text-decoration: none;
	border: 0;
}

.site-header__brand.logo-mega--svg .site-header__wordmark {
	display: block;
	width: 100%;
	height: auto;
}

/* Nur während Home-Intro sichtbar (aria-labelledby auf #home-intro); sonst aus */
.site-header__loading {
	display: none;
	margin: 0 0 0.5rem;
	font-family: var(--font-mono);
	font-size: var(--text-lede);
	text-transform: uppercase;
	color: var(--fg-muted);
}

.site-header--dark .site-header__loading {
	color: var(--white);
}

.site-nav {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 0.75rem 1.5rem;
	max-width: 100%;
	margin: 1rem 0 0;
	padding: 0;
	font-size: var(--text-label);
	font-weight: 400;
	text-transform: uppercase;
}

.site-nav__muted {
	opacity: 1;
}

/* Hauptnav: gleiches 12er-Raster — Cases/Talents ab Spalte 4, Service/About ab 7, Contact ab 11 */
.site-nav--mega {
	display: grid;
	grid-template-columns: repeat(var(--layout-grid-cols), minmax(0, 1fr));
	column-gap: var(--layout-grid-gap);
	row-gap: 0.5rem;
	align-items: baseline;
	width: 100%;
	margin: 1rem 0 0;
	padding: 0;
	font-size: var(--text-label);
	font-weight: 400;
	text-transform: uppercase;
}

.site-nav--mega .site-nav__cluster {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 2rem;
	min-width: 0;
}

.site-nav--mega .site-nav__cluster--left {
	grid-column: 4 / 7;
	justify-self: start;
	justify-content: flex-start;
	text-align: left;
}

.site-nav--mega .site-nav__cluster--center {
	grid-column: 7 / 11;
	justify-self: start;
	justify-content: flex-start;
	text-align: left;
}

.site-nav--mega .site-nav__cluster--right {
	grid-column: 11 / -1;
	justify-self: end;
	justify-content: flex-end;
	text-align: right;
}

.site-nav__mega-panels {
	display: contents;
}

/* Klapplisten-Region (aria-controls); Desktop: durchreichen für 12er-Grid */
.site-nav__mega-links {
	display: contents;
}

/*
 * Tablet / mobile (≤64rem): Fixleiste = Logomark + Menü-Toggle / aufgeklappte Nav.
 * Mega-Nav im Seitenkopf ausgeblendet (Bedienung über Sticky-Leiste nach Scroll).
 */
@media (max-width: 64rem) {
	.site-nav__mega-panels {
		display: flex;
		flex-direction: row;
		align-items: center;
		flex: 1 1 auto;
		min-width: 0;
		width: 100%;
		gap: 0;
		padding-top: 0;
		box-sizing: border-box;
	}

	/* Eine Linkzeile im verbleibenden Platz; display:contents → <a> direkt im Flex */
	.site-nav__mega-links {
		display: flex;
		flex-direction: row;
		flex-wrap: nowrap;
		justify-content: space-between;
		align-items: center;
		column-gap: 0.12rem;
		flex: 1 1 auto;
		min-width: 0;
		padding-top: 0;
		width: auto;
		max-width: none;
		box-sizing: border-box;
	}

	.site-nav__mega-links .site-nav__cluster {
		display: contents;
	}

	.site-nav__mega-links .site-nav__cluster a,
	.site-nav__mega-links .site-nav__cluster .site-nav__muted {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		flex: 1 1 0;
		min-width: 0;
		max-width: 100%;
		padding: 0.3rem 0.08rem;
		min-height: 2rem;
		line-height: 1.2;
		text-align: center;
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
		box-sizing: border-box;
	}

	.site-nav--mega {
		display: flex;
		flex-direction: row;
		align-items: center;
		flex: 1 1 auto;
		min-width: 0;
		gap: 0;
		width: auto;
		max-width: none;
		margin-top: 0.75rem;
	}

	.site-sticky-bar .site-nav--mega {
		margin-top: 0;
	}

	/* Fixleiste: B + Subnav eine Zeile; Links im restlichen Platz justified */
	.site-sticky-bar__inner:has(> .site-nav--mega) {
		display: flex;
		flex-direction: row;
		flex-wrap: nowrap;
		align-items: center;
		justify-content: flex-start;
		gap: 0.45rem var(--layout-grid-gap);
		grid-template-columns: unset;
	}

	.site-sticky-bar__inner:has(> .site-nav--mega) .site-sticky-bar__brand {
		grid-column: unset;
		justify-self: unset;
		flex: 0 0 auto;
		align-self: center;
	}

	.site-sticky-bar__inner:has(> .site-nav--mega) > .site-sticky-bar__nav.site-nav--mega {
		flex: 1 1 auto;
		min-width: 0;
		width: auto;
		max-width: none;
		grid-column: unset;
	}

	.site-sticky-bar__inner:has(> .site-nav--mega) .site-nav__mega-panels {
		min-width: 0;
	}

	/* Seitenkopf: nur Wortmarke — Mega-Nav nur in der Fixleiste (nach Scroll) */
	.site-header:has(> .site-nav--mega) {
		display: flex;
		flex-direction: row;
		flex-wrap: wrap;
		align-items: flex-start;
		justify-content: flex-start;
		column-gap: var(--layout-grid-gap);
		row-gap: 0;
	}

	.site-header:has(> .site-nav--mega) > .site-header__brand {
		flex: 1 1 100%;
		width: 100%;
		min-width: 0;
		max-width: none;
		align-self: stretch;
	}

	.site-header:has(> .site-nav--mega) > .site-header__brand .site-header__wordmark {
		width: 100%;
		max-width: none;
	}

	.site-header:has(> .site-nav--mega) > .site-nav--mega {
		display: none !important;
	}
}

.page-home .site-header {
	/* Dauerhaft über Content: Wordmark immer "oben" */
	z-index: 100;
	background: var(--bg-warm);
	/* Wie Innenseiten: safe-area über .page-wrapper page-pad ausgleichen (kein Logo-Transform mehr auf Home). */
	padding-top: max(0px, calc(env(safe-area-inset-top, 0px) - var(--page-pad)));
	/* Kein extra padding-bottom: Abstand Nav → erster Inhalt nur über .section / .page-intro (--page-intro-vspace), wie Service/About. */
	padding-bottom: 0;
	transition: padding 0.22s ease, background 0.38s cubic-bezier(0.22, 1, 0.36, 1),
		color 0.38s cubic-bezier(0.22, 1, 0.36, 1);
}

/*
 * ?focus=talents: gleiche vertikale Geometrie wie normale Home (.page-wrapper page-pad + Header safe-area),
 * damit Intro/erste Zeile auf derselben Höhe sitzen.
 */

/*
 * focus=talents: html/body schwarz (Gutter neben Header bleibt schwarz). Ab Cases hell per Breakout
 * wie .home-scroll — volle Viewport-Breite warm, Inhalt mit page-pad; Footer-.home-scroll ebenso.
 */
html:has(body.page-home.home--focus-talents) {
	background-color: var(--black);
}

body.page-home.home--focus-talents {
	background-color: var(--black);
}

/*
 * Cases-Band: horizontal gegen .page-wrapper-Pad ausfahren + seitliches Innenpad,
 * sonst schimmert schwarz durch die 1rem-Gutter neben dem warmen Block.
 */
body.page-home.home--focus-talents #cases.home__cases.section {
	background-color: var(--bg-warm);
	color: var(--fg);
	margin-left: calc(-1 * var(--page-pad));
	margin-right: calc(-1 * var(--page-pad));
	width: calc(100% + 2 * var(--page-pad));
	max-width: none;
	box-sizing: border-box;
	padding-left: var(--page-pad);
	padding-right: var(--page-pad);
}

/* Erster home-scroll = nur Talents — bleibt schwarz; zweiter = Footer: hell (überschreibt pages.css) */
body.page-home.home--focus-talents .home__exit-mask-root > .home-scroll:first-of-type {
	background: var(--black);
	color: var(--white);
}

body.page-home.home--focus-talents .home__exit-mask-root > .home-scroll.home-scroll--footer-light {
	background: var(--bg-warm);
	color: var(--fg);
}

/* Nach .page-home .site-header: dunkles Chrome (sonst überschreibt warmes Grau). */
body.page-home.home--focus-talents .site-header,
body.page-home.home--over-talents-dark .site-header {
	background: var(--black);
	color: var(--white);
	transition: none;
}

/* Fixierte Kompaktleiste (Logomark + Nav) — unabhängig vom Seiten-Header */
.site-sticky-bar {
	position: fixed;
	left: 0;
	right: 0;
	top: 0;
	z-index: 120;
	pointer-events: none;
	visibility: hidden;
	opacity: 0;
	transform: translateY(-100%);
	transition:
		transform 0.38s cubic-bezier(0.22, 1, 0.36, 1),
		opacity 0.28s ease,
		visibility 0s linear 0.38s;
	box-sizing: border-box;
	/* iOS: volle Fläche unter Status/„Suchleiste“; sonst scheint die Page durch */
	padding-top: env(safe-area-inset-top, 0px);
}

/* Subnav ist immer hell (kein --dark Zustand) */

.site-sticky-bar.site-sticky-bar--light {
	background-color: var(--bg-warm);
}

/* Subnav ist immer hell: kein background switch */

body.nav-is-sticky .site-sticky-bar {
	pointer-events: auto;
	visibility: visible;
	opacity: 1;
	transform: translateY(0);
	transition:
		transform 0.38s cubic-bezier(0.22, 1, 0.36, 1),
		opacity 0.28s ease,
		visibility 0s linear 0s;
}

@media (prefers-reduced-motion: reduce) {
	.site-sticky-bar {
		transition: opacity 0.15s ease, visibility 0s linear 0.15s;
		transform: translateY(0);
		opacity: 0;
		visibility: hidden;
	}

	body.nav-is-sticky .site-sticky-bar {
		transition: opacity 0.15s ease, visibility 0s linear 0s;
		opacity: 1;
		visibility: visible;
	}
}

.site-sticky-bar__inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 0.65rem 1.25rem;
	width: 100%;
	max-width: var(--max);
	margin: 0 auto;
	padding: 0.3rem var(--page-pad);
	min-height: 2rem;
	box-sizing: border-box;
	background: var(--bg-warm);
	box-shadow: 0 1px 0 var(--fg);
	/* Wichtig: auf About (Body dunkel) sonst geerbtes white → Icon/Links unsichtbar */
	color: var(--fg);
}

.site-sticky-bar--dark .site-sticky-bar__inner {
	background: var(--black);
	color: var(--white);
	box-shadow: 0 1px 0 var(--white);
}

/*
 * Sticky + Mega (Desktop): gleiche Gitterlinien wie .site-nav--mega im Seitenkopf.
 * Logomark belegt Spalten 1–3; Nav-Cluster hängen per display:contents an derselben 12er-Zeile (4/7 · 7/11 · 11/–1).
 */
@media (min-width: 64.0625rem) {
	.site-sticky-bar__inner:has(> .site-nav--mega),
	.site-sticky-bar--mega .site-sticky-bar__inner {
		display: grid;
		grid-template-columns: repeat(var(--layout-grid-cols), minmax(0, 1fr));
		column-gap: var(--layout-grid-gap);
		align-items: center;
		row-gap: 0.35rem;
		flex-wrap: unset;
		justify-content: unset;
	}

	.site-sticky-bar__inner:has(> .site-nav--mega) .site-sticky-bar__brand,
	.site-sticky-bar--mega .site-sticky-bar__brand {
		grid-column: 1 / 4;
		justify-self: start;
		flex: unset;
	}

	.site-sticky-bar__inner:has(> .site-nav--mega) > .site-sticky-bar__nav.site-nav--mega,
	.site-sticky-bar--mega .site-sticky-bar__nav.site-nav--mega {
		grid-column: 1 / -1;
		display: contents;
	}
}

.site-sticky-bar__brand {
	display: block;
	flex: 0 0 auto;
	line-height: 0;
	text-decoration: none;
	border: 0;
}

.site-sticky-bar__logomark {
	display: block;
	width: 100%;
	height: 100%;
	max-height: 1.8rem;
	filter: none;
}

/* Dunkle Subnav: helles Logomark = Logomark-light.svg (Markup), kein CSS-Filter nötig */

.site-sticky-bar .site-sticky-bar__nav {
	margin-top: 0;
	min-width: 0;
}

.site-sticky-bar .site-sticky-bar__nav:not(.site-nav--mega) {
	flex: 1 1 0;
}

.site-sticky-bar--dark .site-sticky-bar__nav a {
	color: var(--white);
}

/* Mobile Sticky (≤64rem): Logomark + Drei-Strich-Icon (Proportionen ~ Triple-B-Logomark), Navigation klappt auf */
@media (max-width: 64rem) {
	.site-sticky-bar__inner {
		position: relative;
	}

	.site-sticky-bar__menu-toggle {
		display: none;
	}

	.site-sticky-bar__inner:has(> .site-nav--mega) .site-sticky-bar__menu-toggle,
	.site-sticky-bar--mega .site-sticky-bar__menu-toggle {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		flex: 0 0 auto;
		min-width: 2rem;
		min-height: 2rem;
		margin-left: auto;
		padding: 0;
		border: 0;
		background: transparent;
		cursor: pointer;
		color: inherit;
		-webkit-tap-highlight-color: transparent;
	}

	/* Drei Striche: --sticky-menu-line-w / --sticky-menu-line-h + Icon-Höhe für vertikalen Abstand */
	.site-sticky-bar__inner:has(> .site-nav--mega) .site-sticky-bar__menu-toggle-icon,
	.site-sticky-bar--mega .site-sticky-bar__menu-toggle-icon {
		--sticky-menu-line-w: 1.8rem;
		--sticky-menu-line-h: max(2px, 0.15em);
		position: relative;
		display: block;
		width: var(--sticky-menu-line-w);
		height: 0.8rem;
		flex: 0 0 auto;
	}

	.site-sticky-bar__inner:has(> .site-nav--mega) .site-sticky-bar__menu-toggle-line,
	.site-sticky-bar--mega .site-sticky-bar__menu-toggle-line {
		position: absolute;
		left: 0;
		display: block;
		width: var(--sticky-menu-line-w);
		height: var(--sticky-menu-line-h);
		margin: 0;
		padding: 0;
		background: currentColor;
		border-radius: 0;
		transform-origin: center;
		transition:
			transform 0.22s ease,
			opacity 0.18s ease,
			top 0.22s ease,
			bottom 0.22s ease;
	}

	.site-sticky-bar__inner:has(> .site-nav--mega) .site-sticky-bar__menu-toggle-line:nth-child(1),
	.site-sticky-bar--mega .site-sticky-bar__menu-toggle-line:nth-child(1) {
		top: 0;
	}

	.site-sticky-bar__inner:has(> .site-nav--mega) .site-sticky-bar__menu-toggle-line:nth-child(2),
	.site-sticky-bar--mega .site-sticky-bar__menu-toggle-line:nth-child(2) {
		top: 50%;
		transform: translateY(-50%);
	}

	.site-sticky-bar__inner:has(> .site-nav--mega) .site-sticky-bar__menu-toggle-line:nth-child(3),
	.site-sticky-bar--mega .site-sticky-bar__menu-toggle-line:nth-child(3) {
		bottom: 0;
	}

	.site-sticky-bar.is-menu-open .site-sticky-bar__menu-toggle-line:nth-child(1),
	.site-sticky-bar--mega.is-menu-open .site-sticky-bar__menu-toggle-line:nth-child(1) {
		top: 50%;
		transform: translateY(-50%) rotate(45deg);
	}

	.site-sticky-bar.is-menu-open .site-sticky-bar__menu-toggle-line:nth-child(2),
	.site-sticky-bar--mega.is-menu-open .site-sticky-bar__menu-toggle-line:nth-child(2) {
		opacity: 0;
	}

	.site-sticky-bar.is-menu-open .site-sticky-bar__menu-toggle-line:nth-child(3),
	.site-sticky-bar--mega.is-menu-open .site-sticky-bar__menu-toggle-line:nth-child(3) {
		bottom: auto;
		top: 50%;
		transform: translateY(-50%) rotate(-45deg);
	}

	@media (prefers-reduced-motion: reduce) {
		.site-sticky-bar__inner:has(> .site-nav--mega) .site-sticky-bar__menu-toggle-line,
		.site-sticky-bar--mega .site-sticky-bar__menu-toggle-line {
			transition: none;
		}

		.site-sticky-bar:not(.is-menu-open) .site-sticky-bar__nav.site-nav--mega,
		.site-sticky-bar.is-menu-open .site-sticky-bar__nav.site-nav--mega {
			transition-duration: 0.01ms !important;
		}
	}

	/*
	 * Mobile Mega-Liste: Panel hängt an top:100% der Subnav — Zuklappen nur per max-height/Padding
	 * (kein translateY nach oben: das wirkte wie „über“ die Leiste). Öffnen: nach unten aufklappen.
	 */
	.site-sticky-bar:not(.is-menu-open) .site-sticky-bar__nav.site-nav--mega {
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		width: auto;
		height: auto;
		margin: 0;
		padding: 0 var(--page-pad);
		max-height: 0;
		overflow: hidden;
		opacity: 0;
		visibility: hidden;
		transform: none;
		transform-origin: top center;
		pointer-events: none;
		clip: auto;
		white-space: normal;
		z-index: 2;
		background: var(--bg-warm);
		border-bottom: 1px solid transparent;
		transition:
			max-height 0.52s cubic-bezier(0.55, 0.06, 0.68, 1),
			padding 0.5s cubic-bezier(0.55, 0.06, 0.68, 1),
			opacity 0.16s ease-out 0.38s,
			visibility 0s linear 0.52s,
			border-bottom-color 0.28s ease,
			box-shadow 0.35s ease;
	}

	.site-sticky-bar--dark:not(.is-menu-open) .site-sticky-bar__nav.site-nav--mega {
		background: var(--black);
	}

	.site-sticky-bar.is-menu-open .site-sticky-bar__nav.site-nav--mega {
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		width: auto;
		height: auto;
		margin: 0;
		overflow: visible;
		max-height: min(92vh, 2000px);
		opacity: 1;
		visibility: visible;
		transform: none;
		transform-origin: top center;
		pointer-events: auto;
		z-index: 2;
		padding: 0.35rem var(--page-pad) 1rem;
		background: var(--bg-warm);
		border-bottom: 1px solid var(--fg);
		/* Öffnen: nach unten aufklappen (max-height + padding); Opacity kurz */
		transition:
			max-height 0.54s cubic-bezier(0.22, 0.75, 0.2, 1),
			opacity 0.2s cubic-bezier(0.2, 0.9, 0.35, 1),
			padding 0.5s cubic-bezier(0.2, 0.82, 0.18, 1),
			visibility 0s linear 0s,
			border-bottom-color 0.35s ease,
			box-shadow 0.45s ease;
	}

	.site-sticky-bar--dark.is-menu-open .site-sticky-bar__nav.site-nav--mega {
		background: var(--black);
		color: var(--white);
		box-shadow: 0 12px 32px rgba(0, 0, 0, 0.35);
		border-bottom-color: var(--white);
	}

	/*
	 * Fixleisten-Mega: immer vertikale Liste — auch während des Schließens, solange noch animiert wird.
	 * (Ohne das greifen die allgemeinen ≤64rem-Regeln: eine horizontale Linkzeile → gequetschter Bug.)
	 */
	.site-sticky-bar .site-sticky-bar__nav.site-nav--mega .site-nav__mega-panels {
		display: flex;
		flex-direction: column;
		width: 100%;
		align-items: stretch;
	}

	.site-sticky-bar .site-sticky-bar__nav.site-nav--mega .site-nav__mega-links {
		display: flex;
		flex-direction: column;
		align-items: stretch;
		gap: 0;
		flex-wrap: nowrap;
		width: 100%;
		max-width: none;
		min-width: 0;
	}

	.site-sticky-bar .site-sticky-bar__nav.site-nav--mega .site-nav__mega-links .site-nav__cluster {
		display: flex;
		flex-direction: column;
		align-items: stretch;
		gap: 0;
	}

	.site-sticky-bar .site-sticky-bar__nav.site-nav--mega .site-nav__mega-links a,
	.site-sticky-bar .site-sticky-bar__nav.site-nav--mega .site-nav__mega-links .site-nav__muted {
		flex: 0 0 auto;
		display: flex;
		justify-content: flex-start;
		text-align: left;
		min-height: 2.65rem;
		padding: 0.5rem 0;
		white-space: normal;
		overflow: visible;
		text-overflow: unset;
		border-bottom: 1px solid var(--fg);
		min-width: 0;
		max-width: none;
	}

	.site-sticky-bar--dark .site-sticky-bar__nav.site-nav--mega .site-nav__mega-links a,
	.site-sticky-bar--dark .site-sticky-bar__nav.site-nav--mega .site-nav__mega-links .site-nav__muted {
		border-bottom-color: var(--white);
	}

	/* Subnav bleibt hell: kein over-talents-dark Menü-Override */

	.site-sticky-bar .site-sticky-bar__nav.site-nav--mega .site-nav__mega-links .site-nav__cluster:last-child a:last-child {
		border-bottom: 0;
	}
}

@media (min-width: 64.0625rem) {
	.site-sticky-bar__menu-toggle {
		display: none !important;
	}
}

/* Keine doppelte Bedienung: Hauptnav im Seiten-Header aus, solange Fixleiste aktiv */
body.nav-is-sticky .site-header .site-nav,
body.nav-is-sticky .site-header .site-nav--mega {
	opacity: 0;
	pointer-events: none;
	visibility: hidden;
}

.page-home .site-header .logo-mega--svg {
	margin-bottom: 0;
}

/*
 * Home-Intro: gestaffelter Auszug — zuerst BERLIN, dann Video, zuletzt die Fläche nach unten.
 * Cases / .home-scroll (Talents+Footer) liegen immer im normalen Fluss darunter.
 */
.home-intro {
	/* Langsamer, weicher Auszug (organisches Ease-out) */
	--home-intro-exit-ease: cubic-bezier(0.26, 0.88, 0.18, 1);
	--home-intro-exit-berlin-delay: 0s;
	--home-intro-exit-berlin-duration: 0.95s;
	--home-intro-exit-video-delay: 0.32s;
	--home-intro-exit-video-duration: 0.95s;
	/* Panel mit leichtem Überlapp zur Video-Bewegung */
	--home-intro-exit-panel-delay: 0.78s;
	--home-intro-exit-panel-duration: 0.9s;

	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	top: var(--home-intro-top, 11rem);
	z-index: 15;
	display: flex;
	flex-direction: column;
	background: var(--bg-warm);
	overflow: hidden;
	transition: transform var(--home-intro-exit-panel-duration) var(--home-intro-exit-ease);
	transition-delay: 0s;
	will-change: transform;
	transform: translateY(0);
	pointer-events: auto;
}

.home-intro.home-intro--exiting {
	transform: translateY(100%);
	transition-delay: var(--home-intro-exit-panel-delay);
	will-change: transform;
}

.home-intro.home-intro--exiting .home-intro__logo--berlin {
	animation: none;
	opacity: 1;
	transform: translate3d(0, 120vh, 0);
	transition: transform var(--home-intro-exit-berlin-duration) cubic-bezier(0.22, 1, 0.36, 1);
	transition-delay: var(--home-intro-exit-berlin-delay);
	will-change: transform;
}

/*
 * Slide nur auf .home-intro__video-exit: isolation + warmer Hintergrund, damit mix-blend-mode: multiply
 * vor dem Transform in eine Ebene gerendert wird (sonst fällt Multiply bei transformiertem Vorfahren weg).
 */
.home-intro.home-intro--exiting .home-intro__video-exit {
	transform: translate3d(0, 120vh, 0);
	transition: transform var(--home-intro-exit-video-duration) var(--home-intro-exit-ease);
	transition-delay: var(--home-intro-exit-video-delay);
	will-change: transform;
}

.home-intro__inner {
	flex: 1;
	display: flex;
	flex-direction: column;
	width: 100%;
	max-width: var(--max);
	margin: 0 auto;
	min-height: 0;
	padding: var(--space) var(--page-pad) var(--space);
}

.home-intro__middle {
	flex: 1 1 auto;
	display: grid;
	grid-template-columns: minmax(0, 1.15fr) auto minmax(0, 1.15fr);
	grid-template-areas: "intro video spacer";
	gap: 2rem;
	align-items: center;
	min-height: 0;
	width: 100%;
}

.home__intro__typewriter .home__intro__typewriter-text {
	display: inline;
	white-space: pre-line;
	text-wrap: pretty;
}

.home__intro__typewriter.is-typing::after {
	content: "";
	display: inline-block;
	width: 0.07em;
	height: 1.05em;
	margin-left: 0.06em;
	background: currentColor;
	vertical-align: -0.12em;
	animation: home-intro-caret 0.95s steps(1, end) infinite;
}

.home__intro__typewriter.is-typewriter-done::after {
	display: none;
}

@keyframes home-intro-caret {
	0%,
	49% {
		opacity: 1;
	}
	50%,
	100% {
		opacity: 0;
	}
}

.home-intro__emblem {
	grid-area: video;
	justify-self: center;
	align-self: center;
	width: auto;
	max-width: 100%;
	min-width: 0;
	min-height: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: visible;
}

.home-intro__middle-spacer {
	grid-area: spacer;
}

/* Nur Video, zentriert */
.home-intro__middle--video-only {
	display: flex;
	justify-content: center;
	align-items: center;
}

/* Eigenes Compositing für Multiply + Exit-Transform (s. .home-intro--exiting .home-intro__video-exit) */
.home-intro__video-exit {
	flex: 1 1 auto;
	display: flex;
	align-items: center;
	justify-content: center;
	min-width: 0;
	min-height: 0;
	width: 100%;
	background-color: var(--bg-warm);
	isolation: isolate;
}

@media (max-width: 52rem) {
	.home-intro__middle:not(.home-intro__middle--video-only) {
		grid-template-columns: 1fr;
		grid-template-areas:
			"intro"
			"video"
			"spacer";
		justify-items: start;
	}

	.home-intro__middle:not(.home-intro__middle--video-only) .home-intro__emblem {
		justify-self: center;
		width: 100%;
		max-width: 100%;
	}

	.home-intro__middle:not(.home-intro__middle--video-only) .home-intro__middle-spacer {
		display: none;
	}
}

.home-intro__logo--berlin {
	display: block;
	width: 100%;
	height: auto;
	transform-origin: center top;
	margin-top: auto;
	opacity: 1;
	transform: none;
	filter: none;
}

/* Intro-Video: multiply gegen warmen Untergrund (Shell + video-exit), ohne Schatten/Maske/Rahmen */
.home-intro__b-shell {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	max-width: min(calc(96vw * 0.56), 28rem);
	margin: 0 auto;
	overflow: hidden;
	padding: 0;
	background-color: var(--bg-warm);
}

/*
 * cover statt contain: bei contain + mix-blend-mode zeichnet Safari oft oben/unten (Letterboxing)
 * einen anderen Grau-Ton als --bg-warm — wirkt wie ein Rahmen. cover füllt die Box, leichte Cropping am Logo-Rand möglich.
 */
.home-intro__b-video {
	display: block;
	pointer-events: none;
	border: 0;
	border-radius: 0;
	outline: none;
	background-color: var(--bg-warm);
	box-shadow: none;
	object-fit: cover;
	object-position: center;
	width: min(calc(94vw * 0.56), calc(46rem * 0.56));
	height: min(calc(60vh * 0.56), calc(34rem * 0.56));
	max-width: 100%;
	mix-blend-mode: multiply;
}

/*
 * Schmal: kein cover (zu viel Crop). height:auto + max-height → Box folgt dem Video, kein Letterboxing
 * wie bei fester Höhe + contain; multiply wie Desktop bleibt möglich.
 */
@media (max-width: 52rem) {
	.home-intro__b-shell {
		max-width: min(92vw, 28rem);
	}

	.home-intro__b-video {
		object-fit: contain;
		width: min(82vw, 100%);
		height: auto;
		max-height: min(46vh, 58vw);
		max-width: 100%;
		mix-blend-mode: multiply;
		background-color: var(--bg-warm);
	}
}

/* Kein Scroll unter dem Intro (ergänzend zu JS-Klasse html.home-intro-active) */
html.home-intro-active {
	overflow: hidden;
	height: 100%;
	overscroll-behavior: none;
}

html.home-intro-active body {
	overflow: hidden;
	overscroll-behavior: none;
}

/*
 * Rasterbilder — Ladezustand (JS: .bianco-img--track / --loading / --error).
 * data-bianco-no-load-shim am <img> oder .bianco-img--exclude: auslassen.
 */
@keyframes bianco-img-load-pulse {
	0%,
	100% {
		opacity: 1;
	}
	50% {
		opacity: 0.86;
	}
}

img.bianco-img--track {
	background-color: rgba(120, 122, 128, 0.14);
}

img.bianco-img--loading {
	animation: bianco-img-load-pulse 1.1s ease-in-out infinite;
}

img.bianco-img--error {
	animation: none;
	opacity: 1;
	background-color: rgba(120, 122, 128, 0.22);
}

@media (prefers-reduced-motion: reduce) {
	img.bianco-img--loading {
		animation: none;
	}
}
