/* ------------------------------------------------------------
   FSV 63 Luckenwalde – Freizeitliga / FSV Oldies
------------------------------------------------------------ */

:root {
	--frei-blue-950: #05142b;
	--frei-blue-900: #071f43;
	--frei-blue-800: #0b2d5c;
	--frei-blue-700: #123d78;
	--frei-yellow: #ffdc21;
	--frei-yellow-2: #f5c400;
	--frei-white: #ffffff;
	--frei-muted: #aebbd0;
	--frei-border: rgba(255,255,255,.16);
	--frei-shadow: 0 24px 70px rgba(0,0,0,.28);
}

.fsv63-freizeit {
	position: relative;
	isolation: isolate;
	background:
		radial-gradient(circle at 12% 10%, rgba(255, 220, 33, .18), transparent 30%),
		radial-gradient(circle at 88% 26%, rgba(43, 108, 214, .32), transparent 34%),
		linear-gradient(180deg, var(--frei-blue-950) 0%, var(--frei-blue-900) 46%, #061225 100%);
	color: #fff;
	overflow: hidden;
}

.fsv63-freizeit::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -1;
	pointer-events: none;
	background-image:
		linear-gradient(135deg, rgba(255,255,255,.035) 25%, transparent 25%, transparent 50%, rgba(255,255,255,.035) 50%, rgba(255,255,255,.035) 75%, transparent 75%, transparent);
	background-size: 38px 38px;
	opacity: .28;
}

.fsv63-freizeit * { box-sizing: border-box; }

.freizeit-container {
	width: min(1180px, calc(100% - 36px));
	margin: 0 auto;
}

.freizeit-hero {
	position: relative;
	min-height: 720px;
	display: flex;
	align-items: center;
	isolation: isolate;
	color: var(--frei-white);
}

.freizeit-hero__bg {
	position: absolute;
	inset: 0;
	z-index: -2;
	background:
		linear-gradient(105deg, rgba(5,20,43,.96) 0%, rgba(7,31,67,.9) 42%, rgba(7,31,67,.62) 72%, rgba(5,20,43,.92) 100%),
		var(--freizeit-hero-image, linear-gradient(135deg, #071f43, #123d78));
	background-size: cover;
	background-position: center;
	filter: saturate(1.05);
}

.freizeit-hero::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 7px;
	background: linear-gradient(90deg, transparent, var(--frei-yellow), transparent);
	z-index: 2;
}

.freizeit-hero__grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(420px, .92fr);
	gap: 42px;
	align-items: center;
	padding: 96px 0 92px;
}

.freizeit-eyebrow,
.freizeit-kicker {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: 12px;
	font-weight: 950;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--frei-yellow);
}

.freizeit-hero h1 {
	margin: 18px 0 18px;
	font-size: clamp(58px, 9vw, 118px);
	line-height: .86;
	font-weight: 950;
	letter-spacing: -.07em;
	color: #fff;
	text-transform: uppercase;
}

.freizeit-hero p {
	max-width: 670px;
	margin: 0;
	font-size: clamp(18px, 2.2vw, 24px);
	line-height: 1.55;
	color: rgba(255,255,255,.84);
}

.freizeit-hero__actions,
.freizeit-hero-facts,
.freizeit-link-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
}

.freizeit-hero__actions { margin-top: 34px; }

.freizeit-btn,
.freizeit-inline-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	font-weight: 950;
	text-decoration: none !important;
	transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.freizeit-btn {
	min-height: 54px;
	padding: 15px 22px;
	border-radius: 999px;
}

.freizeit-btn:hover,
.freizeit-link-grid a:hover { transform: translateY(-3px); }

.freizeit-btn--primary {
	color: #08162b !important;
	background: linear-gradient(135deg, var(--frei-yellow), var(--frei-yellow-2));
	box-shadow: 0 18px 36px rgba(255,220,33,.22);
}

.freizeit-btn--ghost {
	color: #fff !important;
	background: rgba(255,255,255,.08);
	border: 1px solid rgba(255,255,255,.24);
	backdrop-filter: blur(12px);
}

.freizeit-hero-facts {
	margin-top: 34px;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.freizeit-hero-facts > div {
	position: relative;
	min-height: 132px;
	padding: 18px;
	border-radius: 24px;
	background: linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.065));
	border: 1px solid rgba(255,255,255,.18);
	box-shadow: 0 18px 42px rgba(0,0,0,.18);
	overflow: hidden;
}

.freizeit-hero-facts > div::before,
.freizeit-roster-card::before,
.freizeit-contact-box::before {
	content: "";
	position: absolute;
	inset: 0 auto 0 0;
	width: 5px;
	background: linear-gradient(180deg, var(--frei-yellow), transparent);
}

.freizeit-hero-facts span,
.freizeit-panel__icon,
.freizeit-contact-person > span,
.freizeit-link-grid a > span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 auto;
}

