:root {
	--color-gold: #ffd700;
	--color-orange: #ff8c00;
	--color-purple: #8a2be2;
	--color-indigo: #4b0082;
	--color-white: #fff;
	--bg-dark-1: #0a0a1a;
	--bg-dark-2: #1a0a2e;
	--bg-dark-3: #0d0d2b;
	--bg-dark-4: #1a1a3e;
	--glass-bg: rgba(255, 255, 255, 0.05);
	--glass-border: rgba(255, 255, 255, 0.1);
	--glass-blur: 20px;
	--spacing-sm: 12px;
	--spacing-md: 20px;
	--spacing-lg: 30px;
	--spacing-xl: 40px;
	--radius-md: 16px;
	--radius-lg: 24px;
	--transition-fast: 0.1s ease;
	--transition-normal: 0.3s ease;
	--transition-slow: 0.5s ease;
	--gradient-gold: linear-gradient(
		135deg,
		var(--color-gold) 0%,
		var(--color-orange) 100%
	);
	--gradient-text: linear-gradient(
		135deg,
		var(--color-white) 0%,
		var(--color-gold) 50%,
		var(--color-orange) 100%
	);
}

@font-face {
	font-family: "SF Pro Text";
	src: url("SF-Pro-Text-Semibold.otf") format("opentype");
	font-weight: 600;
	font-style: normal;
}

* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

body {
	font-family: "SF Pro Text";
	min-height: 100vh;
	background: linear-gradient(
		135deg,
		var(--bg-dark-1) 0%,
		var(--bg-dark-2) 25%,
		var(--bg-dark-3) 50%,
		var(--bg-dark-4) 75%,
		var(--bg-dark-1) 100%
	);
	background-size: 400% 400%;
	animation: gradientShift 15s ease infinite;
	color: var(--color-white);
	padding: var(--spacing-xl) var(--spacing-md);
	position: relative;
	overflow-x: hidden;
}

body::before {
	content: "";
	position: fixed;
	inset: 0;
	background: radial-gradient(
			ellipse at 20% 20%,
			rgba(138, 43, 226, 0.15) 0%,
			transparent 50%
		),
		radial-gradient(
			ellipse at 80% 80%,
			rgba(75, 0, 130, 0.15) 0%,
			transparent 50%
		),
		radial-gradient(
			ellipse at 50% 50%,
			rgba(255, 255, 0, 0.03) 0%,
			transparent 70%
		);
	pointer-events: none;
	z-index: 0;
}

@keyframes gradientShift {
	0%,
	100% {
		background-position: 0% 50%;
	}
	50% {
		background-position: 100% 50%;
	}
}

@keyframes pulse {
	0%,
	100% {
		transform: scale(1);
		filter: drop-shadow(0 0 20px rgba(255, 215, 0, 0.6))
			drop-shadow(0 0 40px rgba(138, 43, 226, 0.4));
	}
	50% {
		transform: scale(1.05);
		filter: drop-shadow(0 0 30px rgba(255, 215, 0, 0.8))
			drop-shadow(0 0 60px rgba(138, 43, 226, 0.6));
	}
}

@keyframes flicker {
	0%,
	100% {
		opacity: 1;
	}
	10% {
		opacity: 0.8;
	}
	20% {
		opacity: 1;
	}
	30% {
		opacity: 0.6;
	}
	40% {
		opacity: 1;
	}
	50% {
		opacity: 0.9;
	}
	60% {
		opacity: 1;
	}
	70% {
		opacity: 0.7;
	}
	80% {
		opacity: 1;
	}
	90% {
		opacity: 0.85;
	}
}

@keyframes boltAnim {
	0% {
		opacity: 1;
		filter: blur(1px);
	}
	50% {
		opacity: 1;
		filter: blur(0px);
	}
	100% {
		opacity: 0;
		filter: blur(2px);
	}
}

.container {
	max-width: 800px;
	margin: 0 auto;
	position: relative;
	z-index: 1;
}

.glass {
	background: var(--glass-bg);
	backdrop-filter: blur(var(--glass-blur));
	-webkit-backdrop-filter: blur(var(--glass-blur));
	border: 1px solid var(--glass-border);
	border-radius: var(--radius-lg);
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3),
		inset 0 1px 0 rgba(255, 255, 255, 0.1), 0 0 40px rgba(138, 43, 226, 0.1);
}

.head {
	display: flex;
	align-items: center;
	text-align: center;
	justify-content: center;
	gap: var(--spacing-lg);
	padding: var(--spacing-xl);
	margin-bottom: var(--spacing-lg);
	position: relative;
	overflow: hidden;
}

.head img {
	width: 80px;
	height: 80px;
	filter: drop-shadow(0 0 20px rgba(255, 215, 0, 0.6))
		drop-shadow(0 0 40px rgba(138, 43, 226, 0.4));
	animation: pulse 2s ease-in-out infinite, flicker 1.5s infinite;
	position: relative;
	z-index: 1;
}

