/* =========================================================
   FSV 63 Single Player – Senior-Level Child Theme Design
   ========================================================= */

body.single-sp_player {
	background:
		radial-gradient(circle at 10% 0%, rgba(240, 194, 50, 0.12), rgba(240, 194, 50, 0) 28%),
		linear-gradient(180deg, #071d43 0%, #061836 100%);
	color: #fff;
}

body.single-sp_player .site-content {
	background:
		linear-gradient(135deg, rgba(255,255,255,.03) 25%, transparent 25%) 0 0 / 42px 42px,
		linear-gradient(180deg, #0a2555 0%, #061a3b 100%);
	color: #fff;
}

/* Hero */
.fsv-player-hero {
	position: relative;
	overflow: hidden;
	min-height: 560px;
	background: #071d43;
	border-bottom: 2px solid #f0c232;
}

.fsv-player-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(90deg, rgba(3, 17, 42, .98) 0%, rgba(5, 31, 73, .91) 42%, rgba(5, 31, 73, .62) 68%, rgba(5, 31, 73, .38) 100%),
		var(--fsv-player-hero-bg) center center / cover no-repeat;
	transform: scale(1.02);
}

.fsv-player-hero::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 90px;
	background:
		repeating-linear-gradient(90deg, rgba(255,255,255,.12) 0 2px, transparent 2px 8px);
	opacity: .25;
	pointer-events: none;
}

.fsv-player-hero__inner {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: minmax(260px, 390px) minmax(0, 1fr) minmax(270px, 360px);
	gap: 42px;
	align-items: center;
	min-height: 560px;
	padding-top: 60px;
	padding-bottom: 58px;
}

.fsv-player-hero__media {
	position: relative;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	min-height: 460px;
}

.fsv-player-hero__number-bg {
	position: absolute;
	left: -20px;
	top: 28px;
	font-size: clamp(150px, 15vw, 260px);
	line-height: .8;
	font-weight: 950;
	color: rgba(255,255,255,.07);
	letter-spacing: -.08em;
	z-index: 0;
}

.fsv-player-hero__photo {
	position: relative;
	z-index: 1;
	margin: 0;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	width: 100%;
}

.fsv-player-hero__photo img {
	display: block;
	max-height: 500px;
	width: auto;
	max-width: 100%;
	object-fit: contain;
	filter: drop-shadow(0 28px 38px rgba(0,0,0,.34));
}

.fsv-player-hero__main {
	min-width: 0;
}

.fsv-player-hero__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 18px;
	color: #f0c232;
	font-size: 14px;
	line-height: 1;
	font-weight: 900;
	letter-spacing: .12em;
	text-transform: uppercase;
}

.fsv-player-hero__eyebrow::before {
	content: "";
	width: 48px;
	height: 3px;
	border-radius: 99px;
	background: #f0c232;
}

.fsv-player-hero__name {
	display: flex;
	align-items: center;
	gap: 22px;
	margin: 0 0 24px;
	color: #fff;
	text-transform: uppercase;
}

.fsv-player-hero__number {
	display: block;
	font-size: clamp(74px, 8vw, 132px);
	line-height: .78;
	font-weight: 950;
	letter-spacing: -.06em;
	color: #fff;
	text-shadow: 0 14px 30px rgba(0,0,0,.26);
}

