/* ===== Брендові змінні ===== */
:root {
	--color-black: #0a0a0a;
	--color-blue: #3797f1;
	--color-blue-dark: #1f7ad4;
	--color-white: #ffffff;
	--hero-height: 70vh;
	--font:
		'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}

/* ===== Базовий ресет ===== */
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

html,
body {
	height: 100%;
}

body {
	font-family: var(--font);
	background-color: var(--color-black);
	color: var(--color-white);
	-webkit-font-smoothing: antialiased;
}

/* ===== Головна сторінка: картинка на весь екран ===== */
.home {
	position: relative;
	min-height: 100vh;
	min-height: 100dvh;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	overflow: hidden;

	/* Зображення на весь екран. Покладіть свій файл у assets/hero.jpg. */
	background-image: url('/assets/hero.JPG');
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}

/* Затемнення поверх картинки для читабельності тексту й кнопок */
.home__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		180deg,
		rgba(10, 10, 10, 0.45),
		rgba(10, 10, 10, 0.65)
	);
	pointer-events: none;
}

/* Контент (текст + кнопки) поверх картинки */
.home__content {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 24px;
}

.hero__title {
	font-size: clamp(2rem, 6vw, 5rem);
	font-weight: 800;
	letter-spacing: 0.02em;
	line-height: 1.05;
	text-shadow: 0 4px 30px rgba(0, 0, 0, 0.6);
}

/* ===== Назва бренду у лівому верхньому куті ===== */
.brand {
	position: absolute;
	top: 1.5rem;
	left: 2rem;
	z-index: 2;
	/* 2.1875vw = 42px при ширині 1920px; на менших екранах зменшується (мін. 24px) */
	font-size: clamp(1.5rem, 2.1875vw, 2.625rem);
	font-weight: 700;
	color: var(--color-blue);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	text-decoration: none;
	text-shadow: 0 2px 12px rgba(0, 0, 0, 0.6);
	transition: opacity 0.2s ease;
}

.brand:hover {
	opacity: 0.85;
}

/* ===== Розгалуження на регіони (кнопки поверх картинки) ===== */
.regions {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	flex-wrap: wrap;
	margin-top: 2.5rem;
}

.region-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.75rem 2rem;
	min-width: 160px;
	font-size: 1.05rem;
	font-weight: 600;
	letter-spacing: 0.03em;
	text-decoration: none;
	color: var(--color-white);
	background-color: rgba(10, 10, 10, 0.45);
	border: 2px solid var(--color-white);
	border-radius: 999px;
	backdrop-filter: blur(2px);
	transition:
		background-color 0.25s ease,
		color 0.25s ease,
		transform 0.15s ease;
}

.region-btn:hover,
.region-btn:focus-visible {
	background-color: var(--color-white);
	color: var(--color-black);
	transform: translateY(-2px);
	outline: none;
}

/* ===== Мобільні: кнопки одна під одною ===== */
@media (max-width: 480px) {
	.region-btn {
		width: 100%;
		max-width: 280px;
	}
}

/* ===== Регіональні сторінки (заготовка) ===== */
.region-page {
	min-height: 100vh;
	min-height: 100dvh;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 1.5rem;
	text-align: center;
	padding: 24px;
}

.region-page h1 {
	font-size: clamp(2rem, 6vw, 4rem);
	font-weight: 800;
}

.region-page h1 span {
	color: var(--color-blue);
}

.region-page p {
	max-width: 540px;
	font-size: 1.1rem;
	line-height: 1.6;
	opacity: 0.85;
}

.back-link {
	display: inline-block;
	margin-top: 0.5rem;
	padding: 0.75rem 1.75rem;
	border: 2px solid var(--color-blue);
	border-radius: 999px;
	color: var(--color-white);
	text-decoration: none;
	font-weight: 600;
	transition: background-color 0.25s ease;
}

.back-link:hover {
	background-color: var(--color-blue);
}

/* ============================================================
   ІНФОРМАЦІЙНА СТОРІНКА (kharkiv.html / kyiv.html)
   ============================================================ */

.page {
	/* Фірмовий темний фон з ледь помітним синім сяйвом угорі */
	background:
		radial-gradient(
			120% 60% at 50% -10%,
			rgba(55, 151, 241, 0.18),
			transparent 60%
		),
		var(--color-black);
	min-height: 100vh;
}

/* ===== Шапка ===== */
.topbar {
	position: sticky;
	top: 0;
	z-index: 10;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 1rem 2rem;
	background: rgba(10, 10, 10, 0.7);
	backdrop-filter: blur(8px);
	border-bottom: 1px solid rgba(55, 151, 241, 0.2);
}

.brand--static {
	position: static;
	top: auto;
	left: auto;
	text-shadow: none;
}

.topbar__back {
	color: var(--color-white);
	text-decoration: none;
	font-weight: 500;
	opacity: 0.8;
	transition: color 0.2s ease, opacity 0.2s ease;
}

.topbar__back:hover {
	color: var(--color-blue);
	opacity: 1;
}

/* ===== Загальні відступи секцій ===== */
.info {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 2rem;
}

.section {
	padding: 4.5rem 0;
}

.section__title {
	font-size: clamp(1.75rem, 4vw, 3rem);
	font-weight: 800;
	margin-bottom: 2rem;
	color: var(--color-white);
}

