/* ==========================================================================
   Site Header – eigenständiges CSS, unabhängig von Jupiter/WPBakery
   ==========================================================================

   ANPASSEN: Die Werte unter :root sind die Stellschrauben für Farben,
   Schrift und Breakpoint. Mit DevTools (Rechtsklick -> Untersuchen) auf
   der aktuellen Live-Seite die echten Werte ablesen und hier eintragen,
   falls etwas nicht exakt passt.
   ========================================================================== */

:root {
	/* Farben */
	--tvs-color-primary: #e00d06;       /* Vereins-Rot */
	--tvs-color-primary-text: #ffffff;
	--tvs-color-toolbar-bg: #999999;    /* Grau, inaktive Vereins-Buttons      */
	--tvs-color-toolbar-text: #ffffff;
	--tvs-color-header-bg: #ffffff;
	--tvs-color-nav-text: #2b2b2b;
	--tvs-color-border: #e7e7e7;
	--tvs-color-overlay: rgba(0, 0, 0, 0.45);

	/* Typografie */
	--tvs-font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	--tvs-nav-font-size: 13px;
	--tvs-nav-letter-spacing: 0.04em;
	--tvs-nav-item-gap: 6px; /* etwas Luft zwischen den Hauptmenüpunkten */
	--tvs-club-gap: 10px;    /* Abstand zwischen den 4 Vereins-Buttons      */

	/* Masse */
	--tvs-header-height: 90px;          /* Hauptzeile (Logo/Nav), ungescrollt */
	--tvs-header-height-scrolled: 64px; /* Hauptzeile, gescrollt              */
	--tvs-toolbar-height: 42px;         /* Vereins-Toolbar-Zeile              */
	--tvs-breakpoint: 1024px; /* ab hier: Hamburger-Menü statt Vollnavigation */
	--tvs-container-width: 1400px;
	--tvs-container-padding: 20px;
	--tvs-transition: 0.25s ease;
}

/* --------------------------------------------------------------------------
   Grundreset innerhalb des Headers (defensiv gegen Jupiter-Altlasten)
   -------------------------------------------------------------------------- */
.site-header,
.site-header *,
.site-nav-overlay {
	box-sizing: border-box;
}

.site-header ul,
.site-nav-overlay ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.site-header li,
.site-nav-overlay li {
	margin: 0;
	padding: 0;
}

.site-header a {
	text-decoration: none;
}

.site-header img {
	display: block;
	max-width: 100%;
}

/* --------------------------------------------------------------------------
   Header-Grundgerüst
   -------------------------------------------------------------------------- */
.site-header {
	position: sticky;
	top: 0;
	z-index: 9999;
	width: 100%;
	font-family: var(--tvs-font-family);
	background: var(--tvs-color-header-bg);
	border-bottom: 1px solid var(--tvs-color-border);
	transition: box-shadow var(--tvs-transition);
}

.site-header.is-scrolled {
	box-shadow: 0 4px 14px rgba(0, 0, 0, 0.08);
}

/* Gesamt-Layout: Logo links auf voller Höhe, rechts Toolbar + Hauptzeile gestapelt */
.site-header__layout {
	max-width: var(--tvs-container-width);
	margin: 0 auto;
	padding: 0 var(--tvs-container-padding);
	display: flex;
	align-items: stretch;
}

.site-header__logo {
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	height: calc(var(--tvs-toolbar-height) + var(--tvs-header-height));
	padding-right: 28px;
	transition: height var(--tvs-transition);
}

.site-header.is-scrolled .site-header__logo {
	height: var(--tvs-header-height-scrolled);
}

.site-header__logo img {
	max-height: 100%;
	width: auto;
}

.site-header__logo-text {
	font-size: 19px;
	font-weight: 700;
	line-height: 1.2;
	color: var(--tvs-color-nav-text);
	white-space: nowrap;
}

.site-header__right {
	flex: 1 1 auto;
	min-width: 0;
	display: flex;
	flex-direction: column;
}

/* --------------------------------------------------------------------------
   Toolbar (4 Vereine + Social) – auf Mobile ausgeblendet, beim Scrollen
   auf Desktop eingeklappt (Logo schrumpft im Gleichschritt, siehe oben)
   -------------------------------------------------------------------------- */
.site-toolbar {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 24px;
	height: var(--tvs-toolbar-height);
	max-height: var(--tvs-toolbar-height);
	overflow: hidden;
	transition: max-height var(--tvs-transition), opacity var(--tvs-transition);
	opacity: 1;
}

.site-header.is-scrolled .site-toolbar {
	max-height: 0;
	opacity: 0;
}

.site-toolbar__clubs {
	display: flex;
	gap: var(--tvs-club-gap);
}

