/**
 * Lumina Theme — cards.css
 *
 * Сетка карточек: блог, архивы, таксономии, поиск.
 *
 * CSS-переменные (задаются через lumina_cards_inline_css):
 *   --lumina-cols        — колонок в обычных строках
 *   --lumina-cols-first  — колонок в первой строке (только стр.1)
 *   --lumina-card-span   — span первых карточек = floor(max/cols-first)
 *   --lumina-card-aspect — aspect-ratio изображений
 *   --lumina-card-gap    — отступ между карточками
 */

:root {
    --lumina-cols:        3;
    --lumina-cols-first:  4;
    --lumina-card-span:   1;
    --lumina-card-aspect: 4/3;
    --lumina-card-gap:    var(--wp--preset--spacing--xl);
}

/* ── Сетка ───────────────────────────────────────────────────────────────── */

.lumina-cards-query .wp-block-post-template {
    display: grid !important;
    grid-template-columns: repeat( var(--lumina-cols), 1fr );
    gap: var(--lumina-card-gap) !important;
    list-style: none;
    margin: 0;
    padding: 0;
}

/* На первой странице — первые N карточек шире */
.lumina-cards-query .wp-block-post-template > li.lumina-card--featured {
    grid-column: span var(--lumina-card-span);
}

/* На страницах 2+ — все одинаковые */
.lumina-cards-query.lumina-query--inner-page .wp-block-post-template > li {
    grid-column: span 1 !important;
}

/* ── Карточка ────────────────────────────────────────────────────────────── */

.lumina-cards-query .wp-block-post-template > li {
    display: flex;
    flex-direction: column;
    min-width: 0;
    padding: var(--wp--preset--spacing--sm);
    border: 1px solid var(--wp--preset--color--base-3, rgba(0,0,0,.10));
    border-radius: 0;
    box-shadow: 0 2px 8px rgba(0,0,0,.06), 0 0 1px rgba(0,0,0,.04);
    background: var(--wp--preset--color--base, #fff);
    transition: box-shadow 0.2s ease;
}

.lumina-cards-query .wp-block-post-template > li:hover {
    box-shadow: 0 6px 20px rgba(0,0,0,.10), 0 0 1px rgba(0,0,0,.06);
}

/* Изображение */
.lumina-cards-query .wp-block-post-featured-image {
    overflow: hidden;
    border-radius: 0;
    background: var(--wp--preset--color--base-2, #f0f0f0);
    margin: 0;
}

.lumina-cards-query .wp-block-post-featured-image a {
    display: block;
    aspect-ratio: var(--lumina-card-aspect);
    overflow: hidden;
}

.lumina-cards-query .wp-block-post-featured-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.32s ease;
}

.lumina-cards-query .wp-block-post-featured-image a:hover img {
    transform: scale(1.04);
}

/* Без изображения — серый плейсхолдер */
.lumina-cards-query .wp-block-post-featured-image:not(:has(img)) {
    aspect-ratio: var(--lumina-card-aspect);
}

/* Заголовок */
.lumina-cards-query .wp-block-post-title {
    margin: var(--wp--preset--spacing--sm) 0 0;
    font-size: var(--wp--preset--font-size--sm);
    font-weight: 500;
    line-height: 1.35;
}

.lumina-cards-query .wp-block-post-title a {
    text-decoration: none;
    color: var(--wp--preset--color--contrast);
    transition: color 0.15s ease;
}

.lumina-cards-query .wp-block-post-title a:hover {
    color: var(--wp--preset--color--contrast-2);
}

/* ── Пагинация ───────────────────────────────────────────────────────────── */

.lumina-cards-query .wp-block-query-pagination {
    margin-top: var(--wp--preset--spacing--2xl);
}

/* ── Адаптивность ────────────────────────────────────────────────────────── */

@media ( max-width: 1024px ) {
    .lumina-cards-query .wp-block-post-template {
        grid-template-columns: repeat( 2, 1fr ) !important;
    }
    .lumina-cards-query .wp-block-post-template > li.lumina-card--featured,
    .lumina-cards-query .wp-block-post-template > li {
        grid-column: span 1 !important;
    }
}

@media ( max-width: 600px ) {
    .lumina-cards-query .wp-block-post-template {
        grid-template-columns: 1fr !important;
    }
}

/* ── Reduced motion ──────────────────────────────────────────────────────── */

@media ( prefers-reduced-motion: reduce ) {
    .lumina-cards-query .wp-block-post-featured-image img {
        transition: none;
    }
}

/* ── Второй grid (два-контейнера режим) ──────────────────────────────────── */

.lumina-cards-query .wp-block-post-template.lumina-pt--first-row {
    grid-template-columns: repeat( var(--lumina-cols-first), 1fr );
    margin-bottom: var(--lumina-card-gap);
}

/* ── Заглушки для заполнения последней строки ────────────────────────────── */

.lumina-cards-query .lumina-card-placeholder {
    visibility: hidden;
    pointer-events: none;
}

/* Скрываем изображение-заглушку если нет featured image */
.lumina-cards-query .wp-block-post-featured-image:empty {
    display: none;
}

/* ── Два grid: первая строка ────────────────────────────────────────────── */

.lumina-cards-query .wp-block-post-template.lumina-pt--first {
    grid-template-columns: repeat( var(--lumina-cols-first), 1fr );
    margin-bottom: var(--lumina-card-gap);
}

/* ── Заглушки для выравнивания последней строки ─────────────────────────── */

.lumina-cards-query .wp-block-post-template > li.lumina-card--ghost {
    visibility: hidden;
    pointer-events: none;
}
