/**
 * Основные стили темы Француз
 * CSS переменные, сброс стилей, базовые компоненты
 */

/* ===========================
   CSS ПЕРЕМЕННЫЕ (Design System)
   =========================== */

:root {
	/* Основные цвета */
	--color-primary-blue:       #3A5A8C;
	--color-primary-blue-hover: #2E4870;
	--color-accent-red:         #A93226;
	--color-accent-red-hover:   #8B2820;
	--color-neutral-white:      #F5F5F0;
	--color-text-dark:          #1C1C1E;
	--color-bg-light:           #EAEAEA;
	--color-border:             #D1D1D6;
	--color-white:              #FFFFFF;

	/* Отступы (кратны 8px) */
	--space-xs:  8px;
	--space-sm:  16px;
	--space-md:  24px;
	--space-lg:  48px;
	--space-xl:  64px;
	--space-2xl: 96px;

	/* Контейнер */
	--container-width:   1200px;
	--container-padding: 24px;

	/* Сетка */
	--grid-gap: 24px;

	/* Шрифты */
	--font-heading: 'Oswald', sans-serif;
	--font-body:    'Inter', sans-serif;

	/* Скругления */
	--radius-sm: 4px;
	--radius-md: 8px;

	/* Тени */
	--shadow-card:  0 2px 8px rgba(0, 0, 0, 0.08);
	--shadow-hover: 0 4px 16px rgba(0, 0, 0, 0.12);

	/* Переходы */
	--transition: 0.3s ease;

	/* Высота шапки — используется в hero и других блоках */
	--header-height:        80px;
	--header-height-mobile: 64px;
}

/* ===========================
   СБРОС СТИЛЕЙ
   =========================== */

*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	scroll-behavior: smooth;
	overflow-x: hidden; /* Предотвращаем горизонтальный скролл от 100vw breakout */
}

body {
	overflow-x: hidden;
	font-family: var(--font-body);
	font-size: 18px;
	line-height: 1.6;
	color: var(--color-text-dark);
	background-color: var(--color-neutral-white);
}

img {
	max-width: 100%;
	height: auto;
	display: block;
}

a {
	color: var(--color-primary-blue);
	text-decoration: none;
	transition: color var(--transition);
}

a:hover {
	color: var(--color-primary-blue-hover);
}

/* Небольшой отступ при переходе по anchor-ссылкам */
[id] {
	scroll-margin-top: 16px;
}

/* ===========================
   ТИПОГРАФИКА
   =========================== */

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-heading);
	line-height: 1.2;
	color: var(--color-text-dark);
}

h1 { font-size: clamp(48px, 6vw, 64px);   font-weight: 700; }
h2 { font-size: clamp(36px, 4.5vw, 48px); font-weight: 600; }
h3 { font-size: clamp(28px, 3.5vw, 36px); font-weight: 600; }
h4 { font-size: clamp(24px, 3vw, 28px);   font-weight: 600; }

/* ===========================
   ОБЁРТКА САЙТА
   =========================== */

.site {
	min-height: 100vh;
	display: flex;
	flex-direction: column;
}

/* ===========================
   КОНТЕЙНЕР
   =========================== */

.francuz-container {
	max-width: var(--container-width);
	margin: 0 auto;
	padding: 0 var(--container-padding);
}

/* ===========================
   КНОПКИ
   =========================== */

.francuz-btn {
	display: inline-block;
	padding: 14px 36px;
	border-radius: var(--radius-sm);
	font-family: var(--font-body);
	font-size: 16px;
	font-weight: 600;
	text-align: center;
	cursor: pointer;
	transition: background-color var(--transition), transform var(--transition), color var(--transition), border-color var(--transition);
	text-decoration: none;
	border: 2px solid transparent;
	white-space: nowrap;
	line-height: 1.3;
}

.francuz-btn:hover {
	transform: translateY(-2px);
	text-decoration: none;
}

/* Синяя (основная) */
.francuz-btn--blue {
	background-color: var(--color-primary-blue);
	color: var(--color-white);
	border-color: var(--color-primary-blue);
}

.francuz-btn--blue:hover {
	background-color: var(--color-primary-blue-hover);
	border-color: var(--color-primary-blue-hover);
	color: var(--color-white);
}

/* Красная (CTA) */
.francuz-btn--red {
	background-color: var(--color-accent-red);
	color: var(--color-white);
	border-color: var(--color-accent-red);
}

.francuz-btn--red:hover {
	background-color: var(--color-accent-red-hover);
	border-color: var(--color-accent-red-hover);
	color: var(--color-white);
}

/* Контурная белая */
.francuz-btn--outline {
	background-color: transparent;
	color: var(--color-white);
	border-color: var(--color-white);
}

.francuz-btn--outline:hover {
	background-color: var(--color-white);
	color: var(--color-text-dark);
}


/* =======================================================
   Футер (Блок 11)
   ======================================================= */

/* --- Основной блок --- */
.site-footer {
	background: #1C1C1E;
	color:      rgba(255, 255, 255, 0.65);
}

/* --- Внутренний контейнер: 3 колонки --- */
.site-footer__inner {
	display:               grid;
	grid-template-columns: 2fr 1fr 1fr;
	gap:                   var(--space-2xl);
	max-width:             var(--container-width);
	margin:                0 auto;
	padding:               var(--space-2xl) var(--container-padding);
}

/* --- Логотип --- */
.site-footer__logo {
	display:        flex;
	flex-direction: column;
	gap:            4px;
	text-decoration: none;
	margin-bottom:  var(--space-md);
}

.site-footer__logo-name {
	font-family:    'Oswald', sans-serif;
	font-size:      26px;
	font-weight:    700;
	color:          #fff;
	letter-spacing: 0.08em;
	line-height:    1;
}

