/*
 * Page Staff - Страница персонала (тренер, стафф)
 * 
 */

.player-page {
	background: var(--gray-50);
	min-height: 100vh;
	padding-bottom: 5rem;
}

/* ==========================================================================
   HERO SECTION
   ========================================================================== */

.player-hero {
	position: relative;
	height: 31rem;
	padding: 2.5rem 0;
	background: linear-gradient(
		165.07deg,
		var(--red-900, var(--red-900)) 0%,
		var(--red-800, var(--red-800)) 50%,
		var(--gray-800, var(--gray-800)) 100%
	);
	overflow: hidden;
	box-sizing: border-box;
}


/* ---------------------------------------------------
   Полупрозрачный декоративный слой на герое
   --------------------------------------------------- */
.player-hero__overlay {
	position: absolute;
	inset: 0;
	background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1620 432"><circle cx="100" cy="50" r="60" fill="rgba(255,255,255,0.05)"/><circle cx="1500" cy="400" r="100" fill="rgba(255,255,255,0.03)"/></svg>') no-repeat center;
	background-size: cover;
	opacity: 0.1;
}

.player-hero__content {
	position: relative;
	z-index: 2;
	display: flex;
	justify-content: center;
	width: 100%;
	height: 100%;
}

.player-hero__inner {
	width: 100%;
	max-width: var(--container-max-width);
	margin: 0 auto;
	padding: 1.25rem 2.5rem 0;
	display: flex;
	flex-direction: column;
	box-sizing: border-box;
}

.staff-hero__main {
	display: grid;
	grid-template-columns: 32% 68%;
	gap: 6rem;
	justify-content: space-between;
	align-items: stretch;
	min-height: 26.875rem;
}
/*---------------------------------------------------
Обёртка для фото: фиксированный квадрат с обводкой
--------------------------------------------------- */

.staff-photo-wrapper {
	width: 100%;
	max-width: 100%;
	height: 100%;
	margin: 0 auto;	
	border-radius: 2.25rem;
	overflow: hidden;
	display: flex;
	align-items: flex-end;
	justify-content: flex-start;
	border: 0.28125rem solid rgba(255, 255, 255, 0.15);
	box-shadow: 0 1.875rem 5.625rem rgba(77, 77, 77, 0.3);
}



.staff-photo-img {
	height: 100%;
	width: 100%;
	background: linear-gradient(180deg, var(--red-500) 0%, var(--red-100) 100%);
	object-fit: cover;
	object-position: center bottom;
	display: block;
	flex-shrink: 0;
}

.staff-photo-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(255, 255, 255, 0.1);
	color: rgba(255, 255, 255, 0.6);
	font-size: 0.875rem;
	text-align: center;
	padding: 1.25rem;
}

.staff-info-block {
	color: var(--color-white);
	padding-top: 8rem;
}

.staff-position-badge {
	display: inline-flex;
	align-items: center;
	padding: 0.5rem 1rem;
	background: var(--red-700);
	border-radius: 9999px;
	font-size: 0.875rem;
	font-weight: 400;
	line-height: 1.25rem;
	margin-bottom: 1.25rem;
}

.staff-title {
	margin: 0 0 1.5rem;
	font-size: 3.75rem;
	line-height: 4.5rem;
	font-weight: 700;
}

.staff-details-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1.5rem;
	padding-top: 4rem;
}

.staff-detail-item {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
}

.staff-detail-label {
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: rgba(255, 255, 255, 0.8);
}

.staff-detail-value {
	font-size: 1.5rem;
	line-height: 2rem;
	font-weight: 400;
}

/* ==========================================================================
   MAIN CONTENT
   ========================================================================== */

.staff-detail-container {
	margin: 3rem auto 0;
	padding: var(--container-padding-y) var(--container-padding-x);
	max-width: var(--container-max-width);
	width: 100%;
	box-sizing: border-box;
}

.staff-detail-inner {
	display: grid;
	grid-template-columns: minmax(0, 62rem) 30rem;
	gap: 2rem;
	align-items: flex-start;
}

.staff-content {
	display: flex;
	flex-direction: column;
	gap: 2rem;
}

.staff-section {
	background: var(--color-white);
	border-radius: 1rem;
	padding: 2.1875rem;
	box-shadow: 0 0.625rem 0.9375rem -3px rgba(0, 0, 0, 0.1), 0 0.25rem 0.375rem -4px rgba(0, 0, 0, 0.1);
	overflow: hidden;
}

