Шаблон:Main page/header/styles.css: различия между версиями

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


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


Строка 37: Строка 38:
   font-size: 1rem;
   font-size: 1rem;
   color: #bbb;
   color: #bbb;
   margin-bottom: 2rem; /* Уменьшим, если нужно, чтобы не было слишком много места */
   margin-bottom: 0; /* Убираем нижний отступ, чтобы не влиял на расстояние до поиска */
}
}


.home-header__search {
.home-header__search {
   display: inline-flex; /* Остается inline-flex, так как это хорошо работает внутри */
   display: inline-flex;
   align-items: center;
   align-items: center;
   background: #1d242c;
   background: #1d242c;
Строка 51: Строка 52:
   cursor: text;
   cursor: text;
   transition: all 0.2s ease;
   transition: all 0.2s ease;
   margin-left: 20px; /* Отступ слева от блока поиска, чтобы он не прилипал к тексту */
  max-width: 400px; /* Уменьшаем максимальную ширину для более компактного вида */
   flex-shrink: 0; /* Запрещает поиску уменьшаться, если места мало */
  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; /* Центрируем содержимое внутри блока поиска */
}
}


Строка 86: Строка 100:
     .home-header {
     .home-header {
         flex-direction: column; /* На маленьких экранах выстраиваем элементы вертикально */
         flex-direction: column; /* На маленьких экранах выстраиваем элементы вертикально */
         align-items: flex-start; /* Выравниваем по левому краю */
         align-items: center; /* Центрируем все по горизонтали */
         padding: 20px; /* Увеличим padding для мобильных */
         padding: 20px;
     }
     }


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


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

Версия от 23:02, 25 октября 2025

.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; /* Центрируем и добавляем отступ сверху */
    }
}