/* Основные адаптивные стили - устраняем горизонтальный скролл */
html {
	scroll-behavior: smooth;
}

body {
	width: 100%;
	overflow-x: hidden;
	max-width: 100%;
}

/* Общие адаптивные стили */
img,
video,
svg {
	max-width: 100%;
	height: auto;
}

table {
	width: 100%;
	table-layout: fixed;
	word-wrap: break-word;
}

/* Гибкий размер текста */
h1 {
	font-size: clamp(1.8rem, 5vw, 2.8rem);
	word-wrap: break-word;
}

h2 {
	font-size: clamp(1.6rem, 4vw, 2.2rem);
	word-wrap: break-word;
}

h3 {
	font-size: clamp(1.2rem, 3vw, 1.8rem);
	word-wrap: break-word;
}

p,
li {
	font-size: clamp(0.9rem, 2vw, 1rem);
	word-wrap: break-word;
}

/* Отступы секций */
section {
	padding: 60px 15px;
	width: 100%;
	box-sizing: border-box;
	overflow: hidden;
}

.container {
	padding: 0 15px;
	width: 100%;
	max-width: var(--max-width);
	margin: 0 auto;
	box-sizing: border-box;
}

/* Адаптивные сетки */
.benefits-grid,
.courses-grid,
.testimonials-grid,
.values-grid,
.faq-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 20px;
	width: 100%;
}

.contact-grid,
.about-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 30px;
	width: 100%;
}

/* Пошаговая адаптивность */
@media (min-width: 576px) {
	.course-form {
		padding: 40px 30px;
	}
}

@media (min-width: 768px) {
	section {
		padding: 80px 15px;
	}

	.contact-grid {
		grid-template-columns: 1fr;
	}

	.about-grid {
		grid-template-columns: 1fr 1fr;
	}

	.course-form {
		padding: 50px;
	}

	.benefits-grid,
	.courses-grid,
	.testimonials-grid,
	.values-grid,
	.faq-grid {
		gap: 30px;
	}
}

/* Мобильные устройства */
@media (max-width: 480px) {
	.btn {
		display: block;
		width: 100%;
		margin: 10px 0;
		text-align: center;
	}

	.form-submit button {
		width: 100%;
		padding: 15px 20px;
	}

	.hero {
		padding: 100px 15px 60px;
	}

	.contact-item {
		padding-left: 0;
	}

	.course-meta,
	.info-item {
		flex-direction: column;
		align-items: flex-start;
		gap: 10px;
	}

	.benefit-card,
	.testimonial-card,
	.faq-item,
	.value-item {
		padding: 20px;
	}

	.course-form {
		padding: 25px 15px;
	}

	.form-group.checkbox {
		padding-left: 0;
	}

	.contact-map {
		height: 250px;
	}
}

/* Исправления для iframe, чтобы они не вызывали горизонтальный скролл */
iframe {
	max-width: 100%;
	width: 100%;
	border: none;
	box-sizing: border-box;
}

.contact-map {
	width: 100%;
	box-sizing: border-box;
	overflow: hidden;
	border-radius: 10px;
}

/* Исправления для длинных слов и URL-адресов */
p,
h1,
h2,
h3,
h4,
h5,
h6,
a,
span,
li,
td,
th,
label,
input,
textarea,
select,
button {
	overflow-wrap: break-word;
	word-wrap: break-word;
	-ms-word-break: break-all;
	word-break: break-word;
	-ms-hyphens: auto;
	-moz-hyphens: auto;
	-webkit-hyphens: auto;
	hyphens: auto;
}
