/* =========================================================
   FSV 63 – Kooperation 1. FC Union Berlin
   Premium-Seite im blau-gelben FSV-Stil
   ========================================================= */

.fsv-union-page {
	--union-blue-950: #061225;
	--union-blue-900: #081a33;
	--union-blue-850: #0b2346;
	--union-blue-800: #0e2c59;
	--union-yellow: #f4c400;
	--union-yellow-soft: rgba(244, 196, 0, .16);
	--union-white: #ffffff;
	--union-muted: rgba(255,255,255,.76);
	--union-line: rgba(255,255,255,.13);
	--union-card: rgba(9, 31, 67, .72);
	position: relative;
	color: var(--union-white);
	background:
		radial-gradient(circle at 14% 8%, rgba(244,196,0,.16), transparent 28%),
		radial-gradient(circle at 88% 18%, rgba(21,120,255,.18), transparent 30%),
		linear-gradient(180deg, var(--union-blue-900) 0%, var(--union-blue-950) 100%);
	overflow: hidden;
}

.fsv-union-page::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	opacity: .07;
	background: repeating-linear-gradient(
		-45deg,
		rgba(255,255,255,.18) 0,
		rgba(255,255,255,.18) 10px,
		transparent 10px,
		transparent 28px
	);
}

.fsv-union-page > * {
	position: relative;
	z-index: 1;
}

.fsv-union-page .container {
	max-width: 1180px;
}

.fsv-union-page a {
	text-decoration: none;
}

.fsv-union-page .fsv63-fa-icon {
	width: 1em;
	height: 1em;
	line-height: 1;
}

/* Hero */
.fsv-union-hero {
	position: relative;
	min-height: 680px;
	display: flex;
	align-items: center;
	isolation: isolate;
	background:
		linear-gradient(135deg, rgba(4,17,37,.96), rgba(8,29,62,.78)),
		radial-gradient(circle at 80% 32%, rgba(244,196,0,.22), transparent 30%);
	border-bottom: 3px solid rgba(244,196,0,.86);
	overflow: hidden;
}

.fsv-union-hero.has-image::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -2;
	background: var(--fsv-union-hero-image) center center / cover no-repeat;
	transform: scale(1.03);
	filter: saturate(1.08) contrast(1.02);
}

.fsv-union-hero::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -1;
	background:
		linear-gradient(90deg, rgba(3,13,29,.94) 0%, rgba(5,20,44,.82) 43%, rgba(5,20,44,.38) 100%),
		linear-gradient(180deg, rgba(3,13,29,.16) 0%, rgba(3,13,29,.88) 100%);
}

.fsv-union-hero__inner {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(300px, 400px);
	gap: 54px;
	align-items: center;
	padding-top: clamp(86px, 10vw, 136px);
	padding-bottom: clamp(70px, 8vw, 120px);
}

.fsv-union-eyebrow,
.fsv-union-kicker {
	margin: 0 0 14px;
	color: var(--union-yellow);
	font-size: 13px;
	line-height: 1;
	font-weight: 950;
	letter-spacing: .14em;
	text-transform: uppercase;
}

.fsv-union-hero h1 {
	margin: 0;
	max-width: 880px;
	color: #fff;
	font-size: clamp(54px, 7vw, 112px);
	line-height: .9;
	font-weight: 950;
	letter-spacing: -.055em;
	text-transform: uppercase;
}

.fsv-union-hero h1 span,
.fsv-union-hero h1 strong {
	display: block;
}

.fsv-union-hero h1 strong {
	margin-top: 8px;
	color: var(--union-yellow);
	text-shadow: 0 18px 44px rgba(0,0,0,.34);
}

.fsv-union-hero__lead {
	max-width: 720px;
	margin: 28px 0 0;
	color: rgba(255,255,255,.9);
	font-size: clamp(18px, 2vw, 23px);
	line-height: 1.55;
	font-weight: 650;
}

.fsv-union-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	margin-top: 36px;
}

.fsv-union-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 11px;
	min-height: 56px;
	padding: 0 24px;
	border-radius: 16px;
	font-size: 13px;
	font-weight: 950;
	letter-spacing: .04em;
	text-transform: uppercase;
	transition: transform .2s ease, border-color .2s ease, background .2s ease;
}

.fsv-union-btn:hover {
	transform: translateY(-2px);
	text-decoration: none;
}