.freizeit-hero-facts span {
	width: 42px;
	height: 42px;
	border-radius: 14px;
	background: rgba(255,220,33,.14);
	color: var(--frei-yellow);
	margin-bottom: 14px;
}

.freizeit-hero-facts strong,
.freizeit-hero-facts small {
	display: block;
}

.freizeit-hero-facts strong {
	font-size: 18px;
	line-height: 1.15;
	color: #fff;
}

.freizeit-hero-facts small {
	margin-top: 6px;
	font-size: 13px;
	line-height: 1.45;
	color: rgba(255,255,255,.66);
}

.freizeit-hero-photo,
.freizeit-success-photo {
	position: relative;
	margin: 0;
	border-radius: 34px;
	background: rgba(255,255,255,.08);
	border: 1px solid rgba(255,255,255,.22);
	box-shadow: var(--frei-shadow);
	overflow: hidden;
}

.freizeit-hero-photo img,
.freizeit-success-photo img {
	display: block;
	width: 100%;
	height: auto;
}

.freizeit-hero-photo::before,
.freizeit-success-photo::before {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	box-shadow: inset 0 0 0 1px rgba(255,255,255,.1), inset 0 -90px 100px rgba(5,20,43,.26);
}

.freizeit-hero-photo figcaption,
.freizeit-success-photo figcaption {
	position: absolute;
	left: 22px;
	bottom: 18px;
	padding: 9px 13px;
	border-radius: 999px;
	background: rgba(5,20,43,.82);
	color: #fff;
	font-size: 12px;
	font-weight: 950;
	letter-spacing: .08em;
	text-transform: uppercase;
	backdrop-filter: blur(10px);
}

.freizeit-section {
	position: relative;
	padding: 82px 0;
}

.freizeit-section--team,
.freizeit-section--links {
	background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
}

