/*-------------------
    THEME SWITCHER
 -------------------*/
.theme-toggle {
  display: none;
}

.theme-label {
  cursor: pointer;
  position: relative;
  display: block;
  width: 60px;
  height: 30px;
  background: var(--secondary-bg);
  border: 1px solid var(--gray);
  border-radius: 15px;
  transition: 0.3s;
}

.theme-icon {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1.2rem;
  transition: 0.3s;
  display: flex;
  align-items: center;
  justify-content: center;
}

.theme-icon.moon svg {
  fill: var(--text-color);
}

.theme-icon.sun svg {
  fill: yellow;
}

.moon { left: 5px; opacity: 1; }
.sun { right: 5px; opacity: 0; }

.theme-toggle:checked + .theme-label .moon { opacity: 0; }
.theme-toggle:checked + .theme-label .sun { opacity: 1; }


.theme-switcher {
  padding: 15px;
}


.theme-label:before {
  content: '';
  position: absolute;
  top: 3px;
  left: 3px;
  width: 22px;
  height: 22px;
  background: var(--gray);
  border-radius: 50%;
  transition: all 0.3s ease;
}

.theme-toggle:checked + .theme-label {
  background: #0088ff;
}

.theme-toggle:checked + .theme-label:before {
  left: calc(100% - 24px);
}

/*----------
  COMMON
----------*/
html, body {
  height: 100%!important;
  margin: 0;
  padding: 0;
  overflow-x: hidden;
}


body {
  background-color: var(--primary-bg);
  transition: background-color 0.3s, color 0.3s;
  display: flex;
  min-height: 100vh!important;
  padding-top: env(safe-area-inset-top);
  padding-bottom: env(safa-area-inset-bottom);
}

.btn-primary {
  background-color: var(--accent-color);
  border-color: var(--accent-color);
}


.main-content {
  display: flex;
  flex-direction: column; /* Позволяет вложенным элементам заполнять высоту */
  flex: 1; /* Забирает всё оставшееся пространство */
  min-height: 0; /* Устраняет переполнение */
}



#bodyWrapper {
  transition: all .5s;
  border-radius: 25px;
  background-color: var(--secondary-bg);
  display: flex;
  flex: 1;
}

/* Ширина < 991px */
@media (max-width: 991px) {
  #bodyWrapper {
    margin: 0 1rem 1rem 1rem;
  }

  #bodyWrapper.full {
    margin: 0 1rem 1rem 1rem;
  }
}


/* Ширина > 992px */
@media (min-width: 992px) {
  #bodyWrapper {
    margin: 0 2rem 2rem 0;
  }

  #bodyWrapper.full {
    margin: 0 2rem 2rem 2rem;
  }

}



/****************************************
        КОНТЕЙНЕР КАРТОЧЕК
****************************************/
.cards-container {
  display: grid; /* Используем сеточный подход */
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); /* Автоподстройка колонок */
  gap: 1.5rem; /* Расстояние между карточками */
  padding: 1rem; /* Внешние отступы контейнера */
}

/****************************************
            КАРТОЧКА
****************************************/
.card {
  display: flex; /* Flexbox для содержимого карточки */
  height: 220px;
  flex-direction: column; /* Ориентация вертикальная */
  background-color: var(--secondary-bg); /* Цвет фона карточки */
  border-radius: 12px; /* Закругляем углы */
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); /* Лёгкая тень */
  overflow: hidden; /* Обрезаем всё, что выходит за пределы */
  transition: transform 0.3s ease, box-shadow 0.3s ease; /* Анимация при наведении */
}

/* Эффект при наведении на карточку */
.card:hover {
  transform: translateY(-5px); /* Карточка немного поднимается */
  box-shadow: 0 6px 12px rgba(0, 0, 0, 0.15); /* Добавляем больше тени */
}

/* Изображение */
.card-image {
  width: 100%; /* На всю ширину карточки */
  height: 180px; /* Фиксированная высота изображения */
  object-fit: cover; /* Картинка подстраивается под размеры */
}

/* Контент карточки */
.card-content {
  padding: 1rem; /* Внутренние отступы в контенте карточки */
  display: flex;
  flex-direction: column; /* Элементы располагаются вертикально */
  gap: 0.75rem; /* Расстояние между элементами */
}

/* Заголовок карточки */
.card-title {
  font-size: 1.25rem; /* Увеличенный шрифт */
  font-weight: bold; /* Жирное написание */
  color: var(--text-color); /* Цвет основного акцента текста */
  margin: 0; /* Убираем отступы сверху и снизу */
}

/* Описание карточки */
.card-description {
  font-size: 1rem; /* Обычный слайдер текста */
  color: var(--secondary-text-color); /* Цвет для описания */
  flex-grow: 1; /* Занимает оставшееся пространство */
}

/* Кнопка */
.card-button {
  display: inline-block;
  padding: 0.5rem 1rem; /* Просторная кнопка */
  font-size: 1rem; /* Размер текста кнопки */
  color: #ffffff; /* Белый текст */
  background-color: var(--accent-color); /* Акцентный цвет фона */
  border: none; /* Убираем границы */
  border-radius: 8px; /* Закруглённые углы для кнопки */
  text-align: center;
  text-decoration: none; /* Убираем подчёркивание */
  transition: background-color 0.3s ease;
}

.card-button:hover {
  background-color: var(--accent-color); /* Затемнение при наведении */
}

/****************************************
            АДАПТИВНОСТЬ
****************************************/
@media (max-width: 768px) {
  .card-image {
    height: 150px; /* Уменьшаем высоту изображения */
  }

  .card-title {
    font-size: 1.1rem; /* Уменьшаем размер заголовка */
  }

  .card-description {
    font-size: 0.95rem; /* Уменьшаем описание */
  }
}

@media (max-width: 576px) {
  .cards-container {
    padding: 0.5rem; /* Уменьшаем отступы контейнера */
    gap: 1rem; /* Уменьшаем расстояние между карточками */
  }

  .card {
    border-radius: 8px; /* Чуть меньшие закругления */
  }

  .card-content {
    padding: 0.75rem; /* Уменьшаем отступы карточки */
  }
}