.section__title::after {
	content: '';
	display: block;
	width: 64px;
	height: 4px;
	margin-top: 0.75rem;
	background: var(--color-blue);
	border-radius: 2px;
}

/* ===== Місія: заголовок ліворуч, текст праворуч ===== */
.mission {
	display: grid;
	grid-template-columns: 1fr 2fr;
	gap: 2.5rem;
	align-items: start;
}

.mission .section__title {
	margin-bottom: 0;
}

.mission__text {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.mission__text p {
	font-size: 1.05rem;
	line-height: 1.7;
	opacity: 0.9;
}

/* ===== Зігзаг 2×2 ===== */
.zigzag {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1.5rem;
	padding: 2rem 0 4.5rem;
}

.zigzag__cell {
	min-height: 320px;
	border-radius: 16px;
	overflow: hidden;
}

.zigzag__cell--text {
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 1rem;
	padding: 2.5rem;
	background: linear-gradient(
		160deg,
		rgba(55, 151, 241, 0.12),
		rgba(10, 10, 10, 0.4)
	);
	border: 1px solid rgba(55, 151, 241, 0.25);
}

.zigzag__cell--text h3 {
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--color-blue);
}

.zigzag__cell--text p {
	font-size: 1.02rem;
	line-height: 1.65;
	opacity: 0.9;
}

/* Плейсхолдери картинок (замініть на background-image: url(...)) */
.zigzag__cell--img,
.img-ph {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	background:
		linear-gradient(135deg, #0a0a0a 30%, var(--color-blue) 140%);
	background-size: cover;
	background-position: center;
}

.zigzag__cell--img:nth-of-type(odd) {
	background: linear-gradient(135deg, var(--color-blue) -40%, #0a0a0a 70%);
}

.img-ph__label {
	font-size: 0.95rem;
	letter-spacing: 0.05em;
	color: rgba(255, 255, 255, 0.55);
	text-transform: uppercase;
}

/* ===== Список з падаючою лінією (timeline) ===== */
.timeline {
	list-style: none;
	position: relative;
	padding-left: 2.5rem;
}

/* Вертикальна лінія за крапками */
.timeline::before {
	content: '';
	position: absolute;
	left: 7px;
	top: 0.6em;
	bottom: 0.6em;
	width: 2px;
	background: linear-gradient(
		180deg,
		var(--color-blue),
		rgba(55, 151, 241, 0.15)
	);
}

.timeline__item {
	position: relative;
	padding: 0.9rem 0;
	font-size: 1.05rem;
	line-height: 1.6;
	opacity: 0.92;
}

/* Крапка */
.timeline__item::before {
	content: '';
	position: absolute;
	left: -2.5rem;
	top: 1.25rem;
	width: 16px;
	height: 16px;
	border-radius: 50%;
	background: var(--color-blue);
	box-shadow: 0 0 0 4px rgba(55, 151, 241, 0.2);
}

/* ===== Карусель ===== */
.carousel {
	position: relative;
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

.carousel__track {
	display: flex;
	gap: 1.25rem;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	padding: 0.5rem;
	scrollbar-width: none;
}

.carousel__track::-webkit-scrollbar {
	display: none;
}

.carousel__track > * {
	scroll-snap-align: start;
	flex: 0 0 auto;
}

.carousel__btn {
	flex: 0 0 auto;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	border: 1px solid rgba(55, 151, 241, 0.4);
	background: rgba(10, 10, 10, 0.6);
	color: var(--color-white);
	font-size: 1.5rem;
	line-height: 1;
	cursor: pointer;
	transition: background-color 0.2s ease, transform 0.15s ease;
}

.carousel__btn:hover {
	background: var(--color-blue);
	transform: scale(1.05);
}

/* Відгуки */
.review {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	gap: 1.25rem;
	width: 340px;
	max-width: 80vw;
	padding: 1.75rem;
	border-radius: 16px;
	text-decoration: none;
	color: var(--color-white);
	background: linear-gradient(
		160deg,
		rgba(55, 151, 241, 0.12),
		rgba(10, 10, 10, 0.5)
	);
	border: 1px solid rgba(55, 151, 241, 0.25);
	transition: transform 0.2s ease, border-color 0.2s ease;
}

.review:hover {
	transform: translateY(-4px);
	border-color: var(--color-blue);
}

.review__text {
	font-size: 1.02rem;
	line-height: 1.6;
}

.review__author {
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--color-blue);
}

/* Викладачі */
.teacher {
	width: 260px;
	max-width: 70vw;
}

.teacher__photo {
	height: 320px;
	border-radius: 16px;
	background: linear-gradient(135deg, #0a0a0a 20%, var(--color-blue) 150%);
	border: 1px solid rgba(55, 151, 241, 0.25);
}

.teacher__name {
	margin-top: 0.85rem;
	text-align: center;
	font-weight: 600;
	letter-spacing: 0.03em;
}

/* ===== Адаптив ===== */
@media (max-width: 768px) {
	.mission {
		grid-template-columns: 1fr;
		gap: 1.25rem;
	}

	.zigzag {
		grid-template-columns: 1fr;
	}

	/* Зберігаємо порядок: текст → фото → фото → текст лишається логічним */
	.topbar {
		padding: 1rem 1.25rem;
	}

	.info {
		padding: 0 1.25rem;
	}
}