.fsv-player-hero__name-text {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.fsv-player-hero__firstname {
	color: rgba(255,255,255,.92);
	font-size: clamp(28px, 3vw, 46px);
	line-height: .95;
	font-weight: 500;
	letter-spacing: -.02em;
}

.fsv-player-hero__lastname {
	color: #f0c232;
	font-size: clamp(42px, 5vw, 82px);
	line-height: .92;
	font-weight: 900;
	letter-spacing: -.045em;
}

.fsv-player-hero__badges {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 28px;
}

.fsv-player-hero__badges span {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-height: 38px;
	padding: 9px 14px;
	border: 1px solid rgba(255,255,255,.16);
	border-radius: 999px;
	background: rgba(3, 17, 42, .42);
	backdrop-filter: blur(6px);
	color: rgba(255,255,255,.9);
	font-size: 14px;
	line-height: 1;
	font-weight: 800;
}

.fsv-player-hero__flag {
	display: inline-block;
	width: 22px;
	height: 14px;
	object-fit: cover;
	border-radius: 2px;
	box-shadow: 0 3px 8px rgba(0,0,0,.18);
}

.fsv-player-hero__chips {
	display: grid;
	grid-template-columns: repeat(3, minmax(110px, 1fr));
	gap: 14px;
	max-width: 560px;
}

.fsv-player-hero__chip {
	padding: 18px 18px 16px;
	border: 1px solid rgba(255,255,255,.13);
	border-radius: 18px;
	background: rgba(3, 17, 42, .52);
	box-shadow: 0 18px 34px rgba(0,0,0,.18);
	backdrop-filter: blur(6px);
}

.fsv-player-hero__chip strong {
	display: block;
	margin-bottom: 6px;
	color: #fff;
	font-size: 30px;
	line-height: 1;
	font-weight: 950;
}

.fsv-player-hero__chip span {
	display: block;
	color: rgba(255,255,255,.66);
	font-size: 12px;
	line-height: 1.2;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .06em;
}

.fsv-player-hero__panel {
	padding: 26px 28px;
	border: 1px solid rgba(255,255,255,.14);
	border-radius: 24px;
	background: linear-gradient(180deg, rgba(3,17,42,.68), rgba(3,17,42,.42));
	box-shadow: 0 26px 50px rgba(0,0,0,.24);
	backdrop-filter: blur(8px);
}

.fsv-player-hero__panel-title {
	margin-bottom: 20px;
	color: #f0c232;
	font-size: 13px;
	line-height: 1;
	font-weight: 900;
	letter-spacing: .11em;
	text-transform: uppercase;
}

.fsv-player-hero__panel-row {
	display: grid;
	grid-template-columns: minmax(90px, .8fr) minmax(0, 1.2fr);
	gap: 14px;
	align-items: baseline;
	padding: 15px 0;
	border-bottom: 1px solid rgba(255,255,255,.1);
}

.fsv-player-hero__panel-row:last-child {
	border-bottom: 0;
}

.fsv-player-hero__panel-row span {
	color: rgba(255,255,255,.55);
	font-size: 12px;
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .06em;
}

.fsv-player-hero__panel-row strong {
	color: #fff;
	font-size: 15px;
	line-height: 1.35;
	font-weight: 800;
}

/* Tabs */
body.single-sp_player .content-filter {
	margin: 0;
	background: #20252e;
	border-top: 1px solid rgba(255,255,255,.06);
	border-bottom: 1px solid rgba(97,169,255,.22);
}

body.single-sp_player .content-filter__inner {
	border: 0;
}

body.single-sp_player .content-filter__list {
	display: flex;
	justify-content: center;
}

body.single-sp_player .content-filter__item {
	border-left: 1px solid rgba(255,255,255,.06);
}

body.single-sp_player .content-filter__item:last-child {
	border-right: 1px solid rgba(255,255,255,.06);
}

body.single-sp_player .content-filter__link {
	min-height: 88px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 16px 42px;
	color: rgba(255,255,255,.86);
	font-weight: 900;
	text-transform: uppercase;
	letter-spacing: .02em;
	transition: background-color .2s ease, color .2s ease;
}

body.single-sp_player .content-filter__link small {
	margin-bottom: 4px;
	color: rgba(255,255,255,.45);
	font-size: 10px;
	line-height: 1;
	font-weight: 900;
	letter-spacing: .08em;
	text-transform: uppercase;
}

body.single-sp_player .content-filter__item--active .content-filter__link {
	position: relative;
	color: #fff;
	background: rgba(97,169,255,.08);
}

body.single-sp_player .content-filter__item--active .content-filter__link::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 5px;
	background: #61a9ff;
}

/* Content cards */
body.single-sp_player .site-content .card,
body.single-sp_player .site-content .sp-template {
	border-radius: 18px;
	overflow: hidden;
	background: rgba(35, 39, 47, .94);
	border: 1px solid rgba(116,161,235,.16);
	box-shadow: 0 18px 38px rgba(0,0,0,.18);
}

body.single-sp_player .site-content .card__header {
	border-left: 7px solid #61a9ff;
	background: rgba(38,42,50,.96);
}

body.single-sp_player .site-content .card__header h4,
body.single-sp_player .site-content .sp-table-caption {
	color: #61a9ff;
	text-transform: uppercase;
}

body.single-sp_player .site-content table,
body.single-sp_player .site-content .table {
	color: rgba(255,255,255,.9);
}

body.single-sp_player .site-content th {
	color: rgba(255,255,255,.68);
	text-transform: uppercase;
}

body.single-sp_player .site-content td {
	color: rgba(255,255,255,.9);
}

body.single-sp_player .sp-player-details dt {
	color: rgba(255,255,255,.58);
	text-transform: uppercase;
	letter-spacing: .04em;
}

body.single-sp_player .sp-player-details dd {
	color: #fff;
	font-weight: 800;
}

