/* Основные стили для body - задаем шрифт, отступы и цвет текста */
:root {
    --base-font-size: clamp(14px, 2vw, 16px); /* Базовый размер шрифта */
    --h1-font-size: clamp(1.8rem, 5vw, 3.5rem);
    --h2-font-size: clamp(1.5rem, 4vw, 2.5rem);
    --h3-font-size: clamp(1.2rem, 3vw, 1.8rem);
    --p-font-size: clamp(1rem, 1vw + 0.5rem, 1.2rem)
    --small-font-size: clamp(0.8rem, 1.5vw, 1rem);
}

/* Основная структура страницы */
body {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

/* Основное содержимое - растягивается */
main {
    flex: 1 0 auto; /* Растягивается, но не сжимается меньше содержимого */
}

/* Футер - фиксированной высоты */
.footer {
    flex-shrink: 0; /* Не сжимается */
}

/* Стили для основного контейнера страницы */
.container {
    max-width: 1200px; /* Максимальная ширина контейнера */
    margin: 0 auto; /* Центрирование контейнера */
    padding: 0 15px; /* Внутренние отступы слева и справа */
}

/* Подсветка при наведении */
.nav-link {
    transition: color 0.3s ease;
    position: relative;
}

.nav-link:hover {
    color: #28a745 !important; /* Зеленый цвет */
}

/* Опционально: анимация подчеркивания */
.nav-link::after {
    content: '';
    position: absolute;
    width: 0;
    height: 2px;
    bottom: -2px;
    left: 0;
    background-color: #28a745;
    transition: width 0.3s ease;
}

.nav-link:hover::after {
    width: 100%;
}

.orange-text {
    color: #FF6B00;
}

.img-fluid {
    margin-top: 20px;
    }

/* Для мобильного меню внизу */
.fixed-bottom .nav-link:hover {
    color: #28a745 !important;
}

.fixed-bottom .nav-link:hover i {
    color: #28a745 !important;
}

/* Стили для шапки сайта */
header {
    background-color: #fff; /* Белый фон */
    box-shadow: 0 2px 10px rgba(0,0,0,0.1); /* Тень под шапкой */
    position: sticky; /* Липкая шапка при скролле */
    top: 0; /* Прилипает к верху окна */
    z-index: 1000; /* Высокий z-index для перекрытия других элементов */
}

/* Контейнер внутри шапки */
.header-container {
    display: flex; /* Используем flexbox для расположения элементов */
    justify-content: space-between; /* Распределяем пространство между элементами */
    align-items: center; /* Выравниваем элементы по центру по вертикали */
    padding: 15px 0; /* Внутренние отступы сверху и снизу */
}

/* Стили для логотипа */
.logo img {
    height: 70px; /* Фиксированная высота логотипа */
}

/* Стили для контактов в шапке */
.contacts a {
    color: #333; /* Цвет ссылок */
    text-decoration: none; /* Убираем подчеркивание */
    margin-left: 15px; /* Отступ слева между ссылками */
}

/* Стили для главного баннера */
.hero-banner {
    position: relative; /* Относительное позиционирование */
    width: 100%; /* Ширина 100% */
    overflow: hidden; /* Скрываем выходящее за пределы содержимое */
}

/* Контейнер для баннера */
.banner-container {
    position: relative; /* Относительное позиционирование */
    width: 100%; /* Ширина 100% */
    height: 500px; /* Фиксированная высота баннера */
    overflow: hidden; /* Скрываем выходящее за пределы содержимое */
}

/* Изображение баннера */
.banner-image {
    width: auto; /* Изменено с 100% на auto */
    height: 100%; /* Высота 100% */
    object-fit: cover; /* Заполнение пространства с сохранением пропорций */
    display: block; /* Блочное отображение */
    position: absolute; /* Добавлено абсолютное позиционирование */
    right: 0; /* Прижимаем к правому краю */
    min-width: 100%; /* Гарантируем, что изображение заполнит контейнер по ширине */
}

/* Смещение заголовка влево */
.banner-overlay .container.text-center {
    text-align: left !important; /* Выравнивание текста по левому краю (переопределение) */
    margin-left: 0; /* Убираем автоматические отступы */
    padding-left: 20px; /* Добавляем отступ слева */
}

/* Адаптивные стили для мобильных устройств (ширина до 768px) */
@media (max-width: 768px) {
    .banner-overlay .container.text-center {
 /*text-align: center !important; /* Центрируем текст на мобильных */
        padding-left: 15px; /* Отступ слева */
        padding-right: 15px; /* Отступ справа */
    }
}

/* Наложение поверх баннера */
.banner-overlay {
    position: absolute; /* Абсолютное позиционирование */
    top: 0; /* Прижимаем к верху */
    left: 0; /* Прижимаем к левому краю */
    width: 100%; /* Ширина 100% */
    height: 100%; /* Высота 100% */
    background-color: rgba(0, 0, 0, 0.3); /* Полупрозрачный черный фон */
    display: flex; /* Используем flexbox */
    align-items: center; /* Выравниваем по центру по вертикали */
    justify-content: center; /* Выравниваем по центру по горизонтали */
    text-align: center; /* Выравнивание текста по центру */
    padding: 20px; /* Внутренние отступы */
    box-sizing: border-box; /* Учитываем padding в ширине/высоте */
}

/* Заголовок баннера */
.banner-title {
    color: white; /* Белый цвет текста */
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5); /* Тень текста */
    font-size: 3rem; /* Размер шрифта */
    margin-bottom: 20px; /* Отступ снизу */
}

