/* ==========================================================================
   content-cards.css — единый список-карточек для контентных модулей
   Подключается в: news, articles, press, digest — list.html + category-detail.html
   (Фаза 5.2: дедупликация идентичных <style>-блоков. Карточки этих 4 модулей
    были байт-в-байт одинаковы с точностью до префикса → сгруппированы.)
   practical/books НЕ здесь — у них осознанно иной дизайн (свои размеры/avatar).
   ========================================================================== */

/* ── Заголовок секции + CTA «предложить» ── */
.uv-news-header,
.uv-articles-header,
.uv-press-header,
.uv-digest-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: .75rem;
    margin-bottom: 1.25rem;
}
.uv-news-header h1,
.uv-articles-header h1,
.uv-press-header h1,
.uv-digest-header h1 {
    font-size: var(--uv-fs-h1-mobile);
    font-weight: 600;
    color: var(--uv-text-dark);
    margin: 0;
}
.uv-news-suggest,
.uv-articles-suggest,
.uv-press-suggest {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .4rem .9rem;
    border-radius: 8px;
    font-size: var(--uv-fs-caption);
    font-weight: 600;
    text-decoration: none;
    background: linear-gradient(135deg, var(--uv-primary), var(--uv-primary-dark));
    color: #fff;
    border: none;
    transition: all .25s;
}
.uv-news-suggest:hover,
.uv-articles-suggest:hover,
.uv-press-suggest:hover {
    background: linear-gradient(135deg, var(--uv-primary-dark), var(--uv-primary-hover));
    color: #fff;
    box-shadow: 0 3px 12px rgba(13,110,253,.25);
    transform: translateY(-1px);
}

/* ── Карточка списка ── */
.uv-news-card,
.uv-article-card,
.uv-press-card,
.uv-digest-card {
    display: flex;
    gap: 1rem;
    padding: 1rem 0;
    border-bottom: 1px solid var(--uv-border-light);
    transition: background .15s;
}
.uv-news-card:first-child,
.uv-article-card:first-child,
.uv-press-card:first-child,
.uv-digest-card:first-child { padding-top: 0; }
.uv-news-card:last-child,
.uv-article-card:last-child,
.uv-press-card:last-child,
.uv-digest-card:last-child { border-bottom: none; }
.uv-news-card:hover,
.uv-article-card:hover,
.uv-press-card:hover,
.uv-digest-card:hover { background: #fdfcfa; }

/* Превью */
.uv-news-card-thumb,
.uv-article-card-thumb,
.uv-press-card-thumb,
.uv-digest-card-thumb {
    flex-shrink: 0;
    width: 240px;
    height: 135px;
    border-radius: 8px;
    overflow: hidden;
    background: var(--uv-bg-warm);
}
.uv-news-card-thumb img,
.uv-article-card-thumb img,
.uv-press-card-thumb img,
.uv-digest-card-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .3s ease;
}
.uv-news-card:hover .uv-news-card-thumb img,
.uv-article-card:hover .uv-article-card-thumb img,
.uv-press-card:hover .uv-press-card-thumb img,
.uv-digest-card:hover .uv-digest-card-thumb img {
    transform: scale(1.03);
}
.uv-news-card-thumb-empty,
.uv-article-card-thumb-empty,
.uv-press-card-thumb-empty,
.uv-digest-card-thumb-empty {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--uv-primary);
    font-size: var(--uv-fs-h1);
}

/* Тело */
.uv-news-card-body,
.uv-article-card-body,
.uv-press-card-body,
.uv-digest-card-body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
}

/* Мета */
.uv-news-card-meta,
.uv-article-card-meta,
.uv-press-card-meta,
.uv-digest-card-meta {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .5rem;
    margin-bottom: .4rem;
    font-size: var(--uv-fs-xs);
    color: var(--uv-text-muted);
    font-weight: 500;
}
.uv-news-card-meta i,
.uv-article-card-meta i,
.uv-press-card-meta i,
.uv-digest-card-meta i {
    font-size: var(--uv-fs-micro);
    opacity: .6;
}
.uv-news-card-category,
.uv-article-card-category,
.uv-press-card-category,
.uv-digest-card-category {
    display: inline-block;
    padding: .1rem .45rem;
    border-radius: 4px;
    background: var(--uv-bg-warm);
    border: 1px solid var(--uv-border);
    font-size: var(--uv-fs-micro);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .03em;
    color: var(--uv-text-muted);
}

/* Заголовок */
.uv-news-card-title,
.uv-article-card-title,
.uv-press-card-title,
.uv-digest-card-title {
    font-size: var(--uv-fs-h4);
    font-weight: 600;
    line-height: 1.4;
    margin-bottom: .35rem;
}
.uv-news-card-title a,
.uv-article-card-title a,
.uv-press-card-title a,
.uv-digest-card-title a {
    color: var(--uv-text-dark);
    text-decoration: none;
    transition: color .2s;
}
.uv-news-card-title a:hover,
.uv-article-card-title a:hover,
.uv-press-card-title a:hover,
.uv-digest-card-title a:hover { color: var(--uv-primary); }

/* Анонс */
.uv-news-card-excerpt,
.uv-article-card-excerpt,
.uv-press-card-excerpt,
.uv-digest-card-excerpt {
    font-size: var(--uv-fs-caption);
    color: var(--uv-color-dim);
    line-height: 1.55;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Автор (только articles) */
.uv-article-card-author {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
}
.uv-article-card-author a {
    color: var(--uv-text);
    text-decoration: none;
    font-weight: 600;
    transition: color .2s;
}
.uv-article-card-author a:hover { color: var(--uv-primary); }
.uv-article-card-author img {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    object-fit: cover;
}

/* Адаптив */
@media (max-width: 767px) {
    .uv-news-card,
    .uv-article-card,
    .uv-press-card,
    .uv-digest-card { flex-direction: column; gap: .5rem; }
    .uv-news-card-thumb,
    .uv-article-card-thumb,
    .uv-press-card-thumb,
    .uv-digest-card-thumb { width: 100%; height: 180px; }
}
