/* 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: .site-footer padding-bottom (--site-footer-pad-bottom + optional --site-cookie-notice-height).
 */
.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;
}

/* Kein Seiten-Enter auf <main> (keine Load-Animation / kein transform — ruhig, gut mit Home-Intro). */
main#page-main {
	animation: none;
	opacity: 1;
	transform: none;
}

/*
 * 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-nav--mega a[aria-current="page"],
body.page-home.home--over-talents-dark .site-header .site-nav--mega a[aria-current="page"]:hover,
body.page-home.home--over-talents-dark .site-header .site-nav--mega a[aria-current="page"]:focus,
body.page-home.home--focus-talents .site-header .site-nav--mega a[aria-current="page"],
body.page-home.home--focus-talents .site-header .site-nav--mega a[aria-current="page"]:hover,
body.page-home.home--focus-talents .site-header .site-nav--mega a[aria-current="page"]:focus {
	color: var(--accent);
	border-bottom: none;
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.2em;
}

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).
   Case/Talent: <main>…\n<section> — Whitespace ist oft erstes Kind, :first-child trifft .hero-dark dann nicht;
   Breakout explizit über section.project-hero-section. */
.page-wrapper > .hero-dark:first-child,
.page-wrapper > main.page-detail > section.project-hero-section.hero-dark {
	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;
	/* Kein Browser-Standard-Weiß in Subpixel-Lücken (transform / Compositing) */
	background-color: var(--bg);
}

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;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/* 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,
	.home-opener {
		display: none !important;
	}

	/* ?homeOpenerStatic=1: Opener + Intro sichtbar halten; Micro-Transitions aus globaler *-Regel aushebeln */
	html.home-opener-static-preview .home-intro,
	html.home-opener-static-preview .home-intro *,
	html.home-opener-static-preview .home-opener,
	html.home-opener-static-preview .home-opener * {
		animation: none !important;
		animation-duration: 0s !important;
		transition: none !important;
		transition-duration: 0s !important;
	}

	html.home-opener-static-preview .home-intro,
	html.home-opener-static-preview .home-opener {
		display: flex !important;
		opacity: 1 !important;
		visibility: visible !important;
		pointer-events: none !important;
	}

	/* ?homeIntroStatic=1: nur Intro; Opener aus; Micro-Transitions aus globaler *-Regel aushebeln */
	html.home-intro-static-preview .home-intro,
	html.home-intro-static-preview .home-intro * {
		animation: none !important;
		animation-duration: 0s !important;
		transition: none !important;
		transition-duration: 0s !important;
	}

	html.home-intro-static-preview .home-intro {
		display: flex !important;
		opacity: 1 !important;
		visibility: visible !important;
		pointer-events: none !important;
	}

	html.home-intro-static-preview .home-opener {
		display: none !important;
	}

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

	html.home-opener-static-preview body:is(.page-home, .page-service, .page-jobs) .home-scroll,
	html.home-intro-static-preview body:is(.page-home, .page-service, .page-jobs) .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 var(--duration-micro) ease, color var(--duration-micro) 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:not(.home-opener__mark) {
	transform: none;
}

.logo-mega--svg {
	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;
}

/* Aktuelle Seite — gleicher Akzent wie .list-mega */
.site-header .site-nav--mega a[aria-current="page"],
.site-nav--mega a[aria-current="page"],
.site-sticky-bar .site-nav--mega a[aria-current="page"] {
	color: var(--accent);
	border-bottom: none;
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.2em;
	transition:
		color var(--duration-ui-tight) var(--ease-out-ui),
		opacity var(--duration-ui-tight) var(--ease-out-ui);
}

/*
 * Home: „Cases“ hat aria-current schon auf der Startseite — optisch erst, wenn #home-intro entfernt ist
 * (intro-done setzt reveal() früh; :has(#home-intro) deckt Vorhang + Exit ab).
 */