/* Описание в баннере */
.banner-description {
    color: white !important; /* Белый цвет описания */
    max-width: 800px; /* Максимальная ширина */
    margin: 0 auto; /* Центрирование */
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.5); /* Тень текста */
    font-size: clamp(0.9rem, 1.5vw + 0.4rem, 1.5rem);
}
.banner-description p {
        margin-bottom: 0 !important;
    }

/* Стили для блока "___" */
.about {
    padding: clamp(2rem, 5vw, 4rem) 0;
}

.about p {
    font-size: clamp(1.4rem, 1.5vw + 0.4rem, 1.5rem);
    line-height: clamp(1.3, 1.5vw, 1.6);
    margin-bottom: clamp(0.8rem, 0.8vw + 0.4rem, 1rem);
    color: #333;
    margin-bottom: 0 !important;
    margin-left:0.0pt;
}

.about h2 {
    text-align: center;
    font-size: clamp(1.75rem, 4vw, 2.25rem); /* 28-36px с адаптацией */
    line-height: 1.3; /* Фиксированный для заголовков */
    margin-bottom: clamp(1.5rem, 5vw, 2.5rem); /* 24-40px */
    font-weight: 700; /* Полужирный (Bold) */
    color: #222;
    margin-top: 0;
    font-family: inherit; /* Для согласованности */
    max-width: 30ch; /* Ограничение по ширине в символах */
    margin-left: auto;
    margin-right: auto;
}

/* Стиль для предотвращения переноса телефонных номеров */
.phone-no-wrap,
    a[href^="tel:"] {
        white-space: nowrap;
        display: inline-block;
    }

/* Стили для секции с ценами */
.price-section {
    padding: clamp(2rem, 5vw, 4rem) 0;
}

.price-section h2 {
    text-align: center;
    font-size: clamp(1.75rem, 4vw, 2.25rem); /* 28-36px с адаптацией */
    line-height: 1.3; /* Фиксированный для заголовков */
    margin-bottom: clamp(1.5rem, 5vw, 2.5rem); /* 24-40px */
    font-weight: 700; /* Полужирный (Bold) */
    color: #222;
    margin-top: 0;
    font-family: inherit; /* Для согласованности */
    max-width: 30ch; /* Ограничение по ширине в символах */
    margin-left: auto;
    margin-right: auto;
}

/* Контейнер для списка цен */
.price-list {
    max-width: 800px; /* Максимальная ширина */
    margin: 0 auto; /* Центрирование */
    /* ИЗМЕНЕНО - синхронизировано с .about p */
    font-size: clamp(0.9rem, 1.5vw + 0.4rem, 1.5rem);
    line-height: clamp(1.3, 1.5vw, 1.6);
    color: #333;
}