.head h1 {
	display: flex;
	flex-direction: column;
	gap: 4px;
	position: relative;
	z-index: 1;
}

.head h1 span:first-child {
	font-size: 2rem;
	font-weight: 700;
	background: var(--gradient-text);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	text-shadow: 0 0 30px rgba(255, 215, 0, 0.3);
}

.head h1 span:last-child {
	font-size: 1rem;
	font-weight: 300;
	color: rgba(255, 255, 255, 0.6);
	letter-spacing: 2px;
}

.card {
	padding: var(--spacing-lg);
	margin-bottom: var(--spacing-lg);
	position: relative;
	overflow: hidden;
	transition: transform var(--transition-fast),
		box-shadow var(--transition-normal),
		border-color var(--transition-normal);
	transform-style: preserve-3d;
}

.card:hover {
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4),
		inset 0 1px 0 rgba(255, 255, 255, 0.15),
		0 0 60px rgba(138, 43, 226, 0.15);
	border-color: rgba(255, 215, 0, 0.2);
}

.card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 1px;
	background: linear-gradient(
		90deg,
		transparent,
		rgba(255, 215, 0, 0.5),
		rgba(138, 43, 226, 0.5),
		transparent
	);
}

.card h2 {
	font-size: 1.3rem;
	font-weight: 700;
	margin-bottom: var(--spacing-md);
	padding-bottom: var(--spacing-sm);
	border-bottom: 1px solid var(--glass-border);
	background: var(--gradient-gold);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	display: flex;
	align-items: center;
	gap: 10px;
}

.card ul {
	list-style: none;
}

.card-item {
	padding: 16px var(--spacing-md);
	margin-bottom: var(--spacing-sm);
	background: rgba(255, 255, 255, 0.03);
	border-radius: var(--radius-md);
	border: 1px solid rgba(255, 255, 255, 0.05);
	transition: all var(--transition-normal);
	position: relative;
	overflow: hidden;
}

.card-item::before {
	content: "";
	position: absolute;
	top: 0;
	left: -100%;
	width: 100%;
	height: 100%;
	background: linear-gradient(
		90deg,
		transparent,
		rgba(255, 215, 0, 0.1),
		transparent
	);
	transition: left var(--transition-slow);
}

.card-item:hover::before {
	left: 100%;
}

.card-item:hover {
	background: rgba(255, 255, 255, 0.08);
	border-color: rgba(255, 215, 0, 0.3);
	transform: translateX(8px);
	box-shadow: 0 0 20px rgba(138, 43, 226, 0.2);
}

.card-item:last-child {
	margin-bottom: 0;
}

.card-item a {
	color: var(--color-white);
	text-decoration: none;
	font-weight: 500;
	font-size: 1.1rem;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	position: relative;
	transition: all var(--transition-normal);
}

.card-item a::after {
	content: "";
	position: absolute;
	bottom: -2px;
	left: 0;
	width: 0;
	height: 2px;
	background: linear-gradient(90deg, var(--color-gold), var(--color-orange));
	transition: width var(--transition-normal);
}

.card-item a:hover {
	color: var(--color-gold);
	text-shadow: 0 0 10px rgba(255, 215, 0, 0.5);
}

.card-item a:hover::after {
	width: 100%;
}

.card-item .period {
	margin-left: auto;
	font-size: 0.85rem;
	color: rgba(255, 255, 255, 0.4);
	font-weight: 300;
	order: 2;
}

.card-item .description {
	display: block;
	width: 100%;
	margin-top: 6px;
	font-size: 0.9rem;
	color: rgba(255, 255, 255, 0.5);
	font-weight: 300;
	order: 3;
}

.card.contacts ul {
	display: flex;
	flex-wrap: wrap;
	gap: var(--spacing-sm);
	justify-content: center;
}

.card.contacts .card-item {
	flex: 0 1 auto;
	margin-bottom: 0;
	text-align: center;
	padding: 14px var(--spacing-lg);
}

.card.contacts .card-item:hover {
	transform: translateY(-4px);
}

.lightning-bolt {
	position: fixed;
	top: 0;
	pointer-events: none;
	z-index: 9998;
	filter: blur(1px);
	animation: boltAnim var(--transition-normal) ease-out forwards;
}

.lightning-path {
	stroke: var(--color-white);
	stroke-linecap: round;
	filter: drop-shadow(0 0 10px var(--color-gold))
		drop-shadow(0 0 20px var(--color-purple))
		drop-shadow(0 0 30px var(--color-white)) blur(0.5px);
}

@media (max-width: 600px) {
	.head {
		flex-direction: column;
		text-align: center;
		padding: var(--spacing-lg);
	}

	.head h1 span:first-child {
		font-size: 1.6rem;
	}

	.card {
		padding: var(--spacing-lg);
	}

	.card.contacts ul {
		flex-direction: column;
	}

	.card.contacts .card-item {
		width: 100%;
	}
}