.staff-section__header {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--color-text);
	text-transform: uppercase;
	letter-spacing: 0.03125rem;
	margin: 0 0 1.5625rem 0;
	padding-left: 0.9375rem;
	border-left: 0.25rem solid var(--red-900, var(--red-900));
	background: transparent;
}

.staff-section__icon {
	width: 1.25rem;
	height: 1.25rem;
	color: var(--red-900, var(--red-900));
	flex-shrink: 0;
}

.staff-section__title {
	margin: 0;
	font-size: 1.25rem;
	line-height: 1.75rem;
	font-weight: 700;
	color: inherit;
	text-transform: uppercase;
	letter-spacing: 0.03125rem;
}

.staff-section__text {
	margin: 0;
	font-size: 1rem;
	line-height: 1.6rem;
	color: var(--gray-700);
	white-space: pre-wrap;
	word-break: break-word;
}

.staff-achievements,
.staff-career {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.staff-achievement-item,
.staff-career-item {
	display: flex;
	gap: 1rem;
	padding: 1rem;
	min-height: 5rem;
	background: var(--gray-50);
	border-radius: 0.625rem;
	align-items: center;
}

.staff-achievement-icon,
.staff-career-icon {
	width: 3rem;
	height: 3rem;
	border-radius: 9999px;
	background: var(--red-100);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--red-700);
	flex-shrink: 0;
}

.staff-achievement-icon svg,
.staff-career-icon svg {
	width: 1.5rem;
	height: 1.5rem;
	fill: currentColor;
}

.staff-achievement-text {
	margin: 0;
	font-size: 1rem;
	line-height: 1.6rem;
	color: var(--color-charcoal);
	flex: 1;
}

.staff-career-info {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
	flex: 1;
}

.staff-career-title {
	margin: 0;
	font-size: 1rem;
	line-height: 1.4rem;
	font-weight: 600;
	color: var(--gray-900);
}

.staff-career-club {
	margin: 0;
	font-size: 0.875rem;
	line-height: 1.4rem;
	color: var(--gray-600);
}

.staff-career-period {
	margin: 0;
	font-size: 0.875rem;
	line-height: 1.4rem;
	color: var(--gray-500);
}

/* ==========================================================================
   SIDEBAR
   ========================================================================== */