/* Элемент списка цен */
.price-item {
    display: flex; /* Используем flexbox */
    justify-content: space-between; /* Распределяем пространство между элементами */
    padding: 15px 0; /* Отступы сверху и снизу */
    border-bottom: 1px solid #eee; /* Граница снизу */
}

/* Стили для отзывов */
.testimonials {
    padding: 60px 0; /* Отступы сверху и снизу */
    background-color: #f8f9fa; /* Светло-серый фон */
}

.testimonials h2 {
    text-align: center; /* Выравнивание по центру */
    margin-bottom: 40px; /* Отступ снизу */
}

/* Карточка отзыва */
.testimonials .card {
    height: 100%; /* Высота 100% */
    border: none; /* Убираем границу */
    box-shadow: 0 5px 15px rgba(0,0,0,0.1); /* Тень */
    transition: transform 0.3s; /* Анимация трансформации */
}

/* Эффект при наведении на карточку */
.testimonials .card:hover {
    transform: translateY(-5px); /* Сдвигаем карточку вверх */
}

/* Подвал карточки */
.testimonials .card-footer {
    border-top: 1px solid rgba(0,0,0,0.05); /* Верхняя граница */
}

/* Стили для подвала сайта */
footer {
    background-color: #222; /* Темный фон */
    color: #fff; /* Белый текст */
    padding: 40px 0; /* Отступы сверху и снизу */
    text-align: center; /* Выравнивание по центру */
}

/* Адаптивные стили для устройств с шириной до 768px */
@media (max-width: 768px) {
    .header-container {
        flex-direction: column; /* Элементы в колонку */
        text-align: center; /* Выравнивание по центру */
    }

    .banner-image {
        width: auto;
        height: 100%;
        left: auto; /* Отменяем прижатие к левому краю */
        right: 0; /* Фиксируем к правому краю */
    }

    .logo img {
        margin-bottom: 15px; /* Отступ снизу */
    }

    .img-fluid {
    margin-top: 20px;
    }

    .contacts {
        margin-top: 15px; /* Отступ сверху */
    }

    .banner-container {
        height: 400px; /* Уменьшаем высоту для мобильных */
    }

    .banner-title {
        font-size: 2rem; /* Уменьшаем размер шрифта */
    }

    .banner-description {
        font-size: 1rem; /* Уменьшаем размер шрифта */
    }

    .price-item {
        flex-direction: column; /* Элементы в колонку */
    }

    /* Стили для подвала сайта */
    footer {
        margin-bottom: 40px;
    }
}

/* Адаптивные стили для устройств с шириной до 576px */
@media (max-width: 576px) {
    .banner-container {
        height: 450px; /* Высота баннера */
    }

    .banner-title {
        font-size: 1.5rem; /* Уменьшаем размер шрифта */
    }

    .img-fluid {
    margin-top: 20px;
    }

    /* Стили для подвала сайта */
    footer {
        margin-bottom: 40px;
    }
}

.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
}

/* Стили для изображений с обтеканием */
.ck-content .image-style-alignLeft {
    float: left;
    margin-right: 20px;
    max-width: 50%;
}


/* Дополнительные стили */
.price-section .card {
    border-radius: 0.5rem !important;
}
.price-section .carousel-control-prev,
.price-section .carousel-control-next {
    width: 25px;
    height: 25px;
    top: 50%;
    transform: translateY(-50%);
}
@media (max-width: 768px) {
    .price-section .card-title {
        font-size: 1rem;
    }
    .price-section .card-text {
        font-size: 0.85rem;
    }
    .price-section .fs-5 {
        font-size: 1rem !important;
    }
}

/* Дополнительные стили для мобильных кнопок */
@media (max-width: 767px) {
    .btn {
        min-width: 44px;
        height: 44px;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    .nav-link {
        padding: 8px 0;
    }
    .nav-link i {
        margin-bottom: 4px;
    }
}

/* Сдвигаем банер в мобильной версии */
@media (max-width: 768px) {
    .banner-image {
        transform: translateX(190px); /* Примерно 3 см в пикселях */
        /* Или margin-left: 50px; */
    }
}