/* 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 (max(page-pad, safe-area) wie Header oben).
 */
.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);
	padding-bottom: var(--home-intro-nav-gap);
	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-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.4rem 0.08rem;
		min-height: 2.75rem;
		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)));
	padding-bottom: var(--home-intro-nav-gap);
	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: .page-home .site-header steht später in der Datei und hat sonst Vorrang (warmes Grau).
 * Außerdem: .page-wrapper padding-top erzeugt oben einen hellen Streifen vor .home__masthead — weglassen
 * und Oberabstand nur im Header (page-pad + safe-area).
 */
body.page-home.home--focus-talents .page-wrapper {
	padding-top: 0;
}

/*
 * Seitliche „Ränder“: .page-wrapper hat padding-left/right — die Fläche ist transparent,
 * darunter liegt body (hell). Gleiche Logik wie oben: Canvas schwarz wie Talents/Header.
 */
html:has(body.page-home.home--focus-talents) {
	background-color: var(--black);
}

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

/* Cases unter Talents: eigener heller Grund — sonst erbt Fließtext body (--fg) auf schwarz */
body.page-home.home--focus-talents #cases.home__cases.section {
	background-color: 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;
}

/* focus=talents: kein Wrapper-Ober-Pad mehr — Safe-Area + Raster hier im Header */
body.page-home.home--focus-talents .site-header {
	padding-top: max(var(--page-pad), env(safe-area-inset-top, 0px));
}

/* 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.5rem var(--page-pad);
	padding-bottom: 0.55rem;
	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: auto;
	height: clamp(1.1rem, 2.6vw, 1.45rem);
	max-width: 4.75rem;
	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): nur Logomark + Zwei-Strich-Icon, 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: 2.75rem;
		min-height: 2.75rem;
		margin-left: auto;
		padding: 0;
		border: 0;
		background: transparent;
		cursor: pointer;
		color: inherit;
		-webkit-tap-highlight-color: transparent;
	}

	.site-sticky-bar__inner:has(> .site-nav--mega) .site-sticky-bar__menu-toggle-icon,
	.site-sticky-bar--mega .site-sticky-bar__menu-toggle-icon {
		display: flex;
		flex-direction: column;
		align-items: stretch;
		gap: 6px;
	}

	.site-sticky-bar__inner:has(> .site-nav--mega) .site-sticky-bar__menu-toggle-line,
	.site-sticky-bar--mega .site-sticky-bar__menu-toggle-line {
		display: block;
		width: 2.25rem;
		height: 2px;
		flex: 0 0 auto;
		background: currentColor;
		border-radius: 0;
	}

	.site-sticky-bar:not(.is-menu-open) .site-sticky-bar__nav.site-nav--mega {
		position: absolute;
		width: 1px;
		height: 1px;
		padding: 0;
		margin: -1px;
		overflow: hidden;
		clip: rect(0, 0, 0, 0);
		white-space: nowrap;
		border: 0;
		pointer-events: none;
	}

	.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;
		clip: auto;
		white-space: normal;
		pointer-events: auto;
		z-index: 2;
		padding: 0.35rem var(--page-pad) 1rem;
		background: var(--bg-warm);
		border-bottom: 1px solid var(--fg);
	}

	.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);
	}

	.site-sticky-bar.is-menu-open .site-sticky-bar__nav .site-nav__mega-panels {
		display: flex;
		flex-direction: column;
		width: 100%;
		align-items: stretch;
	}

	.site-sticky-bar.is-menu-open .site-sticky-bar__nav .site-nav__mega-links {
		display: flex;
		flex-direction: column;
		align-items: stretch;
		gap: 0;
		flex-wrap: nowrap;
	}

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

	.site-sticky-bar.is-menu-open .site-sticky-bar__nav .site-nav__mega-links a,
	.site-sticky-bar.is-menu-open .site-sticky-bar__nav .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);
	}

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

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

	.site-sticky-bar.is-menu-open .site-sticky-bar__nav .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: nur diese Schicht ist fixed und slidet nach unten weg.
 * Cases / .home-scroll (Talents+Footer) liegen immer im normalen Fluss darunter — kein zweites Transform,
 * kein Zustandschaos mit body.intro-reveal.
 */
.home-intro {
	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 0.88s cubic-bezier(0.22, 1, 0.36, 1);
	will-change: transform;
	transform: translateY(0);
	pointer-events: auto;
}

.home-intro.home-intro--exiting {
	transform: translateY(100%);
	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;
}

@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: 0;
	animation: intro-city-in 1s cubic-bezier(0.22, 1, 0.36, 1) 0.38s forwards;
}

@keyframes intro-city-in {
	from {
		opacity: 0;
		transform: translateY(-0.2em);
		filter: blur(4px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
		filter: blur(0);
	}
}

/* Intro-Video: multiply gegen Intro-Hintergrund, ohne Schatten/Maske/Rahmen */
.home-intro__b-shell {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	max-width: min(96vw, 50rem);
	margin: 0 auto;
	overflow: visible;
	padding: 1rem 0;
}

.home-intro__b-video {
	display: block;
	pointer-events: none;
	border: 0;
	border-radius: 0;
	outline: none;
	background: transparent;
	box-shadow: none;
	object-fit: contain;
	width: auto;
	height: min(60vh, 34rem);
	max-width: min(94vw, 46rem);
	mix-blend-mode: multiply;
}
