/* Кастомные стили поверх Tailwind. */

html, body {
  height: 100%;
  margin: 0;
  overscroll-behavior: none;
}
body {
  padding-top: env(safe-area-inset-top);
  padding-bottom: 0; /* safe-area для нижних карточек добавим внутри карусели */
}

* { -webkit-tap-highlight-color: transparent; }

/* --- App shell: фикс шапка + горизонтальная карусель --- */
.app-shell {
  display: flex;
  flex-direction: column;
  height: 100dvh;          /* динамическая высота: учитывает свернутый бар на iOS */
  max-width: 600px;
  margin: 0 auto;
  overflow: hidden;
}
.app-header {
  flex-shrink: 0;
  position: sticky;
  top: 0;
  z-index: 20;
}

.carousel {
  flex: 1 1 auto;
  display: flex;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  scroll-snap-stop: always;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.carousel::-webkit-scrollbar { display: none; }
.carousel-col {
  flex: 0 0 100%;
  width: 100%;
  scroll-snap-align: start;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-y: contain;   /* не пробрасывать вертикальный bounce наружу */
}
.carousel-col::-webkit-scrollbar { width: 0; }
.carousel-col-inner {
  padding-bottom: env(safe-area-inset-bottom);
}

/* Активная иконка-таб категории */
.cat-tab { position: relative; cursor: pointer; }
.cat-tab-active::after {
  content: '';
  position: absolute;
  left: 25%; right: 25%; bottom: 0;
  height: 2px;
  border-radius: 2px;
  background: #fafafa;
}

/* Подсветка нажатой реакции */
.reaction-btn { filter: grayscale(0.4) opacity(0.85); }
.reaction-btn.reacted {
  filter: none;
  text-shadow: 0 0 12px rgba(255, 255, 255, 0.45);
  transform: scale(1.15);
}

/* line-clamp для старых браузеров */
.line-clamp-2 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

nav::-webkit-scrollbar { display: none; }
