/* Переверстка Тильдиного feed (/blog, /our-projects).
 *
 * Тильда использует display:table на <ul class="t-feed__container"> и
 * фиксированные inline-height на карточках, рассчитанные на момент
 * экспорта — это даёт «лесенку». Перебиваем CSS-grid с фиксированными
 * высотами картинок и кламп строк текста — все карточки одинакового
 * размера и форма. */

ul.t-feed__container,
ul.js-feed-container {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 30px;
    width: 100%;
    max-width: 1200px;
    margin: 0 auto !important;        /* центрируем сетку в родителе */
    padding: 0;
    box-sizing: border-box;
    list-style: none;
    border-collapse: separate;
}

@media (max-width: 1199px) {
    ul.t-feed__container,
    ul.js-feed-container { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 899px) {
    ul.t-feed__container,
    ul.js-feed-container { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 20px; }
}
@media (max-width: 559px) {
    ul.t-feed__container,
    ul.js-feed-container { grid-template-columns: 1fr; padding: 0 16px; }
}

/* Карточка — flex-колонка одинаковой структуры */
.t-feed__container > .js-feed-post {
    display: flex !important;
    flex-direction: column;
    width: auto !important;
    max-width: none !important;     /* перебиваем max-width: 180px из Tilda CSS */
    min-width: 0;
    margin: 0 !important;
    padding: 0 !important;
    float: none !important;
    transition-delay: 0s !important;
}

/* Состояние «скрыто фильтром» — побеждает display: flex !important выше */
.t-feed__container > .js-feed-post.is-feed-hidden {
    display: none !important;
}

/* Внутренняя обёртка занимает всю высоту карточки */
.js-feed-post .t-feed__col-grid__post-wrapper {
    height: 100% !important;
    min-height: 0 !important;
    width: 100%;
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
}

/* Картинки — фиксированная пропорция, одного размера у всех */
.js-feed-post .t-feed__post-imgwrapper {
    flex-shrink: 0;
    width: 100% !important;
    aspect-ratio: 4 / 3 !important;     /* единый формат для всех */
    height: auto !important;
    margin: 0 !important;
    overflow: hidden;
    position: relative;
}
.js-feed-post .t-feed__post-bgimg {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background-size: cover !important;
    background-position: center !important;
}

/* Текстовая часть — растягивается, кламп строк → одинаковый размер */
.js-feed-post .t-feed__col-grid__wrapper {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    padding: 14px 4px;
}
.js-feed-post .t-feed__textwrapper {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.js-feed-post .t-feed__post-title {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: 2.6em;            /* зарезервировать место под 2 строки */
}
.js-feed-post .t-feed__post-descr {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