.freizeit-section--blue {
	background:
		radial-gradient(circle at 86% 18%, rgba(255,220,33,.13), transparent 26%),
		linear-gradient(135deg, #071f43 0%, #0b2d5c 100%);
}

.freizeit-section--success {
	background: linear-gradient(180deg, #f7f9fd 0%, #ffffff 100%);
	color: #071f43;
}

.freizeit-section--contact {
	background: linear-gradient(180deg, rgba(255,220,33,.08), rgba(255,255,255,.02));
}

.freizeit-section-head {
	max-width: 820px;
	margin-bottom: 34px;
}

.freizeit-section-head--center {
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}

.freizeit-section-head h2,
.freizeit-panel h2,
.freizeit-success-grid h2,
.freizeit-contact-box h2 {
	margin: 12px 0 12px;
	font-size: clamp(32px, 4.8vw, 62px);
	line-height: .98;
	letter-spacing: -.055em;
	font-weight: 950;
	color: #fff;
}

.freizeit-section--success h2,
.freizeit-section--success .freizeit-titles strong {
	color: #071f43;
}

.freizeit-section-head p,
.freizeit-panel p,
.freizeit-contact-box p {
	margin: 0;
	font-size: 17px;
	line-height: 1.7;
	color: rgba(255,255,255,.72);
}

.freizeit-section--success p { color: #53627a; }

.freizeit-roster-card,
.freizeit-panel,
.freizeit-contact-box,
.freizeit-link-grid a {
	position: relative;
	border-radius: 30px;
	background: linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.07));
	border: 1px solid rgba(255,255,255,.16);
	box-shadow: 0 20px 60px rgba(0,0,0,.18);
	overflow: hidden;
}

.freizeit-roster-card {
	padding: 12px;
	display: grid;
	gap: 10px;
}

.freizeit-roster-row {
	display: grid;
	grid-template-columns: 180px 1fr;
	gap: 18px;
	align-items: start;
	padding: 20px 22px;
	border-radius: 22px;
	background: rgba(255,255,255,.06);
	border: 1px solid rgba(255,255,255,.1);
}

.freizeit-roster-row strong {
	color: var(--frei-yellow);
	font-size: 14px;
	font-weight: 950;
	letter-spacing: .08em;
	text-transform: uppercase;
}

.freizeit-roster-row span {
	color: rgba(255,255,255,.82);
	font-weight: 750;
	line-height: 1.55;
}

.freizeit-roster-row em { color: rgba(255,255,255,.62); }
.freizeit-roster-row--muted span { color: rgba(255,255,255,.66); }

.freizeit-info-grid {
	display: grid;
	grid-template-columns: minmax(0, .8fr) minmax(0, 1.2fr);
	gap: 24px;
	align-items: stretch;
}

.freizeit-panel {
	padding: 34px;
}

.freizeit-panel--training {
	background: linear-gradient(180deg, rgba(255,220,33,.16), rgba(255,255,255,.07));
}

.freizeit-panel__icon {
	width: 58px;
	height: 58px;
	border-radius: 18px;
	background: var(--frei-yellow);
	color: #071f43;
	font-size: 23px;
	margin-bottom: 22px;
}

.freizeit-panel p + p { margin-top: 18px; }

.freizeit-inline-link {
	margin-top: 24px;
	color: var(--frei-yellow) !important;
}

.freizeit-success-grid {
	display: grid;
	grid-template-columns: minmax(0, .88fr) minmax(360px, 1.12fr);
	gap: 34px;
	align-items: center;
}

.freizeit-section--success .freizeit-kicker { color: #0b2d5c; }

.freizeit-titles {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 16px;
	margin-top: 28px;
}

.freizeit-titles > div {
	position: relative;
	padding: 24px;
	border-radius: 26px;
	background: #fff;
	border: 1px solid rgba(7,31,67,.08);
	box-shadow: 0 20px 58px rgba(7,31,67,.11);
}

.freizeit-titles span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 64px;
	height: 64px;
	border-radius: 20px;
	background: #071f43;
	color: var(--frei-yellow);
	font-size: 20px;
	font-weight: 950;
	margin-bottom: 20px;
}

.freizeit-titles strong,
.freizeit-titles small {
	display: block;
}

.freizeit-titles strong {
	font-size: 22px;
	line-height: 1.15;
	font-weight: 950;
}

.freizeit-titles small {
	margin-top: 8px;
	color: #53627a;
	font-weight: 800;
	line-height: 1.45;
}

.freizeit-success-photo {
	border-color: rgba(7,31,67,.1);
	box-shadow: 0 22px 60px rgba(7,31,67,.16);
}

.freizeit-contact-box {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(320px, .58fr);
	gap: 28px;
	align-items: center;
	padding: 34px;
	background: linear-gradient(135deg, rgba(255,255,255,.13), rgba(255,255,255,.065));
}

.freizeit-contact-person {
	display: grid;
	grid-template-columns: 64px 1fr;
	gap: 18px;
	align-items: center;
	padding: 22px;
	border-radius: 24px;
	background: rgba(255,255,255,.08);
	border: 1px solid rgba(255,255,255,.14);
}

.freizeit-contact-person > span {
	width: 64px;
	height: 64px;
	border-radius: 20px;
	background: var(--frei-yellow);
	color: #071f43;
	font-size: 24px;
}

.freizeit-contact-person strong,
.freizeit-contact-person small,
.freizeit-contact-person a {
	display: block;
}

.freizeit-contact-person strong {
	font-size: 23px;
	font-weight: 950;
	color: #fff;
}

.freizeit-contact-person small {
	margin: 2px 0 8px;
	color: rgba(255,255,255,.6);
	font-weight: 800;
}

.freizeit-contact-person a {
	color: var(--frei-yellow) !important;
	font-weight: 900;
	text-decoration: none !important;
	word-break: break-word;
}

.freizeit-link-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.freizeit-link-grid a {
	min-height: 220px;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: space-between;
	padding: 26px;
	text-decoration: none !important;
	transition: transform .22s ease, box-shadow .22s ease;
}

.freizeit-link-grid a > span {
	width: 54px;
	height: 54px;
	border-radius: 17px;
	background: var(--frei-yellow);
	color: #071f43;
	font-size: 22px;
}

.freizeit-link-grid strong {
	margin-top: 22px;
	font-size: 21px;
	font-weight: 950;
	color: #fff;
}

.freizeit-link-grid small {
	margin-top: 6px;
	color: rgba(255,255,255,.66);
	font-weight: 750;
	line-height: 1.45;
}

.freizeit-link-grid b {
	position: absolute;
	right: 24px;
	bottom: 22px;
	color: var(--frei-yellow);
	font-size: 18px;
}

.fsv63-freizeit .fsv63-fa-icon { line-height: 1; }

@media (max-width: 1080px) {
	.freizeit-hero__grid,
	.freizeit-info-grid,
	.freizeit-success-grid,
	.freizeit-contact-box {
		grid-template-columns: 1fr;
	}

	.freizeit-hero { min-height: auto; }
	.freizeit-link-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 760px) {
	.freizeit-container { width: min(100% - 24px, 1180px); }
	.freizeit-hero__grid { padding: 68px 0 58px; gap: 26px; }
	.freizeit-hero h1 { font-size: clamp(46px, 17vw, 72px); }
	.freizeit-hero p { font-size: 17px; }
	.freizeit-hero__actions,
	.freizeit-btn { width: 100%; }
	.freizeit-hero-facts,
	.freizeit-titles,
	.freizeit-link-grid { grid-template-columns: 1fr; }
	.freizeit-section { padding: 58px 0; }
	.freizeit-roster-row { grid-template-columns: 1fr; gap: 8px; }
	.freizeit-contact-person { grid-template-columns: 1fr; }
	.freizeit-hero-photo,
	.freizeit-success-photo,
	.freizeit-roster-card,
	.freizeit-panel,
	.freizeit-contact-box,
	.freizeit-link-grid a { border-radius: 24px; }
}