/* Responsive */
@media (max-width: 1199px) {
	.fsv-player-hero__inner {
		grid-template-columns: minmax(220px, 320px) minmax(0, 1fr);
	}

	.fsv-player-hero__panel {
		grid-column: 1 / -1;
	}

	.fsv-player-hero__panel {
		display: grid;
		grid-template-columns: 180px repeat(3, minmax(0, 1fr));
		gap: 0 22px;
		align-items: start;
	}

	.fsv-player-hero__panel-title {
		grid-row: span 2;
	}

	.fsv-player-hero__panel-row {
		padding: 10px 0;
	}
}

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

	.fsv-player-hero__inner {
		grid-template-columns: 1fr;
		gap: 24px;
		min-height: auto;
		padding-top: 42px;
		padding-bottom: 42px;
	}

	.fsv-player-hero__media {
		min-height: 340px;
		order: 2;
	}

	.fsv-player-hero__main {
		order: 1;
	}

	.fsv-player-hero__panel {
		order: 3;
		display: block;
	}

	.fsv-player-hero__photo img {
		max-height: 360px;
	}

	body.single-sp_player .content-filter__list {
		justify-content: flex-start;
		overflow-x: auto;
	}

	body.single-sp_player .content-filter__link {
		min-height: 72px;
		padding: 14px 28px;
		white-space: nowrap;
	}
}

@media (max-width: 767px) {
	.fsv-player-hero__name {
		align-items: flex-start;
		gap: 14px;
	}

	.fsv-player-hero__number {
		font-size: 58px;
	}

	.fsv-player-hero__chips {
		grid-template-columns: 1fr;
	}

	.fsv-player-hero__badges span {
		width: 100%;
	}

	.fsv-player-hero__media {
		min-height: 280px;
	}

	.fsv-player-hero__photo img {
		max-height: 300px;
	}
}


/* v2: Hero-Feinschliff
   - Name darf nicht vom Kurzprofil abgeschnitten werden
   - Kurzprofil rutscht auf mittelgroßen Desktops nach unten
   - Typografie etwas ruhiger und kontrollierter
*/
@media (min-width: 1200px) {
	.fsv-player-hero__inner {
		grid-template-columns: minmax(230px, 330px) minmax(0, 1fr) minmax(250px, 330px);
		gap: clamp(24px, 3vw, 42px);
	}

	.fsv-player-hero__main {
		max-width: 660px;
	}

	.fsv-player-hero__name {
		gap: 18px;
	}

	.fsv-player-hero__number {
		font-size: clamp(70px, 6.2vw, 116px);
		letter-spacing: -0.065em;
	}

	.fsv-player-hero__firstname {
		font-size: clamp(25px, 2.2vw, 40px);
	}

	.fsv-player-hero__lastname {
		font-size: clamp(38px, 4.1vw, 68px);
		line-height: 0.95;
		letter-spacing: -0.05em;
		max-width: 100%;
		overflow-wrap: anywhere;
	}

	.fsv-player-hero__panel {
		padding: 24px 24px;
	}
}

@media (min-width: 1200px) and (max-width: 1450px) {
	.fsv-player-hero__inner {
		grid-template-columns: minmax(220px, 300px) minmax(0, 1fr) minmax(230px, 300px);
		gap: 24px;
	}

	.fsv-player-hero__number {
		font-size: clamp(62px, 5.2vw, 92px);
	}

	.fsv-player-hero__firstname {
		font-size: clamp(24px, 2vw, 34px);
	}

	.fsv-player-hero__lastname {
		font-size: clamp(34px, 3.4vw, 54px);
	}

	.fsv-player-hero__badges span {
		font-size: 13px;
		padding: 8px 12px;
	}

	.fsv-player-hero__chip {
		padding: 15px 16px 14px;
	}

	.fsv-player-hero__chip strong {
		font-size: 26px;
	}
}

/* Auf kleineren Desktopbreiten das Kurzprofil unter den Namen setzen,
   damit lange Namen nie abgeschnitten werden. */
@media (min-width: 992px) and (max-width: 1199px) {
	.fsv-player-hero__inner {
		grid-template-columns: minmax(220px, 300px) minmax(0, 1fr);
		gap: 30px;
	}

	.fsv-player-hero__panel {
		grid-column: 2;
		display: block;
		max-width: 100%;
	}

	.fsv-player-hero__number {
		font-size: clamp(58px, 6vw, 88px);
	}

	.fsv-player-hero__lastname {
		font-size: clamp(36px, 4.6vw, 58px);
		overflow-wrap: anywhere;
	}
}

/* Header/Hero wirkt hochwertiger, wenn die Bildmarke im Hintergrund etwas ruhiger ist. */
.fsv-player-hero::before {
	background:
		linear-gradient(90deg, rgba(3, 17, 42, .98) 0%, rgba(5, 31, 73, .93) 44%, rgba(5, 31, 73, .68) 70%, rgba(5, 31, 73, .46) 100%),
		var(--fsv-player-hero-bg) center center / cover no-repeat;
	filter: saturate(1.08);
}

.fsv-player-hero__badges,
.fsv-player-hero__chips,
.fsv-player-hero__panel {
	position: relative;
	z-index: 2;
}
