:root {
    --brand-green-color: #02ea02;  /* Брендовый зеленый цвет */
}

/* Подключение шрифтов start */
@font-face {
    font-family: 'Fira Sans';
    src: url('../fonts/FiraSans-Regular.woff2') format('woff2'),
         url('../fonts/FiraSans-Regular.woff') format('woff');
    font-weight: 400;
    font-style: normal;
}

@font-face {
    font-family: 'Fira Sans';
    src: url('../fonts/FiraSans-Bold.woff2') format('woff2'),
         url('../fonts/FiraSans-Bold.woff') format('woff');
    font-weight: 700;
    font-style: normal;
}

@font-face {
    font-family: 'Fira Sans';
    src: url('../fonts/FiraSans-Italic.woff2') format('woff2'),
         url('../fonts/FiraSans-Italic.woff') format('woff');
    font-weight: 400;
    font-style: italic;
}

@font-face {
    font-family: 'Fira Sans';
    src: url('../fonts/FiraSans-BoldItalic.woff2') format('woff2'),
         url('../fonts/FiraSans-BoldItalic.woff') format('woff');
    font-weight: 700;
    font-style: italic;
}
/* Подключение шрифтов end */

/* БАЗОВЫЕ СТИЛИ ДЛЯ ВСЕГО САЙТА start */
/* Обнуление стилей */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