.fsv-union-btn--primary {
	color: #061225;
	background: linear-gradient(180deg, #ffe064, var(--union-yellow));
	box-shadow: 0 20px 40px rgba(244,196,0,.22);
}

.fsv-union-btn--primary:hover { color: #061225; }

.fsv-union-btn--ghost {
	color: #fff;
	border: 1px solid rgba(255,255,255,.22);
	background: rgba(255,255,255,.06);
	backdrop-filter: blur(10px);
}

.fsv-union-btn--ghost:hover {
	color: var(--union-yellow);
	border-color: rgba(244,196,0,.5);
}

.fsv-union-partner-card {
	position: relative;
	padding: 28px;
	border: 1px solid rgba(255,255,255,.15);
	border-radius: 28px;
	background:
		linear-gradient(180deg, rgba(10,35,73,.82), rgba(4,16,36,.72)),
		radial-gradient(circle at 80% 0%, rgba(244,196,0,.16), transparent 36%);
	box-shadow: 0 28px 70px rgba(0,0,0,.34);
	backdrop-filter: blur(12px);
	overflow: hidden;
}

.fsv-union-partner-card::before {
	content: "";
	position: absolute;
	inset: 0 0 auto;
	height: 5px;
	background: linear-gradient(90deg, var(--union-yellow), #1c65bd, #d41f2b);
}

.fsv-union-partner-card__clubs {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: 10px;
	text-align: center;
	font-size: 18px;
	line-height: 1;
	font-weight: 950;
	text-transform: uppercase;
}

.fsv-union-partner-card__clubs span {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 92px;
	padding: 14px 12px;
	border-radius: 20px;
	background: rgba(255,255,255,.06);
	border: 1px solid rgba(255,255,255,.1);
}

.fsv-union-partner-card__clubs b {
	color: var(--union-yellow);
	font-size: 34px;
}

.fsv-union-partner-card__date {
	margin-top: 22px;
	padding: 22px;
	border-radius: 20px;
	background: rgba(2,10,24,.34);
	border: 1px solid rgba(255,255,255,.1);
	text-align: center;
}

.fsv-union-partner-card__date strong {
	display: block;
	color: var(--union-yellow);
	font-size: clamp(34px, 4vw, 52px);
	line-height: .95;
	font-weight: 950;
	letter-spacing: -.05em;
}

.fsv-union-partner-card__date small {
	display: block;
	margin-top: 10px;
	color: rgba(255,255,255,.78);
	font-size: 12px;
	font-weight: 900;
	letter-spacing: .1em;
	text-transform: uppercase;
}

.fsv-union-partner-card__claim {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	width: 100%;
	margin-top: 18px;
	padding: 13px 14px;
	border-radius: 999px;
	color: #fff;
	background: rgba(244,196,0,.08);
	border: 1px solid rgba(244,196,0,.28);
	font-size: 13px;
	font-weight: 950;
	text-transform: uppercase;
	letter-spacing: .04em;
}

.fsv-union-partner-card__claim .fsv63-fa-icon { color: var(--union-yellow); }

/* Body */
.fsv-union-body {
	padding: clamp(44px, 6vw, 80px) 0 clamp(70px, 8vw, 110px);
	background:
		radial-gradient(circle at 12% 42%, rgba(244,196,0,.08), transparent 28%),
		radial-gradient(circle at 84% 78%, rgba(24,99,210,.16), transparent 30%);
}

.fsv-union-banner {
	position: relative;
	margin: 0 0 clamp(34px, 5vw, 58px);
	padding: 10px;
	border-radius: 24px;
	background: linear-gradient(90deg, var(--union-yellow), #1c65bd, #d41f2b);
	box-shadow: 0 30px 70px rgba(0,0,0,.28);
}

.fsv-union-banner img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 16px;
	background: #fff;
}

.fsv-union-section-head {
	display: flex;
	align-items: flex-start;
	gap: 18px;
	margin-bottom: 28px;
}

.fsv-union-section-head > span {
	width: 58px;
	height: 58px;
	border-radius: 18px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--union-yellow);
	font-size: 25px;
	background: rgba(244,196,0,.1);
	border: 1px solid rgba(244,196,0,.34);
	box-shadow: 0 16px 34px rgba(0,0,0,.18);
	flex: 0 0 auto;
}

.fsv-union-section-head p {
	margin: 0 0 6px;
	color: var(--union-yellow);
	font-size: 12px;
	font-weight: 950;
	text-transform: uppercase;
	letter-spacing: .14em;
}

.fsv-union-section-head h2 {
	margin: 0;
	color: #fff;
	font-size: clamp(32px, 4vw, 56px);
	line-height: 1;
	font-weight: 950;
	letter-spacing: -.045em;
	text-transform: uppercase;
}

.fsv-union-section-head--compact {
	margin-top: 8px;
}

.fsv-union-intro,
.fsv-union-bridge,
.fsv-union-projects,
.fsv-union-quote,
.fsv-union-cta {
	margin-top: 26px;
}

.fsv-union-focus-grid {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 14px;
}

.fsv-union-focus-card,
.fsv-union-project-card,
.fsv-union-bridge,
.fsv-union-quote,
.fsv-union-cta a {
	border: 1px solid var(--union-line);
	background:
		linear-gradient(180deg, rgba(12,42,88,.78), rgba(5,18,40,.64));
	box-shadow: 0 22px 54px rgba(0,0,0,.22);
	backdrop-filter: blur(8px);
}

.fsv-union-focus-card {
	position: relative;
	min-height: 250px;
	padding: 24px 20px;
	border-radius: 22px;
	overflow: hidden;
}

.fsv-union-focus-card::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 5px;
	background: var(--union-yellow);
	box-shadow: 0 0 18px rgba(244,196,0,.4);
}

.fsv-union-focus-card__icon {
	width: 54px;
	height: 54px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 18px;
	border-radius: 18px;
	color: var(--union-yellow);
	font-size: 22px;
	background: rgba(255,255,255,.06);
	border: 1px solid rgba(255,255,255,.12);
}

.fsv-union-focus-card h3,
.fsv-union-project-card h3 {
	margin: 0 0 10px;
	color: #fff;
	font-size: 18px;
	line-height: 1.15;
	font-weight: 950;
	letter-spacing: -.02em;
}

.fsv-union-focus-card p,
.fsv-union-project-card p,
.fsv-union-bridge p,
.fsv-union-quote blockquote,
.fsv-union-quote cite,
.fsv-union-cta small {
	color: var(--union-muted);
}

.fsv-union-focus-card p,
.fsv-union-project-card p {
	margin: 0;
	font-size: 14px;
	line-height: 1.58;
	font-weight: 600;
}

/* Bridge */
.fsv-union-bridge {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(320px, 460px);
	gap: 34px;
	align-items: center;
	padding: clamp(28px, 4vw, 44px);
	border-radius: 28px;
}

.fsv-union-bridge h2 {
	margin: 0 0 16px;
	color: #fff;
	font-size: clamp(34px, 4vw, 60px);
	line-height: .98;
	font-weight: 950;
	letter-spacing: -.05em;
	text-transform: uppercase;
}

.fsv-union-bridge p:not(.fsv-union-kicker) {
	max-width: 720px;
	margin: 0;
	font-size: 17px;
	line-height: 1.72;
	font-weight: 600;
}

.fsv-union-pipeline {
	display: grid;
	grid-template-columns: 1fr auto 1fr auto 1fr;
	gap: 10px;
	align-items: center;
	padding: 18px;
	border-radius: 24px;
	background: rgba(2,10,24,.3);
	border: 1px solid rgba(255,255,255,.1);
}

.fsv-union-pipeline div {
	min-height: 104px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 16px 12px;
	border-radius: 18px;
	background: rgba(255,255,255,.06);
	border: 1px solid rgba(255,255,255,.1);
}

.fsv-union-pipeline strong {
	color: #fff;
	font-size: 15px;
	font-weight: 950;
	text-transform: uppercase;
}

.fsv-union-pipeline span {
	margin-top: 7px;
	color: var(--union-yellow);
	font-size: 12px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .04em;
}

.fsv-union-pipeline i {
	color: var(--union-yellow);
	font-style: normal;
	font-size: 19px;
}

/* Projekte */
.fsv-union-project-grid {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 14px;
}

.fsv-union-project-card {
	padding: 24px 18px;
	border-radius: 22px;
	text-align: center;
}

.fsv-union-project-card > div {
	width: 62px;
	height: 62px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 16px;
	border-radius: 50%;
	color: #061225;
	font-size: 25px;
	background: linear-gradient(180deg, #ffe064, var(--union-yellow));
	box-shadow: 0 18px 38px rgba(244,196,0,.16);
}

/* Quote */
.fsv-union-quote {
	position: relative;
	display: grid;
	grid-template-columns: 72px minmax(0, 1fr);
	gap: 22px;
	padding: clamp(30px, 4vw, 52px);
	border-radius: 28px;
	overflow: hidden;
}

.fsv-union-quote::after {
	content: "FSV";
	position: absolute;
	right: 36px;
	bottom: -12px;
	color: rgba(244,196,0,.06);
	font-size: 170px;
	line-height: .75;
	font-weight: 950;
	letter-spacing: -.08em;
}

.fsv-union-quote__mark {
	color: var(--union-yellow);
	font-family: Georgia, serif;
	font-size: 92px;
	line-height: .8;
	font-weight: 900;
}

.fsv-union-quote blockquote {
	position: relative;
	z-index: 1;
	margin: 0;
	font-size: clamp(19px, 2vw, 27px);
	line-height: 1.62;
	font-weight: 650;
	font-style: italic;
}

.fsv-union-quote cite {
	display: block;
	position: relative;
	z-index: 1;
	margin-top: 20px;
	font-size: 14px;
	line-height: 1.35;
	font-weight: 900;
	font-style: normal;
}

/* CTA */
.fsv-union-cta {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.fsv-union-cta a {
	position: relative;
	display: grid;
	grid-template-columns: 56px minmax(0, 1fr);
	gap: 16px;
	align-items: center;
	min-height: 132px;
	padding: 24px;
	border-radius: 24px;
	transition: transform .2s ease, border-color .2s ease, background .2s ease;
}

.fsv-union-cta a:hover {
	transform: translateY(-3px);
	border-color: rgba(244,196,0,.46);
	text-decoration: none;
}

.fsv-union-cta span {
	grid-row: span 2;
	width: 56px;
	height: 56px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 18px;
	color: var(--union-yellow);
	font-size: 22px;
	background: rgba(244,196,0,.1);
	border: 1px solid rgba(244,196,0,.26);
}

.fsv-union-cta strong {
	align-self: end;
	color: #fff;
	font-size: 18px;
	line-height: 1.1;
	font-weight: 950;
	text-transform: uppercase;
}

.fsv-union-cta small {
	align-self: start;
	font-size: 13px;
	line-height: 1.4;
	font-weight: 650;
}

/* Parent Theme Content-Reset */
.fsv-union-page h1,
.fsv-union-page h2,
.fsv-union-page h3,
.fsv-union-page p,
.fsv-union-page blockquote,
.fsv-union-page figure {
	font-family: inherit;
}

/* Responsive */
@media (max-width: 1199px) {
	.fsv-union-hero__inner,
	.fsv-union-bridge {
		grid-template-columns: 1fr;
	}

	.fsv-union-partner-card {
		max-width: 520px;
	}

	.fsv-union-focus-grid,
	.fsv-union-project-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 860px) {
	.fsv-union-hero {
		min-height: auto;
	}

	.fsv-union-hero::after {
		background:
			linear-gradient(180deg, rgba(3,13,29,.9) 0%, rgba(3,13,29,.88) 100%),
			linear-gradient(90deg, rgba(3,13,29,.94), rgba(3,13,29,.58));
	}

	.fsv-union-hero__inner {
		gap: 34px;
		padding-top: 74px;
		padding-bottom: 64px;
	}

	.fsv-union-hero h1 {
		font-size: clamp(42px, 12vw, 68px);
	}

	.fsv-union-hero__lead {
		font-size: 17px;
	}

	.fsv-union-focus-grid,
	.fsv-union-project-grid,
	.fsv-union-cta {
		grid-template-columns: 1fr;
	}

	.fsv-union-focus-card {
		min-height: auto;
	}

	.fsv-union-pipeline {
		grid-template-columns: 1fr;
	}

	.fsv-union-pipeline i {
		transform: rotate(90deg);
		justify-self: center;
	}

	.fsv-union-quote {
		grid-template-columns: 1fr;
		gap: 4px;
	}

	.fsv-union-quote__mark {
		font-size: 70px;
	}
}

@media (max-width: 560px) {
	.fsv-union-actions,
	.fsv-union-btn {
		width: 100%;
	}

	.fsv-union-btn {
		min-height: 54px;
	}

	.fsv-union-partner-card {
		padding: 22px;
		border-radius: 22px;
	}

	.fsv-union-partner-card__clubs {
		grid-template-columns: 1fr;
	}

	.fsv-union-partner-card__clubs b {
		font-size: 26px;
	}

	.fsv-union-partner-card__clubs span {
		min-height: 70px;
	}

	.fsv-union-section-head {
		gap: 14px;
	}

	.fsv-union-section-head > span {
		width: 48px;
		height: 48px;
		border-radius: 15px;
		font-size: 21px;
	}

	.fsv-union-section-head h2,
	.fsv-union-bridge h2 {
		font-size: 32px;
	}

	.fsv-union-banner {
		padding: 6px;
		border-radius: 18px;
	}

	.fsv-union-banner img {
		border-radius: 12px;
	}

	.fsv-union-bridge,
	.fsv-union-quote {
		border-radius: 22px;
	}

	.fsv-union-cta a {
		grid-template-columns: 48px minmax(0, 1fr);
		min-height: 116px;
		padding: 20px;
	}

	.fsv-union-cta span {
		width: 48px;
		height: 48px;
		border-radius: 15px;
	}
}

/* ------------------------------------------------------------
   FSV63 Union-Koop: Text- und Kartenfeinschliff
------------------------------------------------------------ */
.fsv-union-focus-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.fsv-union-project-grid {
	grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
}

.fsv-union-focus-card h3,
.fsv-union-project-card h3,
.fsv-union-pipeline strong,
.fsv-union-pipeline span {
	overflow-wrap: anywhere;
	hyphens: auto;
}

.fsv-union-focus-card {
	min-height: 230px;
}

.fsv-union-project-card {
	min-height: 210px;
}

.fsv-union-project-card h3 {
	font-size: 17px;
}

@media (max-width: 1100px) {
	.fsv-union-focus-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 860px) {
	.fsv-union-focus-grid {
		grid-template-columns: 1fr;
	}
}

/* ------------------------------------------------------------
   FSV63 Union-Koop: finaler Overflow-/Lesbarkeits-Fix
   Verhindert abgeschnittene Karten, zu breite Headlines
   und unruhige Textumbrüche auf Desktop/Tablet.
------------------------------------------------------------ */
.fsv-union-page,
.fsv-union-page * {
	box-sizing: border-box;
}

.fsv-union-page {
	max-width: 100%;
	overflow-x: clip;
}

.fsv-union-page .container {
	width: min(1180px, calc(100% - 40px));
	max-width: 1180px;
	padding-left: 0;
	padding-right: 0;
	margin-left: auto;
	margin-right: auto;
}

.fsv-union-section-head,
.fsv-union-section-head > div,
.fsv-union-focus-card,
.fsv-union-project-card,
.fsv-union-bridge,
.fsv-union-quote,
.fsv-union-cta a,
.fsv-union-pipeline,
.fsv-union-pipeline div {
	min-width: 0;
}

.fsv-union-hero h1,
.fsv-union-section-head h2,
.fsv-union-bridge h2,
.fsv-union-focus-card h3,
.fsv-union-project-card h3,
.fsv-union-pipeline strong,
.fsv-union-pipeline span,
.fsv-union-quote blockquote {
	max-width: 100%;
	overflow-wrap: anywhere;
	word-break: normal;
	hyphens: auto;
}

.fsv-union-section-head h2 {
	font-size: clamp(30px, 3.25vw, 48px);
	line-height: 1.03;
	text-wrap: balance;
}

.fsv-union-focus-grid,
.fsv-union-project-grid {
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 18px;
}

.fsv-union-focus-card,
.fsv-union-project-card {
	overflow: visible;
	min-height: 0;
	height: auto;
}

.fsv-union-focus-card {
	padding: 24px 22px 26px 24px;
}

.fsv-union-focus-card h3,
.fsv-union-project-card h3 {
	font-size: clamp(17px, 1.25vw, 20px);
	line-height: 1.18;
	letter-spacing: -.015em;
}

.fsv-union-focus-card p,
.fsv-union-project-card p {
	font-size: 14px;
	line-height: 1.55;
}

.fsv-union-project-card {
	padding: 24px 20px;
}

.fsv-union-bridge {
	grid-template-columns: minmax(0, 1fr);
	gap: 28px;
}

.fsv-union-pipeline {
	width: 100%;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 14px;
}

.fsv-union-pipeline i {
	display: none;
}

.fsv-union-pipeline div {
	min-height: 98px;
	padding: 16px 14px;
}

.fsv-union-pipeline strong {
	font-size: 14px;
	line-height: 1.15;
}

.fsv-union-pipeline span {
	font-size: 11px;
	line-height: 1.2;
}

.fsv-union-quote {
	grid-template-columns: 56px minmax(0, 1fr);
}

.fsv-union-quote blockquote {
	font-size: clamp(18px, 1.55vw, 23px);
	line-height: 1.55;
}

@media (max-width: 1024px) {
	.fsv-union-focus-grid,
	.fsv-union-project-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 760px) {
	.fsv-union-page .container {
		width: min(100% - 28px, 1180px);
	}

	.fsv-union-section-head {
		align-items: flex-start;
	}

	.fsv-union-section-head h2 {
		font-size: clamp(28px, 9vw, 38px);
	}

	.fsv-union-focus-grid,
	.fsv-union-project-grid,
	.fsv-union-pipeline {
		grid-template-columns: 1fr;
	}

	.fsv-union-pipeline div {
		min-height: 82px;
	}

	.fsv-union-quote {
		grid-template-columns: 1fr;
	}
}