body.page-home.has-home-intro:has(#home-intro) .site-header .site-nav--mega a[aria-current="page"],
body.page-home.has-home-intro:has(#home-intro) .site-header .site-nav--mega a[aria-current="page"]:hover,
body.page-home.has-home-intro:has(#home-intro) .site-header .site-nav--mega a[aria-current="page"]:focus,
body.page-home.has-home-intro:has(#home-intro) .site-sticky-bar .site-nav--mega a[aria-current="page"],
body.page-home.has-home-intro:has(#home-intro) .site-sticky-bar .site-nav--mega a[aria-current="page"]:hover,
body.page-home.has-home-intro:has(#home-intro) .site-sticky-bar .site-nav--mega a[aria-current="page"]:focus {
	color: inherit;
	text-decoration: none;
}

/* Mega-Nav aus, solange der Home-Intro-Vorhang (#home-intro) im DOM ist */
body.page-home.has-home-intro:has(#home-intro) .site-header .site-nav--mega,
body.page-home.has-home-intro:has(#home-intro) .site-sticky-bar .site-nav--mega {
	opacity: 0;
	pointer-events: none;
	visibility: hidden;
}

/* Header-Wordmark aus solange #home-intro im DOM (BIANCO nur im Intro) */
body.page-home.has-home-intro:has(#home-intro) .site-header .site-header__brand.logo-mega--svg {
	visibility: hidden;
	pointer-events: none;
}

.site-sticky-bar--dark .site-nav--mega a[aria-current="page"] {
	color: var(--accent);
}

/*
 * Tablet / mobile (≤64rem): Fixleiste = Logomark + Menü-Toggle / aufgeklappte Nav.
 * Mega-Nav im Seitenkopf ausgeblendet; Fixleiste per JS sofort sichtbar (nicht erst 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),
	.site-sticky-bar--mega .site-sticky-bar__inner {
		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,
	.site-sticky-bar--mega .site-sticky-bar__brand {
		grid-column: unset;
		justify-self: unset;
		flex: 0 0 auto;
		align-self: center;
		position: relative;
		z-index: 2;
	}

	.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 {
		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,
	.site-sticky-bar--mega .site-nav__mega-panels {
		min-width: 0;
	}

	/* Seitenkopf: nur Wortmarke — Mega-Nav nur in der Fixleiste (Mobile: sofort sichtbar) */
	.site-header:has(> .site-nav--mega),
	.site-header--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,
	.site-header--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,
	.site-header--mega > .site-header__brand .site-header__wordmark {
		width: 100%;
		max-width: none;
	}

	.site-header:has(> .site-nav--mega) > .site-nav--mega,
	.site-header--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 var(--duration-ui-tight) ease, background var(--duration-ui) var(--ease-out-ui),
		color var(--duration-ui) var(--ease-out-ui);
}

/*
 * ?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-Klasse page-home--focus-talents (home.php) — Canvas/Gutter in Chrome/Brave zuverlässig schwarz.
 */
html.page-home--focus-talents {
	background-color: var(--black);
	min-height: 100%;
}

/*
 * 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);
}

/* Scroll-Gutter / Canvas: sonst kann helles html durchscheinen, wenn Body schon „over talents dark“ ist */
html:has(body.page-home.home--over-talents-dark) {
	background-color: var(--black);
}

body.page-home.home--focus-talents {
	background-color: var(--black);
	min-height: 100vh;
	min-height: 100dvh;
}

/* Volle schwarze Fläche im Wrapper (Padding/Gutter), sonst 1px-Anteiligkeit an hellen Tokens */
body.page-home.home--focus-talents .page-wrapper,
body.page-home.home--over-talents-dark .page-wrapper {
	background-color: var(--black);
}

/* Kompaktleiste: Safe-Area über der inneren Zeile ebenfalls schwarz (sonst transparent → GPU-Hairline) */
body.page-home.home--focus-talents .site-sticky-bar,
body.page-home.home--over-talents-dark .site-sticky-bar {
	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 .page-wrapper > .home-scroll.home-scroll--footer-light {
	background: var(--bg-warm);
	color: var(--fg);
	/* Abstand zu #cases: nicht über .site-footer margin-top (transparent → schwarzer Body schimmert durch). */
	padding-top: 4rem;
}

body.page-home.home--focus-talents .page-wrapper > .home-scroll.home-scroll--footer-light > .site-footer {
	margin-top: 0;
}

/* 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;
	box-shadow: none;
	border-bottom: 0;
}

/* 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 var(--duration-ui) var(--ease-out-ui),
		opacity 0.28s ease,
		visibility 0s linear var(--duration-ui);
	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) */

/* Äußere Sticky-Leiste: --light setzt sonst warmen Hintergrund (Spezifität sicher unter html.page-home--focus-talents) */
html.page-home--focus-talents .site-sticky-bar.site-sticky-bar--light {
	background-color: var(--black);
}

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

.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 var(--duration-ui) var(--ease-out-ui),
		opacity 0.28s ease,
		visibility 0s linear 0s;
}

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

	body.nav-is-sticky .site-sticky-bar {
		transition: opacity var(--duration-micro) 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: none;
}

/* Home + dunkles Talents-Band: keine 1px-Linie unter der Subnav (auch vor nav-is-sticky / Chromium-Composite) */
body.page-home.home--over-talents-dark .site-sticky-bar .site-sticky-bar__inner,
body.page-home.home--focus-talents .site-sticky-bar .site-sticky-bar__inner {
	box-shadow: none;
}
/*
 * 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;
	min-height: 1.8rem;
}

.site-sticky-bar__logomark {
	display: block;
	width: auto;
	height: 1.8rem;
	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: 2.75rem;
		min-height: 2.75rem;
		margin-left: auto;
		padding: 0;
		border: 0;
		background: transparent;
		cursor: pointer;
		color: inherit;
		position: relative;
		z-index: 2;
		-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(1px, 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 var(--duration-ui-tight) ease,
			opacity 0.18s ease,
			top var(--duration-ui-tight) ease,
			bottom var(--duration-ui-tight) 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 var(--duration-structural) var(--ease-panel-collapse),
			padding var(--duration-structural) var(--ease-panel-collapse),
			opacity 0.16s ease-out var(--duration-ui),
			visibility 0s linear var(--duration-structural),
			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 var(--duration-panel-open) var(--ease-panel-open),
			opacity 0.2s var(--ease-aux-fade),
			padding var(--duration-structural) var(--ease-out-soft),
			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 opener (v1): vor Home-Intro — BIANCO oben, BERLIN unten; .home-opener__inner wächst in max-height.
 */
.home-opener {
	--home-opener-pre-slide-hold: 0.6s;
	--home-opener-slide-duration: 0.72s;
	--home-opener-pre-slide-gap: 2rem;
	--home-opener-inner-max-start: calc(
		var(--home-opener-pre-slide-gap) + 0.35rem + (266 / 1881) * min(100vw - 2 * var(--page-pad), var(--max))
	);

	position: fixed;
	inset: 0;
	z-index: 210;
	display: flex;
	flex-direction: column;
	align-items: stretch;
	justify-content: center;
	box-sizing: border-box;
	padding: var(--page-pad) var(--page-pad) var(--page-pad);
	background: transparent;
	overflow: hidden;
	opacity: 1;
	pointer-events: none;
}

body.intro-done #home-opener {
	display: none !important;
	visibility: hidden !important;
	pointer-events: none !important;
}

html.home-opener-static-preview body.intro-done #home-opener,
html.home-opener-static-preview .home-opener {
	display: flex !important;
	visibility: visible !important;
	opacity: 1 !important;
}

html.home-intro-static-preview .home-opener {
	display: none !important;
}

.home-opener__inner {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	justify-content: center;
	flex: 1 1 auto;
	width: 100%;
	max-width: var(--max);
	margin: 0 auto;
	min-height: 0;
	box-sizing: border-box;
	overflow: hidden;
}

.home-opener__stack {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	justify-content: space-between;
	flex: 1 1 0;
	width: 100%;
	box-sizing: border-box;
	min-height: 0;
	gap: var(--home-opener-pre-slide-gap);
	row-gap: var(--home-opener-pre-slide-gap);
}

.home-opener .home-opener__mark.logo-mega {
	transform: translateZ(0);
}

@-webkit-keyframes home-opener-inner-grow {
	from {
		max-height: var(--home-opener-inner-max-start);
	}
	to {
		max-height: 100%;
	}
}

@keyframes home-opener-inner-grow {
	from {
		max-height: var(--home-opener-inner-max-start);
	}
	to {
		max-height: 100%;
	}
}

.home-opener__mark {
	width: 100%;
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	transform: translate3d(0, 0, 0);
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}

.home-opener__wordmark {
	display: block;
	width: 100%;
	height: auto;
}

@media (prefers-reduced-motion: no-preference) {
	.home-opener__inner {
		max-height: var(--home-opener-inner-max-start);
		-webkit-animation: home-opener-inner-grow var(--home-opener-slide-duration) var(--ease-out-ui)
			var(--home-opener-pre-slide-hold) forwards;
		animation: home-opener-inner-grow var(--home-opener-slide-duration) var(--ease-out-ui)
			var(--home-opener-pre-slide-hold) forwards;
	}
}

@media (prefers-reduced-motion: reduce) and (min-width: 52.0625rem) {
	.home-opener__inner {
		max-height: none;
		overflow: visible;
	}

	.home-opener__stack {
		flex: 1 1 0;
		justify-content: space-between;
		gap: var(--home-opener-pre-slide-gap);
		row-gap: var(--home-opener-pre-slide-gap);
		min-height: 0;
	}
}

@media (prefers-reduced-motion: reduce) and (max-width: 52rem) {
	.home-opener__inner {
		max-height: none;
		overflow: visible;
	}

	.home-opener__stack {
		gap: max(1.25rem, 3.25vw);
		row-gap: max(1.25rem, 3.25vw);
	}
}

html.home-opener-static-preview .home-opener .home-opener__inner {
	-webkit-animation: none !important;
	animation: none !important;
	max-height: none !important;
	overflow: visible !important;
}

html.home-opener-static-preview .home-opener .home-opener__stack {
	flex: 1 1 0 !important;
	justify-content: space-between !important;
	gap: var(--home-opener-pre-slide-gap) !important;
	row-gap: var(--home-opener-pre-slide-gap) !important;
}

@media (max-width: 52rem) {
	html.home-opener-static-preview .home-opener .home-opener__stack {
		gap: max(1.25rem, 3.25vw) !important;
		row-gap: max(1.25rem, 3.25vw) !important;
	}
}

/*
 * Opener-Sync: Intro-Video sichtbar in der Mitte; Intro-Marks unsichtbar (kein Flex-Collapse → kein Blink beim Handoff).
 */
.home-intro.home-intro--opener-sync {
	background: transparent;
	pointer-events: none;
}

.home-intro.home-intro--opener-sync .home-intro__bianco-bar,
.home-intro.home-intro--opener-sync .home-intro__logo--berlin {
	position: absolute;
	width: 1px;
	height: 1px;
	margin: 0;
	padding: 0;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	clip-path: inset(50%);
	white-space: nowrap;
	border: 0;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
}

.home-intro.home-intro--opener-sync .home-intro__inner {
	position: relative;
	flex: 1;
	min-height: 0;
}

.home-intro.home-intro--opener-sync .home-intro__curtain {
	flex: 1 1 auto;
	min-height: 0;
}

.home-intro.home-intro--opener-sync:not(.home-intro--video-reveal) .home-intro__b-video {
	opacity: 0;
	-webkit-transition: opacity var(--home-opener-slide-duration) var(--ease-out-ui);
	transition: opacity var(--home-opener-slide-duration) var(--ease-out-ui);
}

.home-intro.home-intro--video-reveal .home-intro__b-video {
	opacity: 1;
}

/*
 * Home-Intro v1 (baseline): BIANCO oben; warmes Panel + Video; BERLIN unten.
 * Exit: Phase 1 Video-Opacity → Phase 2 BERLIN → intro.remove.
 */
.home-intro {
	--home-intro-exit-ease: var(--ease-home-intro);
	--home-intro-exit-panel-delay: 0.06s;
	--home-intro-exit-panel-duration: 0.55s;

	position: fixed;
	inset: 0;
	z-index: 200;
	display: flex;
	flex-direction: column;
	background: var(--bg-warm);
	overflow: hidden;
	opacity: 1;
	pointer-events: auto;
}

.home-intro.home-intro--exiting {
	pointer-events: none;
}

/* ≤52rem: Intro-Exit ohne Phasen-Transition (JS: .home-intro--hard-cut → sofort remove) */
@media (max-width: 52rem) {
	.home-intro.home-intro--hard-cut,
	.home-intro.home-intro--hard-cut * {
		-webkit-animation: none !important;
		animation: none !important;
		-webkit-transition: none !important;
		transition: none !important;
	}
}

/* Warmes Panel nur für Video-Multiply; kein Slide */
.home-intro__curtain {
	flex: 1 1 auto;
	display: flex;
	flex-direction: column;
	min-height: 0;
	width: 100%;
	background-color: var(--bg-warm);
	isolation: isolate;
}

.home-intro.home-intro--exiting.home-intro--exit-phase-1 .home-intro__b-shell:not(.home-intro__b-shell--gif-fallback) .home-intro__b-video {
	opacity: 0;
	-webkit-transition:
		opacity var(--home-intro-exit-panel-duration) var(--home-intro-exit-ease)
		var(--home-intro-exit-panel-delay);
	transition:
		opacity var(--home-intro-exit-panel-duration) var(--home-intro-exit-ease)
		var(--home-intro-exit-panel-delay);
}

.home-intro.home-intro--exiting.home-intro--exit-phase-1 .home-intro__b-shell.home-intro__b-shell--gif-fallback .home-intro__b-fallback {
	opacity: 0;
	-webkit-transition:
		opacity var(--home-intro-exit-panel-duration) var(--home-intro-exit-ease)
		var(--home-intro-exit-panel-delay);
	transition:
		opacity var(--home-intro-exit-panel-duration) var(--home-intro-exit-ease)
		var(--home-intro-exit-panel-delay);
}

.home-intro.home-intro--exiting.home-intro--exit-phase-2 .home-intro__logo--berlin {
	animation: none;
	transform: translate3d(0, calc(100% + 2.5rem), 0);
	-webkit-transition:
		transform var(--home-intro-exit-panel-duration) var(--home-intro-exit-ease)
		var(--home-intro-exit-panel-delay);
	transition:
		transform var(--home-intro-exit-panel-duration) var(--home-intro-exit-ease)
		var(--home-intro-exit-panel-delay);
	will-change: transform;
}

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

/* Fluss: BIANCO → Video → BERLIN (BIANCO im Flex, nicht absolut — sonst liegt das Panel unter dem Schriftzug) */
.home-intro__video-stack {
	position: relative;
	flex: 1 1 auto;
	display: flex;
	flex-direction: column;
	min-height: 0;
	width: 100%;
}

.home-intro__video-stack > .home-intro__middle {
	flex: 1 1 auto;
	min-height: 0;
	width: 100%;
}

/* BIANCO: volle Viewport-Breite wie BERLIN; im Flex oberhalb des Video-Panels (kein Überlagern) */
.home-intro__bianco-bar {
	position: relative;
	flex-shrink: 0;
	width: 100vw;
	max-width: none;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	margin-top: 0;
	margin-bottom: 0;
	padding-left: max(var(--page-pad), env(safe-area-inset-left, 0px));
	padding-right: max(var(--page-pad), env(safe-area-inset-right, 0px));
	padding-top: 0;
	padding-bottom: 0;
	box-sizing: border-box;
	z-index: 2;
	pointer-events: none;
	border: 0;
	opacity: 1;
}

.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: block;
	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 — min-height stabilisiert die Fläche; volle Viewport-Breite für optische Zentrierung. */
.home-intro__middle--video-only {
	display: flex;
	justify-content: center;
	align-items: center;
	min-height: clamp(12rem, 38vmin, 26rem);
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	padding-left: max(var(--page-pad), env(safe-area-inset-left, 0px));
	padding-right: max(var(--page-pad), env(safe-area-inset-right, 0px));
	box-sizing: border-box;
}

/* Eigenes Compositing für multiply am Video (warmes Panel) */
.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;
	/* Ausgangsmatrix für Transition — vermeidet Sprung von „transform: none“ → translate3d beim Exit. */
	transform: translate3d(0, 0, 0);
}

@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;
	box-sizing: border-box;
	width: 100vw;
	max-width: none;
	height: auto;
	margin-top: auto;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	padding-left: max(var(--page-pad), env(safe-area-inset-left, 0px));
	padding-right: max(var(--page-pad), env(safe-area-inset-right, 0px));
	transform-origin: center top;
	opacity: 1;
	transform: translate3d(0, 0, 0);
	transition: none;
	filter: none;
}

/*
 * Intro-Medien: multiply gegen warmes Panel (Shell + .home-intro__video-exit).
 * Warme Shell wieder hinter Video: transparenter Shell brach auf manchen Mobile-WebKits multiply+decode.
 */
.home-intro__b-shell {
	position: relative;
	display: grid;
	place-items: center;
	width: 100%;
	max-width: min(calc(96vw * 0.56), 28rem);
	margin: 0 auto;
	overflow: hidden;
	padding: 0;
	background-color: var(--bg-warm);
}

.home-intro__b-shell > .home-intro__b-video,
.home-intro__b-shell > .home-intro__b-fallback {
	grid-area: 1 / 1;
	max-width: 100%;
}

/*
 * 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,
.home-intro__b-fallback {
	pointer-events: none;
	border: 0;
	border-radius: 0;
	outline: none;
	background-color: transparent;
	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;
	transition: none;
	/* Eigenes Compositing: in manchen Chromium-Builds (inkl. Brave) sonst multiply+Video unsichtbar */
	transform: translate3d(0, 0, 0);
	backface-visibility: hidden;
	-webkit-backface-visibility: hidden;
	-webkit-user-select: none;
	-moz-user-select: none;
	user-select: none;
	-webkit-user-drag: none;
	-webkit-touch-callout: none;
}

/*
 * Video erst bei playback sichtbar: WebKit/iOS zeigen sonst kurz den nativen Play-Overlay, solange kein Frame läuft.
 * Exit Phase 1 überschreibt opacity mit höherer Spezifität.
 */
.home-intro__b-video {
	display: block;
	opacity: 0;
	transition: opacity 0.14s ease-out;
}

.home-intro__b-video.home-intro__b-video--playing {
	opacity: 1;
}

/*
 * Touch / schmale Viewports: kein Opacity-Gate bis „playing“ (außer während Opener-Sync + video-reveal).
 * iOS/WebKit liefert oft keine Frames / kein zuverlässiges timeupdate bei opacity:0 → Watchdog fällt auf GIF, Video „tot“.
 * Kein display:none auf -webkit-media-controls-enclosure — bricht Inline-Playback auf iOS.
 */
@media (pointer: coarse), (max-width: 52rem) {
	.home-intro__b-video {
		opacity: 1;
	}

	.home-intro.home-intro--opener-sync:not(.home-intro--video-reveal) .home-intro__b-video {
		opacity: 0;
		-webkit-transition: opacity var(--home-opener-slide-duration) var(--ease-out-ui);
		transition: opacity var(--home-opener-slide-duration) var(--ease-out-ui);
	}

	.home-intro.home-intro--video-reveal .home-intro__b-video {
		opacity: 1;
	}
}

.home-intro__b-fallback {
	display: none;
}

.home-intro__b-shell--gif-fallback .home-intro__b-video {
	display: none;
}

/*
 * GIF-Fallback: Theme-Off-Weiß (--white) als „Papier“, multiply zieht GIF-Weiß darauf (ohne Filter).
 * Video bleibt auf warmem Panel (Regeln oben); :has ersetzt kein JS.
 */
#home-intro:has(.home-intro__b-shell--gif-fallback) {
	background: var(--white);
}