.site-toolbar__club a {
	display: flex;
	align-items: center;
	height: var(--tvs-toolbar-height);
	padding: 0 18px;
	background: var(--tvs-color-toolbar-bg);
	color: var(--tvs-color-toolbar-text);
	font-size: 16px;
	font-weight: 500;
	white-space: nowrap;
	transition: filter var(--tvs-transition);
}

.site-toolbar__club a:hover {
	filter: brightness(1.08);
}

.site-toolbar__club.is-active a {
	background: var(--tvs-color-primary);
	color: var(--tvs-color-primary-text);
}

/* Logo + Text aus dem WP-Menü-Label (.meni-item-text / .metanav_item_text
   stammen 1:1 aus dem bestehenden Menüeintrag) – hier der gewünschte Abstand */
.site-toolbar__club .meni-item-text {
	display: flex;
	align-items: center;
	gap: 10px;
}

.site-toolbar__club .meni-item-text img {
	height: 25px;
	width: auto;
	flex-shrink: 0;
}

.site-toolbar__social {
	display: flex;
	align-items: center;
	gap: 14px;
	flex-shrink: 0;
}

.site-toolbar__social a {
	display: flex;
	color: #555555;
}

.site-toolbar__social svg {
	height: 16px;
	width: 16px;
	fill: currentColor;
}

/* --------------------------------------------------------------------------
   Hauptzeile: Navigation + Hamburger (Logo sitzt jetzt eine Ebene höher)
   -------------------------------------------------------------------------- */
.site-header__main {
	flex: 1 1 auto;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	height: var(--tvs-header-height);
	transition: height var(--tvs-transition);
}

.site-header.is-scrolled .site-header__main {
	height: var(--tvs-header-height-scrolled);
}

/* --------------------------------------------------------------------------
   Hamburger-Button (nur Mobile sichtbar, 3 Linien -> X)
   -------------------------------------------------------------------------- */
.site-header__toggle {
	display: none;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 5px;
	width: 40px;
	height: 40px;
	background: transparent;
	border: 0;
	cursor: pointer;
	padding: 0;
}

.site-header__toggle-bar {
	width: 24px;
	height: 2px;
	background: var(--tvs-color-nav-text);
	transition: transform var(--tvs-transition), opacity var(--tvs-transition);
}

.site-header__toggle[aria-expanded="true"] .site-header__toggle-bar:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}

.site-header__toggle[aria-expanded="true"] .site-header__toggle-bar:nth-child(2) {
	opacity: 0;
}

.site-header__toggle[aria-expanded="true"] .site-header__toggle-bar:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

/* --------------------------------------------------------------------------
   Navigation – Desktop (>= Breakpoint): horizontale Liste mit Dropdowns,
   ganz rechts ausgerichtet (justify-content: flex-end auf .site-header__main)
   -------------------------------------------------------------------------- */
.site-nav__list {
	display: flex;
	align-items: center;
	gap: var(--tvs-nav-item-gap);
}

.site-nav__item {
	position: relative;
}

.site-nav__link {
	display: flex;
	align-items: center;
	gap: 6px;
	padding: 10px 14px;
	font-size: var(--tvs-nav-font-size);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: var(--tvs-nav-letter-spacing);
	color: var(--tvs-color-nav-text);
	transition: color var(--tvs-transition);
}

/* Letzter Menüpunkt: rechter Innenabstand entfernt, damit der Text exakt am
   selben rechten Rand endet wie die Social-Icons in der Toolbar darüber. */
.site-nav__list > .site-nav__item:last-child > .site-nav__link {
	padding-right: 0;
}

.site-nav__link:hover,
.site-nav__link:focus {
	color: var(--tvs-color-primary);
}

/* Aktiver Menüpunkt (auch der Oberpunkt, wenn man auf einer Unterseite ist):
   roter Strich unten, ohne dass sich die Höhe des Elements ändert. */
.site-nav__item.is-current > .site-nav__link {
	color: var(--tvs-color-primary);
	box-shadow: inset 0 -3px 0 0 var(--tvs-color-primary);
}

.site-nav__subitem.is-current > .site-nav__sublink {
	color: var(--tvs-color-primary);
	font-weight: 700;
}

.site-nav__chevron {
	width: 8px;
	height: 8px;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: rotate(45deg);
	margin-top: -2px;
	transition: transform var(--tvs-transition);
}

/* position:fixed statt absolute: dadurch wird das Dropdown nicht von einem
   evtl. overflow:hidden eines Vorfahren (z.B. rund um einen Slider/Banner
   in der Seite) abgeschnitten – Top/Left werden in site-header.js anhand
   der tatsächlichen Position des Menüpunkts berechnet. */
.site-nav__submenu {
	position: fixed;
	min-width: 230px;
	background: #ffffff;
	box-shadow: 0 10px 25px rgba(0, 0, 0, 0.12);
	border-radius: 2px;
	padding: 6px 0;
	opacity: 0;
	visibility: hidden;
	transform: translateY(6px);
	transition: opacity var(--tvs-transition), transform var(--tvs-transition), visibility var(--tvs-transition);
	z-index: 9999;
}