.staff-sidebar {
	position: sticky;
	top: 7.5rem;
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.staff-info-card {
	background: var(--color-white);
	border-radius: 1rem;
	box-shadow: 0 0.625rem 0.9375rem -3px rgba(0, 0, 0, 0.1), 0 0.25rem 0.375rem -4px rgba(0, 0, 0, 0.1);
	overflow: hidden;
}

.staff-info-card__header {
	background: linear-gradient(135deg, var(--red-900, var(--red-900)) 0%, var(--red-700, var(--red-700)) 100%);
	padding: 1rem 1.5rem;
}

.staff-info-card__title {
	margin: 0;
	font-size: 1.25rem;
	line-height: 1.75rem;
	font-weight: 600;
	color: var(--color-white);
}

.staff-info-card__body {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	padding: 1.5rem;
}

.staff-info-card__row {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
	padding-bottom: 1rem;
	border-bottom: 0.0625rem solid var(--gray-200);
}

.staff-info-card__row:last-child {
	padding-bottom: 0;
	border-bottom: none;
}

.staff-info-card__label {
	font-size: 0.875rem;
	line-height: 1.25rem;
	color: var(--gray-600);
}

.staff-info-card__value {
	font-size: 1.125rem;
	line-height: 1.75rem;
	color: var(--gray-900);
}

.staff-fact-card {
	background: linear-gradient(180deg, var(--red-50) 0%, var(--red-100) 100%);
	border: 0.0625rem solid var(--red-100, #ffe5e5);
	border-radius: 1rem;
	padding: 1.5rem;
	box-shadow: 0 0.625rem 0.9375rem -3px rgba(0, 0, 0, 0.1), 0 0.25rem 0.375rem -4px rgba(0, 0, 0, 0.1);
}

.staff-fact-card .staff-fact-icon {
	margin-bottom: 1rem;
}

.staff-fact-icon {
	width: 3rem;
	height: 3rem;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 9999px;
	background: var(--red-900);
	color: var(--color-white);
	padding: 0.5rem;
}

.staff-fact-icon .staff-section__icon {
	color: var(--color-white);
}

.staff-fact-icon svg {
	width: 100%;
	height: 100%;
	fill: currentColor;
}

.staff-fact-title {
	margin: 0 0 0.75rem;
	font-size: 1.125rem;
	line-height: 1.575rem;
	font-weight: 600;
	color: var(--red-900);
}

.staff-fact-text {
	margin: 0;
	font-size: 0.875rem;
	line-height: 1.4rem;
	color: var(--gray-700);
}

/* ==========================================================================
   АДАПТИВНОСТЬ
   ========================================================================== */

/* Desktop Large (1024px) */
@media (max-width: 1024px) {
	.staff-container {
		padding: 0 1.875rem;
		height: auto;
	}

	.staff-photo-wrapper {
		width: 100%;
		height: 100%;
	}

	.staff-hero__main {
		grid-template-columns: 1fr 1.2fr;
		gap: 2.5rem;
	}

	.staff-info-block {
		padding-top: 0;
	}

	.staff-title {
		font-size: 2.625rem;
		line-height: 3.25rem;
	}

	.staff-details-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 1.25rem;
	}

	.staff-detail-value {
		font-size: 1.25rem;
		line-height: 1.75rem;
	}

	.staff-detail-container {
		padding: 0 1.875rem;
		margin-top: 2rem;
	}

	.staff-detail-inner {
		grid-template-columns: 1fr;
	}

	.staff-sidebar {
		position: static;
		width: 100%;
		flex-direction: column;
	}

	.staff-info-card,
	.staff-fact-card {
		max-width: 100%;
	}

	.staff-section {
		padding: 1.875rem;
	}

	.staff-section__header {
		margin-bottom: 1.25rem;
	}

	.staff-content {
		gap: 1.5rem;
	}
}

/* Tablet (768px) */
@media (max-width: 768px) {
	.player-page {
		padding-bottom: 3rem;
	}

	.player-hero {
		height: auto;
		padding: 1.5625rem 0;
	}

	.player-hero__inner {
		padding: 0 1.25rem;
	}

	.staff-container {
		padding: 0 1.25rem;
	}

	.staff-hero__main {
		grid-template-columns: 1fr;
		gap: 1.5rem;
		padding: 0;
		align-items: start;
	}

	.staff-photo-wrapper {
		width: 100%;
		max-width: 100%;
		height: auto;
		border-radius: 1.5rem;
	}

	.staff-info-block {
		padding-top: 0;
		text-align: left;
		background: rgba(255, 255, 255, 0.25);
		border-radius: 0.75rem;
		padding: 1.25rem;
		height: auto;
	}

	.staff-position-badge {
		padding: 0.3125rem 0.75rem;
		font-size: 0.75rem;
		width: fit-content;
	}

	.staff-title {
		font-size: 1.75rem;
		line-height: 2.25rem;
		margin-bottom: 0.5rem;
	}

	.staff-details-grid {
		grid-template-columns: 1fr 1fr;
		gap: 0.9375rem;
		padding-top: 2rem;
	}

	.staff-detail-item {
		gap: 0.125rem;
	}

	.staff-detail-label {
		font-size: 0.75rem;
	}

	.staff-detail-value {
		font-size: 1.25rem;
		line-height: 1.75rem;
	}

	.staff-detail-container {
		padding: 0 1.25rem;
		margin-top: 2rem;
	}

	.content-container {
		padding: 0 1.25rem;
	}

	.staff-detail-inner {
		grid-template-columns: 1fr;
		gap: 1.5rem;
	}

	.staff-sidebar {
		position: static;
		width: 100%;
	}

	.staff-content {
		gap: 1.5rem;
	}

	.staff-section {
		padding: 1.25rem;
		border-radius: 0.75rem;
	}

	.staff-section__header {
		font-size: 1.125rem;
		margin-bottom: 1.25rem;
		padding-left: 0.75rem;
	}

	.staff-achievement-item,
	.staff-career-item {
		min-height: unset;
		padding: 0.75rem;
		gap: 0.75rem;
	}

	.staff-achievement-icon,
	.staff-career-icon {
		width: 2.5rem;
		height: 2.5rem;
	}

	.staff-achievement-text,
	.staff-career-info {
		font-size: 0.875rem;
	}

	.staff-info-card {
		border-radius: 0.75rem;
	}

	.staff-info-card__header {
		padding: 0.875rem 1.25rem;
	}

	.staff-info-card__body {
		padding: 1.25rem;
		gap: 0.75rem;
	}

	.staff-info-card__title {
		font-size: 1.125rem;
		line-height: 1.5rem;
	}

	.staff-fact-card {
		padding: 1.125rem;
		border-radius: 0.75rem;
	}

	.staff-fact-title {
		font-size: 1rem;
		line-height: 1.375rem;
	}

	.staff-fact-text {
		font-size: 0.8125rem;
		line-height: 1.25rem;
	}
}

/* Mobile (480px) */
@media (max-width: 30rem) {
	h1, h2, h3, h4, h5, h6 {
		text-align: left;
	}

	.staff-container {
		padding: 0 0.75rem;
		height: auto;
	}

	.content-container {
		padding: 0 0.75rem;
	}

	.player-hero {
		height: auto;
		padding: 0.9375rem 0;
	}

	.player-hero__inner {
		padding: 1.25rem 1rem 0;
	}

	.staff-hero__main {
		grid-template-columns: 1fr;
		gap: 1rem;
		align-items: start;
	}

	.staff-photo-wrapper {
		width: 100%;
		height: auto;
		border-radius: 1rem;
		border: 0.1875rem solid rgba(255, 255, 255, 0.15);
	}

	.staff-info-block {
		padding: 1rem;
		border-radius: 0.625rem;
		gap: 1rem;
		height: auto;
	}

	.staff-position-badge {
		font-size: 0.6875rem;
		padding: 0.25rem 0.625rem;
		border-radius: 1.25rem;
	}

	.staff-title {
		font-size: 1.5rem;
		line-height: 2rem;
		margin-bottom: 0.375rem;
	}

	.staff-details-grid {
		grid-template-columns: 1fr;
		gap: 0.5rem;
		padding-top: 1.5rem;
	}

	.staff-detail-item {
		gap: 0.125rem;
	}

	.staff-detail-label {
		font-size: 0.6875rem;
		line-height: 1rem;
	}

	.staff-detail-value {
		font-size: 1rem;
		line-height: 1.5rem;
	}

	.staff-detail-container {
		padding: 0 0.75rem;
	}

	.staff-detail-inner {
		grid-template-columns: 1fr;
		gap: 1rem;
	}

	.staff-sidebar {
		position: static;
		width: 100%;
		flex-direction: column;
	}

	.staff-content {
		gap: 1rem;
	}

	.staff-section {
		padding: 1rem;
		border-radius: 0.625rem;
	}

	.staff-section__header {
		font-size: 1rem;
		margin-bottom: 1rem;
		padding-left: 0.75rem;
	}

	.staff-section__title {
		font-size: 1rem;
		line-height: 1.25rem;
	}

	.staff-section__text {
		font-size: 0.875rem;
		line-height: 1.375rem;
	}

	.staff-achievement-item,
	.staff-career-item {
		padding: 0.625rem;
		gap: 0.625rem;
		min-height: unset;
		border-radius: 0.5rem;
	}

	.staff-achievement-icon,
	.staff-career-icon {
		width: 2.25rem;
		height: 2.25rem;
	}

	.staff-achievement-text {
		font-size: 0.875rem;
		line-height: 1.25rem;
	}

	.staff-career-title {
		font-size: 0.875rem;
		line-height: 1.25rem;
	}

	.staff-career-club,
	.staff-career-period {
		font-size: 0.75rem;
		line-height: 1.125rem;
	}

	.staff-info-card {
		border-radius: 0.625rem;
	}

	.staff-info-card__header {
		padding: 0.75rem 1rem;
	}

	.staff-info-card__title {
		font-size: 1rem;
		line-height: 1.5rem;
	}

	.staff-info-card__body {
		padding: 1rem;
		gap: 0.75rem;
	}

	.staff-info-card__label {
		font-size: 0.75rem;
		line-height: 1.125rem;
	}

	.staff-info-card__value {
		font-size: 1rem;
		line-height: 1.5rem;
	}

	.staff-fact-card {
		padding: 1rem;
		border-radius: 0.625rem;
	}

	.staff-fact-icon {
		width: 2.25rem;
		height: 2.25rem;
	}

	.staff-fact-title {
		font-size: 0.875rem;
		line-height: 1.25rem;
		margin-bottom: 0.625rem;
	}

	.staff-fact-text {
		font-size: 0.75rem;
		line-height: 1.125rem;
	}
}

/* Уменьшение иконок в достижениях и карьере на 25% */
.staff-achievement-icon,
.staff-career-icon {
	transform: scale(0.75);
	transform-origin: left center;
}
/* ========================================================================== 
   Анимированный плейсхолдер фото (Lottie камера веб-компонент)
   ========================================================================== */

lottie-player {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	background: linear-gradient(135deg, var(--gray-50) 0%, var(--gray-200) 100%) !important;
	border-radius: 0.5rem;
}

/* Мобильный вид */
@media (max-width: 768px) {
	lottie-player {
		min-height: 12.5rem !important;
	}
}