#home-intro:has(.home-intro__b-shell--gif-fallback) .home-intro__curtain,
#home-intro:has(.home-intro__b-shell--gif-fallback) .home-intro__video-exit {
	background-color: var(--white);
}

.home-intro__b-shell--gif-fallback {
	background-color: var(--white);
}

.home-intro__b-shell--gif-fallback .home-intro__b-fallback {
	display: block;
	mix-blend-mode: multiply;
	background-color: var(--white);
}

/*
 * 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,
	.home-intro__b-fallback {
		object-fit: contain;
		width: min(82vw, 100%);
		height: auto;
		max-height: min(46vh, 58vw);
		max-width: 100%;
		mix-blend-mode: multiply;
		background-color: transparent;
		transform: translate3d(0, 0, 0);
		backface-visibility: hidden;
		-webkit-backface-visibility: hidden;
	}
}

/* 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;
	background-color: var(--bg-warm);
}

/*
 * Rasterbilder — Ladezustand (JS: .bianco-img--track / --loading / --error).
 * Sanftes Einblenden: leichtes Dim während .bianco-img--loading, dann transition → 1
 * data-bianco-no-load-shim am <img> oder .bianco-img--exclude: auslassen.
 */
img.bianco-img--track {
	/* sichtbarer, hellgrauer Ersatz hinter object-fit, bis decodiert */
	background-color: rgba(120, 122, 128, 0.2);
	transition: opacity var(--duration-ui-md) ease;
}

img.bianco-img--track.bianco-img--loading {
	opacity: 0.72;
}

img.bianco-img--track:not(.bianco-img--loading):not(.bianco-img--error) {
	opacity: 1;
}

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

@media (prefers-reduced-motion: reduce) {
	img.bianco-img--track {
		transition: opacity 0.05s ease;
	}
}