/* Шрифты и цвета */
body {
    font-family: 'Fira Sans', sans-serif;
    font-size: 16px;
    line-height: 1.5;
    color: #f8f8f8;  /* светлый цвет шрифта для темной темы */
    background-color: #121212;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

/* Стандартные стили заголовков */
h1, h2, h3, h4, h5, h6 {
    margin: 20px 0;
    line-height: 1.2;
    color: #f8f8f8;  /* светлый цвет шрифта для заголовков */
}
h1 { font-size: 1.25em; }
h2 { font-size: 1.25em; }
h3 { font-size: 1.25em; }
h4 { font-size: 1.25em; }
h5 { font-size: 1em; }
h6 { font-size: 1em; }

/* Стили ссылок */
a {
    color: #f8f8f8;  /* яркий цвет ссылок для контраста */
    text-decoration: none;
    transition: color 0.2s ease-in-out;
}
a:hover, a:focus {
    color: var(--brand-green-color);  /* цвет при наведении */
    /* text-decoration: underline; */
    text-decoration: none;
}
/* Стили ссылок в навбаре */
.navbar-nav .nav-link:hover, .navbar-nav .nav-link:focus {
    text-decoration: underline;
}

/* Кнопки */
button {
    padding: 10px 20px;
    font-size: 1em;
    color: #fff;
    background-color: #ff1e1e;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    transition: background-color 0.2s ease-in-out;
}
button:hover, button:focus {
    background-color: #fff;
}

/* Цвет фона выделенного текста */
/* Для всех браузеров, кроме Firefox */
::selection {
    background-color: var(--brand-green-color);
    color: #000; /* Цвет текста */
}
/* Для Firefox */
::-moz-selection {
    background-color: var(--brand-green-color);
    color: #000; /* Цвет текста */
}
/* Стили для breadcrumb start */
.breadcrumb-item.active {
    color: #fff;
}
.breadcrumb-item + .breadcrumb-item::before {
    color: #fff !important; /* Принудительно устанавливаем цвет разделителя */
}
/* Стили для breadcrumb end */
/* БАЗОВЫЕ СТИЛИ ДЛЯ ВСЕГО САЙТА end */

main {
    background-color: #303030;
    flex-grow: 1; /* Растягиваем main на всё оставшееся пространство */
}

/* Высота блока main */
.height-viewport {
    height: 70vh;
}

.welcome {
    padding-left: 5 !important;
    padding-right: 5 !important;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
}

/* СТИЛИ КНОПОК start */
/* Задаем цвет кнопки при наведении */
.btn-outline-success:hover {
    border-color: var(--brand-green-color) !important;
    background-color: var(--brand-green-color) !important;
    box-shadow: none !important;
}
/* Задаем цвет кнопки при нажатии */
.btn-outline-success:active,
.btn-outline-success:focus,
.btn-outline-success:focus-visible {
    border-color: var(--brand-green-color) !important;
    background-color: var(--brand-green-color) !important;
    box-shadow: none !important;
}
/* Задаем цвет кнопки при удержании на мобильных устройствах */
.btn-outline-success:active,
.btn-outline-success:focus,
.btn-outline-success:focus-visible {
    border-color: var(--brand-green-color) !important;
    background-color: var(--brand-green-color) !important;
    box-shadow: none !important;
}
/* СТИЛИ КНОПОК end */

/* NAVBAR start */
.navbar .nav-link {
    font-weight: 400;
    font-size: 1.3rem;
}
.navbar-brand {
    margin-right: 0 !important;
}
/* Переопределяем цвет подсветки поля input */
.form-control:focus {
    border-color: var(--brand-green-color); /* зеленый цвет границы */
    box-shadow: 0 0 0 0.25rem rgba(2, 234, 2, 0.25); /* зеленый цвет тени */
}
/* Задаем цвет крестика для удаления текста */
input[type="search"]::-webkit-search-cancel-button {
    -webkit-appearance: none;
    height: 16px;
    width: 16px;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='%2302ea02' d='M9.414 8l4.95-4.95a1 1 0 0 0-1.414-1.415L8 6.586 3.05 1.636A1 1 0 0 0 1.636 3.05L6.586 8l-4.95 4.95a1 1 0 0 0 1.415 1.414L8 9.414l4.95 4.95a1 1 0 0 0 1.415-1.415L9.414 8z'/%3E%3C/svg%3E") center / contain no-repeat;
}
.nav-link {
    color: #ffffff;
}
.nav-link:hover {
    color: var(--brand-green-color);
}
.navbar-nav .nav-link.active {
    color: var(--brand-green-color);
}
.navbar-toggler {
    background-color: #fffcee;
}
.navbar-toggler:focus {
    box-shadow: none;
}
.btn-outline-success {
    color: #ffffff;
    border-color: #ffffff;
}
.btn-outline-success:hover {
    border-color: var(--brand-green-color);
    background-color: var(--brand-green-color);
}
/* Цвет текста в активной ссылке */
.navbar-nav .nav-link:active, .navbar-nav .nav-link:focus {
    color: #ffffff;
}
/* Задаем темный фон для выпадающего меню */
.dropdown-menu {
    background-color: #303030;  /* темный фон */
    color: #f8f8f8;  /* светлый цвет текста */
}
/* Задаем цвет текста в пунктах меню */
.dropdown-menu .dropdown-item {
    color: #f8f8f8;  /* светлый цвет текста */
}
/* Задаем цвет при наведении на пункт меню */
.dropdown-menu .dropdown-item:hover, .dropdown-menu .dropdown-item:focus {
    background-color: var(--brand-green-color);  /* зеленый фон */
    color: #303030;  /* темный цвет текста */
}
/* Убираем синюю рамку при нажатии на элементы навигационного меню */
.nav-link:focus,
.dropdown-item:focus {
    outline: none !important;
    box-shadow: none !important;
}
.about {
    margin-right: 40px;
}
/* Выравнивание по центру логотипа и формы поиска */
@media (max-width: 767px) {
    .navbar .container {
        display: flex;
        flex-direction: column;
        align-items: center;
    }
    .navbar .container .navbar-brand,
    .navbar .container .d-flex {
        width: 100%;
        display: flex;
        justify-content: center;
        margin-bottom: 10px; /* добавляет отступ между логотипом и формой поиска */
    }
}

/* NAVBAR end */

/* OFFER CARD start */
.card-offer {
    background-color: transparent !important;
    border: none !important;
}

.card-offer .card-title {
    color: #f8f8f8 !important;
}

.card-body {
    padding: 0;
}

/* Размер логотипов офферов */
.card-offer .card-img-top {
    width: 20vw;
    max-width: 100px;
    height: auto;
    margin: 0 auto; /* Центрирование изображения */
    display: block; /* Устанавливаем display как block */
}
/* OFFER CARD end */

/* BOOTSTRAP start */
/* Переопределение значений переменных CSS Bootstrap */
:root {
    --bs-dark-bg-subtle: #343a40;  /* Ваш выбранный цвет */
}

/* Переопределение отступов для классов .row */
.row {
    margin-right: 0 !important;
    margin-left: 0 !important;
    padding-right: 0 !important;
    padding-left: 0 !important;
}

/* BOOTSTRAP end */

/* Выравнивание по центру элементов на всех экранах */
.text-center {
    text-align: center !important;
}
