/* ============================================================
   Leukos Master — components.css
   Sektionen, Header, Footer, FAQ, Slider, POI-Map.
   ============================================================ */

/* -------- Top-Bar -------- */
.leukos-topbar { background: var(--text); color: #fff; font-size: .8rem; }
.leukos-topbar__inner {
	max-width: var(--content-max);
	margin: 0 auto;
	padding: .5rem var(--gutter);
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
}
.leukos-topbar a { color: #fff; }
.leukos-topbar__lang a { padding: 0 .35em; }

/* -------- Header / Nav -------- */
.leukos-header { background: var(--bg); border-bottom: 1px solid rgba(0,0,0,.06); position: sticky; top: 0; z-index: 100; }
.leukos-header__inner {
	max-width: var(--content-max);
	margin: 0 auto;
	padding: .75rem var(--gutter);
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1.5rem;
	height: var(--header-h);
}
.leukos-header__logo {
	display: inline-flex;
	align-items: center;
	background-image: none !important;
}
.leukos-header__logo img {
	height: 60px;
	width: auto;
	max-height: 60px;
	display: block !important;
}
@media (max-width: 720px) {
	.leukos-header__logo img { height: 48px; max-height: 48px; }
}

.leukos-header__menu {
	display: flex; gap: 1.75rem;
	margin: 0; padding: 0; list-style: none;
}
.leukos-header__menu a {
	color: var(--text);
	font-family: var(--heading-font);
	font-size: .875rem;
	text-transform: uppercase;
	letter-spacing: 1.5px;
	padding: .4em 0;
	border-bottom: 2px solid transparent;
}
.leukos-header__menu a:hover { border-color: var(--accent); opacity: 1; }
.leukos-header__toggle { display: none; background: none; border: 0; cursor: pointer; padding: .5em; }
.leukos-header__burger {
	display: block; width: 24px; height: 2px;
	background: var(--text); position: relative;
}
.leukos-header__burger::before,
.leukos-header__burger::after {
	content: ''; position: absolute; left: 0; width: 100%; height: 2px; background: var(--text);
	transition: transform .2s;
}
.leukos-header__burger::before { top: -7px; }
.leukos-header__burger::after  { top:  7px; }

@media (max-width: 880px) {
	.leukos-header__toggle { display: block; }
	.leukos-header__menu {
		position: absolute; top: 100%; left: 0; right: 0;
		flex-direction: column; gap: 0;
		background: var(--bg);
		max-height: 0; overflow: hidden;
		transition: max-height .3s ease;
		border-bottom: 1px solid rgba(0,0,0,.06);
	}
	.leukos-header__menu[data-open="true"] { max-height: 80vh; padding: 1rem var(--gutter); }
	.leukos-header__menu li { padding: .5rem 0; }
}

/* -------- Side icons -------- */
.leukos-side {
	position: fixed; right: 1rem; top: 50%;
	transform: translateY(-50%);
	z-index: 90;
}
.leukos-side__list {
	display: flex; flex-direction: column; gap: .35rem;
	list-style: none; margin: 0; padding: 0;
}
.leukos-side__list a {
	display: flex; align-items: center; justify-content: center;
	width: 44px; height: 44px;
	background: var(--bg);
	border: 1px solid rgba(0,0,0,.08);
	color: var(--text);
}
.leukos-side__list a:hover { background: var(--accent); color: #fff; opacity: 1; }
.leukos-side__list svg { width: 18px; height: 18px; fill: currentColor; }

@media (max-width: 720px) {
	.leukos-side {
		position: fixed; right: auto; left: 0; top: auto; bottom: 0;
		transform: none; width: 100%;
		background: var(--bg);
		border-top: 1px solid rgba(0,0,0,.08);
	}
	.leukos-side__list { flex-direction: row; justify-content: space-around; padding: .5rem; }
	.leukos-side__list a { border: 0; }
}

/* -------- Hero -------- */
.leukos-hero {
	position: relative;
	min-height: 90vh;
	display: flex; align-items: center;
	color: #fff;
	overflow: hidden;
}
.leukos-hero__bg {
	position: absolute; inset: 0;
	background-size: cover; background-position: center;
	z-index: 0;
}
.leukos-hero__overlay {
	position: absolute; inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,.15) 0%, rgba(0,0,0,.55) 100%);
	z-index: 1;
}
.leukos-hero__inner {
	position: relative; z-index: 2;
	max-width: var(--content-max);
	width: 100%;
	margin: 0 auto;
	padding: var(--section-pad-y) var(--gutter);
}
.leukos-hero__eyebrow { color: rgba(255,255,255,.8); font-family: var(--heading-font); text-transform: uppercase; letter-spacing: 2px; margin-bottom: .5rem; }
.leukos-hero__title { color: #fff; margin-bottom: .5rem; }
.leukos-hero__slogan { color: rgba(255,255,255,.9); font-size: 1.25rem; max-width: 50ch; }
.leukos-hero__features {
	list-style: none; padding: 0; margin: 2rem 0;
	display: flex; flex-wrap: wrap; gap: 1.5rem 2.5rem;
}
.leukos-hero__features li {
	display: flex; align-items: center; gap: .5rem;
	color: rgba(255,255,255,.9); font-size: .9rem;
	text-transform: uppercase; letter-spacing: 1.5px;
}
.leukos-hero__cta { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 1rem; }
.leukos-hero__cta .leukos-btn { background: rgba(255,255,255,.95); color: var(--text); border-color: rgba(255,255,255,.95); }
.leukos-hero__cta .leukos-btn--ghost { background: transparent; color: #fff; border-color: #fff; }
.leukos-hero__scroll {
	position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%);
	z-index: 3; color: #fff;
	animation: leukos-bob 2s ease-in-out infinite;
}
.leukos-hero__scroll svg { width: 32px; height: 32px; fill: currentColor; }
@keyframes leukos-bob { 0%,100% { transform: translate(-50%,0); } 50% { transform: translate(-50%,-8px); } }

/* -------- Generic Section -------- */
.leukos-section { padding: var(--section-pad-y) 0; background: var(--bg); }
.leukos-section--alt { background: var(--bg-alt); }
.leukos-section__inner {
	max-width: var(--content-max);
	margin: 0 auto;
	padding: 0 var(--gutter);
}
.leukos-section__header { margin-bottom: 3rem; max-width: 70ch; }
.leukos-section__eyebrow {
	font-family: var(--heading-font);
	font-size: .85rem;
	text-transform: uppercase;
	letter-spacing: 2px;
	color: var(--accent);
	margin-bottom: .75rem;
}
.leukos-section__title { color: var(--text); }
.leukos-section__grid--objekt {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 2.5rem;
	margin-bottom: 2.5rem;
}
@media (max-width: 880px) {
	.leukos-section__grid--objekt { grid-template-columns: 1fr; }
}

/* Objekt-Facts */
.leukos-objekt__facts {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 1.5rem;
	padding-top: 2rem;
	border-top: 1px solid rgba(0,0,0,.08);
}
.leukos-objekt__fact { text-align: center; }
.leukos-objekt__fact-num {
	font-family: var(--heading-font);
	font-size: 2.5rem;
	color: var(--accent);
	display: block;
	margin-bottom: .25rem;
	font-weight: 300;
}
.leukos-objekt__fact-label {
	font-size: .8rem;
	text-transform: uppercase;
	letter-spacing: 1.5px;
	color: var(--text-muted);
}

/* Slider (basic horizontal scroll) */
.leukos-objekt__slider {
	display: flex;
	gap: 1rem;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	padding-bottom: 1rem;
}
.leukos-objekt__slider img {
	flex: 0 0 80%;
	scroll-snap-align: start;
	object-fit: cover;
	aspect-ratio: 4/3;
}

/* Wohnungen Section */
.leukos-wohnungen__ausstattung {
	columns: 2;
	column-gap: 2rem;
	margin-bottom: 3rem;
}
.leukos-wohnungen__ausstattung ul { padding-left: 1.25em; }
.leukos-wohnungen__ausstattung li { margin-bottom: .5em; break-inside: avoid; }
@media (max-width: 720px) {
	.leukos-wohnungen__ausstattung { columns: 1; }
}

/* Tabs */
.leukos-tabs { margin-bottom: 3rem; }
.leukos-tabs__nav {
	display: flex; gap: 0; flex-wrap: wrap;
	border-bottom: 1px solid rgba(0,0,0,.1);
	margin-bottom: 1.5rem;
}
.leukos-tabs__btn {
	background: none; border: 0; border-bottom: 2px solid transparent;
	padding: .75em 1.25em;
	font-family: var(--heading-font); font-size: .875rem;
	text-transform: uppercase; letter-spacing: 1.5px;
	color: var(--text-muted); cursor: pointer;
	transition: color .15s, border-color .15s;
}
.leukos-tabs__btn[aria-selected="true"] { color: var(--accent); border-color: var(--accent); }
.leukos-tabs__panel { display: none; }
.leukos-tabs__panel[data-active="true"] { display: block; }
.leukos-tabs__panel img { width: 100%; aspect-ratio: 16/9; object-fit: cover; }

/* Concept cards (B-UP! Smart / Classic / Skyliner) */
.leukos-concepts {
	display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 1.5rem;
	margin-bottom: 3rem;
}
.leukos-concept {
	background: var(--bg);
	padding: 2rem;
	border: 1px solid rgba(0,0,0,.08);
	display: flex; flex-direction: column;
	transition: border-color .15s, transform .2s;
}
.leukos-concept:hover { border-color: var(--accent); transform: translateY(-4px); }
.leukos-concept h3 { color: var(--accent); }

/* Matterport */
.leukos-wohnungen__matterport-frame {
	background: #000;
	aspect-ratio: 16/9;
	display: flex; align-items: center; justify-content: center;
	color: #fff;
	margin-top: 1rem;
}

/* App */
.leukos-wohnungen__app {
	display: grid; grid-template-columns: 1fr 1fr;
	gap: 2.5rem; align-items: center;
	margin: 4rem 0;
}
@media (max-width: 880px) {
	.leukos-wohnungen__app { grid-template-columns: 1fr; }
}

/* Lage */
.leukos-lage__grid {
	display: grid; grid-template-columns: 1.4fr 1fr;
	gap: 2.5rem;
	margin-bottom: 3rem;
}
@media (max-width: 880px) {
	.leukos-lage__grid { grid-template-columns: 1fr; }
}
.leukos-lage__distances {
	list-style: none; padding: 0; margin: 0;
	border-top: 1px solid rgba(0,0,0,.08);
}
.leukos-lage__distances li {
	display: flex; justify-content: space-between;
	padding: .75rem 0;
	border-bottom: 1px solid rgba(0,0,0,.08);
	font-size: .9rem;
}
.leukos-lage__distances strong { font-weight: 500; color: var(--text); }

.leukos-lage__filters {
	display: flex; flex-wrap: wrap; gap: .5rem;
	margin-bottom: 1rem;
}
.leukos-lage__filter {
	background: var(--bg); border: 1px solid rgba(0,0,0,.15);
	padding: .5em 1em;
	font-family: var(--heading-font); font-size: .8rem;
	text-transform: uppercase; letter-spacing: 1.5px;
	cursor: pointer;
}
.leukos-lage__filter.is-active { background: var(--accent); color: #fff; border-color: var(--accent); }

.leukos-lage__map {
	height: 480px;
	width: 100%;
	background: var(--bg-alt);
}
.leukos-lage__map-note {
	font-size: .75rem;
	color: var(--text-muted);
	margin-top: .5rem;
}

/* Process */
.leukos-process {
	list-style: none; padding: 0; margin: 0;
	counter-reset: process;
	display: grid; gap: 1.5rem;
}
.leukos-process__step {
	background: var(--bg); padding: 2rem;
	border-left: 4px solid var(--accent);
}
.leukos-process__num {
	display: inline-block;
	font-family: var(--heading-font);
	font-size: 2.5rem; line-height: 1;
	color: var(--accent);
	margin-bottom: .5rem;
}

/* FAQ */
.leukos-faq__item {
	border-bottom: 1px solid rgba(0,0,0,.08);
}
.leukos-faq__item summary {
	cursor: pointer;
	list-style: none;
	padding: 1.25rem 2.5rem 1.25rem 0;
	font-family: var(--heading-font);
	font-size: 1rem;
	text-transform: uppercase;
	letter-spacing: 1.5px;
	color: var(--text);
	position: relative;
}
.leukos-faq__item summary::-webkit-details-marker { display: none; }
.leukos-faq__item summary::after {
	content: '+';
	position: absolute; right: 0; top: 50%; transform: translateY(-50%);
	font-size: 1.75rem; color: var(--accent);
	transition: transform .2s;
}
.leukos-faq__item[open] summary::after { content: '−'; }
.leukos-faq__answer { padding: 0 0 1.5rem; color: var(--text-muted); }

/* Kontakt */
.leukos-kontakt__grid {
	display: grid; grid-template-columns: 1fr 1.5fr 1fr;
	gap: 2.5rem;
}
@media (max-width: 1024px) {
	.leukos-kontakt__grid { grid-template-columns: 1fr; }
}
.leukos-kontakt__avatar img {
	width: 120px; height: 120px;
	border-radius: 50%;
	object-fit: cover;
	margin-bottom: 1rem;
}
.leukos-kontakt__downloads ul { list-style: none; padding: 0; }
.leukos-kontakt__downloads a { display: flex; align-items: center; gap: .5rem; padding: .5rem 0; border-bottom: 1px solid rgba(0,0,0,.08); }
.leukos-kontakt__downloads a::before {
	content: '↓'; color: var(--accent); font-weight: bold;
}

/* Placeholder styling */
.placeholder {
	border: 2px dashed var(--accent);
	background: rgba(0,0,0,.02);
	padding: 2rem;
}
.placeholder::before {
	content: 'Platzhalter — wird durch Plugin-Ausgabe ersetzt';
	display: block;
	font-size: .75rem; text-transform: uppercase; letter-spacing: 2px;
	color: var(--accent);
	margin-bottom: 1rem;
}

/* Footer */
.leukos-footer { background: var(--text); color: rgba(255,255,255,.8); padding: 3rem 0 1rem; margin-top: 4rem; }
.leukos-footer h3 { color: #fff; }
.leukos-footer a { color: rgba(255,255,255,.8); }
.leukos-footer__inner {
	max-width: var(--content-max);
	margin: 0 auto;
	padding: 0 var(--gutter);
	display: grid; grid-template-columns: repeat(3, 1fr);
	gap: 2.5rem;
}
@media (max-width: 880px) {
	.leukos-footer__inner { grid-template-columns: 1fr; gap: 1.5rem; }
}
.leukos-footer__bottom {
	max-width: var(--content-max);
	margin: 2rem auto 0;
	padding: 1rem var(--gutter) 0;
	border-top: 1px solid rgba(255,255,255,.1);
	font-size: .75rem;
	color: rgba(255,255,255,.6);
}
.leukos-footer__col ul { list-style: none; padding: 0; }
.leukos-footer__col li { margin-bottom: .35rem; }


/* === B-UP! additions === */
.leukos-section__grid--objekt {
	grid-template-columns: 1.4fr 1fr;
	align-items: start;
}
@media (max-width: 880px) {
	.leukos-section__grid--objekt { grid-template-columns: 1fr; }
}
.leukos-objekt__text p { margin-bottom: 1em; }
.leukos-objekt__slider img { aspect-ratio: 4/3; }

.leukos-wohnungen__eyebrow {
	font-family: var(--heading-font);
	font-size: .75rem;
	text-transform: uppercase;
	letter-spacing: 2px;
	color: var(--accent);
	margin: 0 0 .5rem;
}
.leukos-wohnungen__headline {
	font-family: var(--heading-font);
	font-size: clamp(1.5rem, 2.5vw, 2rem);
	font-weight: 400;
	text-transform: none;
	letter-spacing: .02em;
	color: var(--text);
	margin: 0 0 1rem;
}

.leukos-concepts {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 1.5rem;
	margin-bottom: 4.5rem;
}
.leukos-concept {
	background: var(--bg);
	border: 1px solid rgba(0,0,0,.08);
	display: flex; flex-direction: column;
	overflow: hidden;
	transition: border-color .15s, transform .2s;
}
.leukos-concept:hover { border-color: var(--accent); transform: translateY(-4px); }
.leukos-concept__img img {
	width: 100%;
	aspect-ratio: 4/3;
	object-fit: contain;
	background: var(--bg-alt);
}
.leukos-concept__body { padding: 1.75rem; display: flex; flex-direction: column; gap: .5rem; flex: 1; }
.leukos-concept__body h3 { color: var(--accent); margin: 0; font-size: 1.5rem; }
.leukos-concept__subtitle { font-family: var(--heading-font); font-size: .8rem; text-transform: uppercase; letter-spacing: 1.5px; color: var(--text-muted); margin: 0; }
.leukos-concept .leukos-btn { margin-top: auto; align-self: flex-start; }

.leukos-wohnungen__ausstattung-block {
	display: grid;
	grid-template-columns: 1fr 1.2fr;
	gap: 3rem;
	margin-bottom: 4.5rem;
	padding-bottom: 4rem;
	border-bottom: 1px solid rgba(0,0,0,.06);
}
.leukos-wohnungen__ausstattung-list ul {
	list-style: none; padding: 0; margin: 0;
	columns: 2; column-gap: 2rem;
}
.leukos-wohnungen__ausstattung-list li {
	padding: .5rem 0 .5rem 1.25rem;
	position: relative; break-inside: avoid;
	color: var(--text); font-size: .95rem;
}
.leukos-wohnungen__ausstattung-list li::before {
	content: ''; position: absolute; left: 0; top: .95rem;
	width: 6px; height: 6px;
	background: var(--accent); border-radius: 50%;
}
@media (max-width: 880px) {
	.leukos-wohnungen__ausstattung-block { grid-template-columns: 1fr; gap: 2rem; }
	.leukos-wohnungen__ausstattung-list ul { columns: 1; }
}

.leukos-wohnungen__app {
	display: grid; grid-template-columns: 1fr 1fr;
	gap: 3rem; align-items: center;
	margin-bottom: 4.5rem;
	padding-bottom: 4rem;
	border-bottom: 1px solid rgba(0,0,0,.06);
}
.leukos-wohnungen__app--reverse .leukos-wohnungen__app-img { order: -1; }
.leukos-wohnungen__app-text p { margin-bottom: 1em; }
.leukos-wohnungen__app-text ul {
	list-style: none; padding: 0; margin: 1rem 0 0;
}
.leukos-wohnungen__app-text li {
	padding: .4rem 0 .4rem 1.25rem;
	position: relative; color: var(--text); font-size: .95rem;
}
.leukos-wohnungen__app-text li::before {
	content: ''; position: absolute; left: 0; top: .9rem;
	width: 6px; height: 6px;
	background: var(--accent); border-radius: 50%;
}
.leukos-wohnungen__app-img img { width: 100%; object-fit: cover; aspect-ratio: 4/3; }
@media (max-width: 880px) {
	.leukos-wohnungen__app { grid-template-columns: 1fr; }
	.leukos-wohnungen__app--reverse .leukos-wohnungen__app-img { order: 0; }
}

/* Footer legal block */
.leukos-footer h4 {
	color: #fff;
	font-family: var(--heading-font);
	font-size: .8rem;
	text-transform: uppercase;
	letter-spacing: 2px;
	margin: 0 0 .75rem;
}
.leukos-footer__legal {
	max-width: var(--content-max);
	margin: 2.5rem auto 0;
	padding: 2rem var(--gutter) 0;
	border-top: 1px solid rgba(255,255,255,.1);
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: 2.5rem;
}
@media (max-width: 880px) {
	.leukos-footer__legal { grid-template-columns: 1fr; gap: 1.5rem; }
}
.leukos-footer__legal-block p { color: rgba(255,255,255,.7); }
.leukos-footer__small {
	font-size: .75rem;
	line-height: 1.6;
	color: rgba(255,255,255,.7) !important;
	margin: 0 0 .5em !important;
}

.leukos-kontakt__grid--no-downloads {
	grid-template-columns: 1fr 1.5fr !important;
}
@media (max-width: 1024px) {
	.leukos-kontakt__grid--no-downloads { grid-template-columns: 1fr !important; }
}

/* === Sticky header fix: also stick the outer WP template-part wrapper === */
header.wp-block-template-part {
	position: sticky !important;
	top: 0 !important;
	z-index: 100 !important;
	background: var(--bg, #fff);
}
/* Make sure the topbar template-part also doesn't break stacking */
.wp-block-template-part:has(.leukos-topbar) {
	position: relative;
	z-index: 101;
}
/* Inner header keeps the visual styling but no longer needs sticky on its own */
.leukos-header {
	position: relative;
	box-shadow: 0 2px 8px rgba(0,0,0,.04);
}

/* === Premium sticky header (taller, blur, soft shadow) === */
header.wp-block-template-part {
	background: rgba(255,255,255,.92) !important;
	-webkit-backdrop-filter: saturate(180%) blur(12px);
	backdrop-filter: saturate(180%) blur(12px);
	border-bottom: 1px solid rgba(0,0,0,.06) !important;
	box-shadow: 0 4px 24px rgba(0,0,0,.06);
}
.leukos-header__inner {
	min-height: 104px !important;
	padding-top: 1rem !important;
	padding-bottom: 1rem !important;
}
.leukos-header__logo img {
	height: 72px !important;
	max-height: 72px !important;
}
.leukos-header__menu {
	gap: 2.25rem !important;
}
.leukos-header__menu a {
	font-size: .82rem !important;
	letter-spacing: 1.8px !important;
}
@media (max-width: 880px) {
	.leukos-header__inner { min-height: 80px !important; }
	.leukos-header__logo img {
		height: 56px !important;
		max-height: 56px !important;
	}
}

/* === Transparent header over hero, opaque on scroll === */
header.wp-block-template-part {
	background: transparent !important;
	backdrop-filter: none !important;
	-webkit-backdrop-filter: none !important;
	border-bottom-color: transparent !important;
	box-shadow: none !important;
	transition: background .3s ease, backdrop-filter .3s ease, border-color .3s ease, box-shadow .3s ease;
}
header.wp-block-template-part.is-scrolled {
	background: rgba(255,255,255,.88) !important;
	-webkit-backdrop-filter: saturate(180%) blur(14px);
	backdrop-filter: saturate(180%) blur(14px);
	border-bottom-color: rgba(0,0,0,.06) !important;
	box-shadow: 0 4px 24px rgba(0,0,0,.05) !important;
}

/* When hero is in view (header is transparent) — invert text colors to white */
.leukos-header { background: transparent !important; }
header.wp-block-template-part:not(.is-scrolled) .leukos-header__menu a {
	color: #ffffff !important;
	text-shadow: 0 1px 2px rgba(0,0,0,.35);
}
header.wp-block-template-part:not(.is-scrolled) .leukos-header__menu a:hover {
	border-bottom-color: #ffffff !important;
}
header.wp-block-template-part:not(.is-scrolled) .leukos-header__burger,
header.wp-block-template-part:not(.is-scrolled) .leukos-header__burger::before,
header.wp-block-template-part:not(.is-scrolled) .leukos-header__burger::after {
	background: #ffffff !important;
}
/* Logo on transparent header: invert to white-friendly version via filter */
header.wp-block-template-part:not(.is-scrolled) .leukos-header__logo img {
	filter: brightness(0) invert(1) drop-shadow(0 1px 2px rgba(0,0,0,.35));
}
header.wp-block-template-part.is-scrolled .leukos-header__logo img {
	filter: none;
}

/* Topbar above the header — keep dark, but make it absolute so header sits on top of hero */
.wp-block-template-part:has(.leukos-topbar) {
	position: relative;
	z-index: 99;
}
/* Avoid double-spacing for hero — hero already has 90vh min-height, no offset needed */

/* === Fixed overlay header — sits on top of hero === */
header.wp-block-template-part {
	position: fixed !important;
	top: 0 !important;
	left: 0 !important;
	right: 0 !important;
	width: 100% !important;
	z-index: 100 !important;
}
/* Hero pulls up under the header so transparent header overlays the building photo */
.leukos-hero {
	margin-top: 0 !important;
	min-height: 100vh !important;
}
/* Topbar template part sits above the header fixed */
.wp-block-template-part:has(.leukos-topbar) {
	position: fixed !important;
	top: 0 !important;
	left: 0; right: 0; width: 100%;
	z-index: 102 !important;
}
header.wp-block-template-part {
	top: 36px !important; /* topbar height */
}
/* Body padding-top only after the hero ends — handled by hero having 100vh */
body { padding-top: 0 !important; }

/* === Final fix: sticky overlay (content stays below, transparent over hero) === */
header.wp-block-template-part {
	position: sticky !important;
	top: 0 !important;
	left: auto !important;
	right: auto !important;
	width: auto !important;
	z-index: 100 !important;
	margin-top: -104px;
	padding-top: 0 !important;
}
.wp-block-template-part:has(.leukos-topbar) {
	position: sticky !important;
	top: 0 !important;
	left: auto !important;
	right: auto !important;
	width: auto !important;
	z-index: 102 !important;
}
/* The hero must extend behind the header */
.leukos-hero { min-height: 100vh !important; padding-top: 104px; }
/* Reset body padding */
body { padding-top: 0 !important; }

/* When NOT scrolled (over hero): transparent header, white nav text */
header.wp-block-template-part:not(.is-scrolled) {
	background: transparent !important;
	border-bottom: none !important;
	box-shadow: none !important;
	backdrop-filter: none !important;
	-webkit-backdrop-filter: none !important;
}
header.wp-block-template-part:not(.is-scrolled) .leukos-header__menu a {
	color: #ffffff !important;
	text-shadow: 0 1px 3px rgba(0,0,0,.45);
}
header.wp-block-template-part:not(.is-scrolled) .leukos-header__logo img {
	filter: brightness(0) invert(1) drop-shadow(0 1px 3px rgba(0,0,0,.45));
}

/* When scrolled past hero: white blur with dark text */
header.wp-block-template-part.is-scrolled {
	background: rgba(255,255,255,.92) !important;
	backdrop-filter: saturate(180%) blur(14px) !important;
	-webkit-backdrop-filter: saturate(180%) blur(14px) !important;
	border-bottom: 1px solid rgba(0,0,0,.06) !important;
	box-shadow: 0 4px 24px rgba(0,0,0,.05) !important;
}
header.wp-block-template-part.is-scrolled .leukos-header__menu a {
	color: var(--text, #333) !important;
	text-shadow: none;
}
header.wp-block-template-part.is-scrolled .leukos-header__logo img {
	filter: none;
}

/* === Logo final size + crisp rendering === */
.leukos-header__logo img {
	height: 84px !important;
	max-height: 84px !important;
	width: auto !important;
	image-rendering: -webkit-optimize-contrast;
	image-rendering: crisp-edges;
}
@media (max-width: 880px) {
	.leukos-header__logo img {
		height: 64px !important;
		max-height: 64px !important;
	}
}
.leukos-header__inner {
	min-height: 114px !important;
}