.site-nav__item.has-children:hover > .site-nav__submenu,
.site-nav__item.has-children:focus-within > .site-nav__submenu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.site-nav__item.has-children:hover > .site-nav__link .site-nav__chevron {
	transform: rotate(225deg);
}

.site-nav__sublink {
	display: block;
	padding: 9px 18px;
	font-size: 16px;
	color: var(--tvs-color-nav-text);
}

.site-nav__sublink:hover,
.site-nav__sublink:focus {
	color: var(--tvs-color-primary);
	background: #f7f7f7;
}

/* Die mobile Vereinsliste (eigenes <ul> unterhalb der Hauptnavigation)
   ist auf Desktop ausgeblendet – sie erscheint nur im Hamburger-Menü. */
.site-nav__clubs-mobile {
	display: none;
}

/* --------------------------------------------------------------------------
   Navigation – Mobile (< Breakpoint): kompakte einzeilige Kopfzeile,
   Off-Canvas-Panel, EINE Quelle im DOM
   -------------------------------------------------------------------------- */
@media (max-width: 1024px) {
	.site-toolbar {
		display: none;
	}

	.site-header__layout {
		align-items: center;
	}

	.site-header__logo {
		height: auto;
		padding-right: 12px;
	}

	.site-header__logo img {
		max-height: 40px;
	}

	.site-header.is-scrolled .site-header__logo img {
		max-height: 32px;
	}

	.site-header__right {
		flex-direction: row;
	}

	.site-header__main {
		height: 64px;
		justify-content: flex-end;
	}

	.site-header.is-scrolled .site-header__main {
		height: 56px;
	}

	.site-header__toggle {
		display: flex;
	}

	.site-nav {
		position: fixed;
		top: 64px;
		right: 0;
		bottom: 0;
		width: min(85vw, 360px);
		background: #ffffff;
		overflow-y: auto;
		transform: translateX(100%);
		transition: transform var(--tvs-transition);
		box-shadow: -8px 0 24px rgba(0, 0, 0, 0.15);
	}

	.site-header.nav-is-open .site-nav {
		transform: translateX(0);
	}

	.site-nav__list {
		display: block;
		padding: 10px 0 24px;
	}

	.site-nav__item {
		border-bottom: 1px solid var(--tvs-color-border);
	}

	.site-nav__list > .site-nav__item:last-child > .site-nav__link {
		padding-right: 22px;
	}

	.site-nav__link {
		padding: 14px 22px;
		justify-content: space-between;
	}

	.site-nav__chevron {
		transition: transform var(--tvs-transition);
	}

	.site-nav__item.has-children.is-open > .site-nav__link .site-nav__chevron {
		transform: rotate(225deg);
	}

	.site-nav__submenu {
		position: static;
		opacity: 1;
		visibility: visible;
		transform: none;
		box-shadow: none;
		display: none;
		background: #fafafa;
		padding: 4px 0 8px;
	}

	.site-nav__list > .site-nav__item:last-child > .site-nav__submenu {
		right: auto;
	}

	.site-nav__item.has-children.is-open > .site-nav__submenu {
		display: block;
	}

	.site-nav__sublink {
		padding: 10px 32px;
	}

	/* Vereinsliste im Mobile-Menü: volle Breite statt Pill-Button,
	   gleiche Logo+Text-Struktur wie in der Desktop-Toolbar. */
	.site-nav__clubs-mobile {
		display: block;
		border-top: 1px solid var(--tvs-color-border);
		margin-top: 14px;
		padding-bottom: 8px;
	}

	.site-nav__clubs-mobile .site-toolbar__club {
		border-bottom: 1px solid var(--tvs-color-border);
	}

	.site-nav__clubs-mobile .site-toolbar__club a {
		height: auto;
		width: 100%;
		padding: 14px 22px;
		background: transparent;
		color: var(--tvs-color-nav-text);
	}

	.site-nav__clubs-mobile .site-toolbar__club.is-active a {
		background: var(--tvs-color-primary);
		color: var(--tvs-color-primary-text);
	}
}

/* Verdunkelung hinter dem geöffneten Mobile-Menü */
.site-nav-overlay {
	position: fixed;
	inset: 0;
	background: var(--tvs-color-overlay);
	z-index: 9998;
}

.site-nav-overlay[hidden] {
	display: none;
}

/* --------------------------------------------------------------------------
   Eingabegeräte / Barrierefreiheit
   -------------------------------------------------------------------------- */
.site-header a:focus-visible,
.site-header button:focus-visible {
	outline: 2px solid var(--tvs-color-primary);
	outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
	.site-header *,
	.site-nav,
	.site-header__toggle-bar,
	.site-header__logo {
		transition: none !important;
	}
}
