Шаблон:Main page/header/styles.css

Материал из SS220 SS14 WIKI
.home-header {
  /* text-align: center; */ /* Убираем центрирование родителя */
  margin: 3rem 0;
  display: flex; /* Делаем контейнер гибким */
  justify-content: flex-start; /* Выравниваем элементы к началу (слева) */
  align-items: center; /* Выравниваем элементы по центру по вертикали */
  width: 100%; /* Занимаем всю доступную ширину */
  box-sizing: border-box;
  padding: 0 20px; /* Добавим немного горизонтальных отступов */
  flex-wrap: wrap; /* Позволяет элементам переноситься на новую строку */
  position: relative; /* Нужен для позиционирования поиска */
}

.home-header-text-group {
    display: flex;
    flex-direction: column; /* Элементы внутри будут располагаться вертикально */
    flex-grow: 1; /* Позволяет текстовому блоку занимать все доступное пространство слева */
    text-align: left; /* Выравнивание текста влево */
    /* margin-right: auto; */ /* Можно использовать для выталкивания поиска вправо, но здесь попробуем по-другому */
}

.home-header__pretitle {
  color: #7faad9;
  font-size: 0.9rem;
  letter-spacing: 1px;
  margin-bottom: 0.5rem;
  text-transform: uppercase;
}

.home-header__title {
  font-size: 2.5rem;
  font-weight: 700;
  color: #fff;
  margin: 0.5rem 0;
}

.home-header__subtitle {
  font-size: 1rem;
  color: #bbb;
  margin-bottom: 0; /* Убираем нижний отступ, чтобы не влиял на расстояние до поиска */
}

.home-header__search {
  display: inline-flex;
  align-items: center;
  background: #1d242c;
  border: 1px solid #2e3a46;
  border-radius: 12px;
  padding: 0.7rem 1.2rem;
  font-size: 0.95rem;
  color: #ccc;
  cursor: text;
  transition: all 0.2s ease;
  max-width: 400px; /* Уменьшаем максимальную ширину для более компактного вида */
  width: 100%; /* Позволяем ему быть гибким */

  /* Для центрирования относительно родителя с flex: */
  position: absolute; /* Позиционируем абсолютно */
  left: 50%; /* Начинаем от середины родителя */
  transform: translateX(-50%); /* Сдвигаем назад на половину своей ширины */
  top: 50%; /* Относительно середины родителя */
  transform: translate(-50%, -50%); /* Сдвигаем на половину своей ширины и высоты */

  /* Дополнительные корректировки для вертикального позиционирования */
  margin-top: 80px; /* Отступ от верхнего края, чтобы опустить его ниже заголовка */
  min-width: 280px; /* Минимальная ширина, чтобы не был слишком узким */
  box-sizing: border-box; /* Важно для padding и width */
  justify-content: center; /* Центрируем содержимое внутри блока поиска */
}

.home-header__search:hover {
  border-color: #4a90e2;
  color: #fff;
}

.home-header__searchIcon {
  margin-right: 0.6rem;
  opacity: 0.7;
}

.home-header__searchText a {
  color: #7faad9;
  text-decoration: none;
}

.home-header__searchText a:hover {
  text-decoration: underline;
}

kbd {
  background: #2e3a46;
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 0.85rem;
  color: #eee;
}

/* Медиа-запрос для адаптивности на маленьких экранах */
@media (max-width: 768px) {
    .home-header {
        flex-direction: column; /* На маленьких экранах выстраиваем элементы вертикально */
        align-items: center; /* Центрируем все по горизонтали */
        padding: 20px;
    }

    .home-header-text-group {
        width: 100%;
        text-align: center; /* Текст тоже по центру на мобильных */
        margin-bottom: 20px; /* Отступ между текстом и поиском */
    }

    .home-header__search {
        position: static; /* Отключаем абсолютное позиционирование на мобильных */
        transform: none; /* Убираем трансформации */
        width: 90%; /* Занимает 90% ширины */
        max-width: none; /* Снимаем ограничение max-width */
        margin: 20px auto 0 auto; /* Центрируем и добавляем отступ сверху */
    }
}