.site-footer__logo-tagline {
	font-family:    'Inter', sans-serif;
	font-size:      11px;
	color:          rgba(255, 255, 255, 0.45);
	letter-spacing: 0.03em;
}

/* --- Короткое описание --- */
.site-footer__about-text {
	font-family: 'Inter', sans-serif;
	font-size:   14px;
	line-height: 1.65;
	color:       rgba(255, 255, 255, 0.5);
	margin:      0 0 var(--space-md);
}

/* --- Социальные иконки --- */
.site-footer__social {
	display: flex;
	gap:     10px;
}

.site-footer__social-link {
	display:         flex;
	align-items:     center;
	justify-content: center;
	width:           40px;
	height:          40px;
	border-radius:   10px;
	background:      rgba(255, 255, 255, 0.08);
	color:           rgba(255, 255, 255, 0.65);
	text-decoration: none;
	transition:      background 0.2s, color 0.2s, transform 0.2s;
}

.site-footer__social-link:hover {
	color:     #fff;
	transform: translateY(-3px);
}

.site-footer__social-link--vk:hover { background: #0077FF; }
.site-footer__social-link--wa:hover { background: #25D366; }
.site-footer__social-link--tg:hover { background: #2AABEE; }

/* --- Заголовки колонок --- */
.site-footer__col-title {
	font-family:    'Oswald', sans-serif;
	font-size:      15px;
	font-weight:    600;
	color:          #fff;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin:         0 0 var(--space-md);
	padding-bottom: 12px;
	border-bottom:  1px solid rgba(255, 255, 255, 0.1);
}

/* --- Навигация --- */
.site-footer__nav-list {
	list-style: none;
	margin:     0;
	padding:    0;
	display:    flex;
	flex-direction: column;
	gap:        10px;
}

.site-footer__nav-list li a {
	font-family:  'Inter', sans-serif;
	font-size:    14px;
	color:        rgba(255, 255, 255, 0.6);
	text-decoration: none;
	transition:   color 0.2s, padding-left 0.2s;
	display:      inline-block;
}

.site-footer__nav-list li a:hover {
	color:        #fff;
	padding-left: 6px;
}

/* --- Контакты в футере --- */
.site-footer__contacts-list {
	list-style: none;
	margin:     0;
	padding:    0;
	display:    flex;
	flex-direction: column;
	gap:        14px;
}

.site-footer__contacts-item {
	display:     flex;
	align-items: flex-start;
	gap:         10px;
	font-family: 'Inter', sans-serif;
	font-size:   13px;
	color:       rgba(255, 255, 255, 0.6);
	line-height: 1.55;
}

.site-footer__contacts-icon {
	flex-shrink: 0;
	margin-top:  2px;
	color:       rgba(58, 90, 140, 0.9);
}

.site-footer__contacts-item a {
	color:           rgba(255, 255, 255, 0.6);
	text-decoration: none;
	transition:      color 0.2s;
}

.site-footer__contacts-item a:hover {
	color: #fff;
}

/* --- Нижняя полоса: копирайт --- */
.site-footer__bottom {
	border-top: 1px solid rgba(255, 255, 255, 0.07);
}

.site-footer__bottom-inner {
	display:         flex;
	align-items:     center;
	justify-content: space-between;
	gap:             var(--space-sm);
	max-width:       var(--container-width);
	margin:          0 auto;
	padding:         var(--space-md) var(--container-padding);
}

.site-footer__copy {
	font-family: 'Inter', sans-serif;
	font-size:   13px;
	color:       rgba(255, 255, 255, 0.35);
	margin:      0;
}

.site-footer__privacy {
	font-family:     'Inter', sans-serif;
	font-size:       13px;
	color:           rgba(255, 255, 255, 0.35);
	text-decoration: none;
	transition:      color 0.2s;
}

.site-footer__privacy:hover {
	color: rgba(255, 255, 255, 0.65);
}

/* =======================================================
   Плавающие кнопки: WhatsApp и Telegram
   ======================================================= */

.site-float-btns {
	position:       fixed;
	bottom:         32px;
	right:          24px;
	z-index:        9000;
	display:        flex;
	flex-direction: column;
	gap:            10px;
}

.site-float-btn {
	display:         flex;
	align-items:     center;
	justify-content: center;
	width:           52px;
	height:          52px;
	border-radius:   50%;
	color:           #fff;
	text-decoration: none;
	box-shadow:      0 4px 20px rgba(0, 0, 0, 0.25);
	transition:      transform 0.2s, box-shadow 0.2s;
}

.site-float-btn:hover {
	transform:  scale(1.12);
	box-shadow: 0 6px 28px rgba(0, 0, 0, 0.35);
}

.site-float-btn--wa { background: #25D366; }
.site-float-btn--tg { background: #2AABEE; }

/* === Адаптив футера === */

/* Планшет */
@media (max-width: 992px) {
	.site-footer__inner {
		grid-template-columns: 1fr 1fr;
		gap:                   var(--space-lg);
	}

	.site-footer__col--about {
		grid-column: 1 / -1;
	}
}

/* Мобильный */
@media (max-width: 768px) {
	.site-footer__inner {
		grid-template-columns: 1fr;
		gap:                   var(--space-lg);
		padding:               var(--space-lg) var(--container-padding);
	}

	.site-footer__col--about {
		grid-column: auto;
	}

	.site-footer__bottom-inner {
		flex-direction: column;
		text-align:     center;
	}

	.site-float-btns {
		bottom: 20px;
		right:  16px;
	}

	.site-float-btn {
		width:  46px;
		height: 46px;
	}
}
