/**
 * FILTER THE GOV — BLOG CARDS v2.0
 * Grid-based cards inspired by competitor analysis:
 * - 3-col responsive grid (the proven niche standard)
 * - Category badges with accent colors
 * - Hover lift + accent glow shadow
 * - Card-wide click areas (mobile-first)
 * - 16:9 featured images with consistent aspect ratio
 * - Metadata row: category | date | read time
 *
 * Added: 2026-05-30
 * Author: OWL
 */

/* ============================================
   BLOG GRID LAYOUT
   Container: turn the blog loop into a grid
   ============================================ */
.blog .site-main,
.archive .site-main,
.search .site-main {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 2rem !important;
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 2rem 1rem !important;
}

/* Make each post a flex container for full-height cards */
.blog .post,
.archive .post,
.search .post {
    display: flex !important;
    flex-direction: column !important;
    background: var(--color-surface) !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-md) !important;
    margin-bottom: 0 !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    overflow: hidden !important;
    position: relative !important;
}

.blog .post:hover,
.archive .post:hover {
    border-color: var(--color-accent-2) !important;
    transform: translateY(-6px) !important;
    box-shadow: 0 12px 40px rgba(46, 196, 166, 0.18), 0 4px 12px rgba(0, 0, 0, 0.4) !important;
}

/* ============================================
   FEATURED IMAGE
   16:9 aspect ratio, full-width card top
   ============================================ */
.blog .post .post-image,
.archive .post .post-image {
    margin: 0 !important;
    border-radius: 0 !important;
    overflow: hidden !important;
    position: relative !important;
    aspect-ratio: 16 / 9 !important;
    width: 100% !important;
    flex-shrink: 0 !important;
}

.blog .post .post-image img,
.archive .post .post-image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    transition: transform 0.4s ease !important;
}

.blog .post:hover .post-image img,
.archive .post:hover .post-image img {
    transform: scale(1.05) !important;
}

/* Placeholder for posts without featured images */
.blog .post .post-image:not(:has(img)),
.archive .post .post-image:not(:has(img)),
.blog .post:not(:has(.post-image)),
.archive .post:not(:has(.post-image)) {
    /* Fallback: colored gradient placeholder via pseudo-element on the card */
}

/* ============================================
   CATEGORY BADGE
   Overlaid on bottom-left of featured image
   ============================================ */
.blog .post .post-image .categories,
.archive .post .post-image .categories,
.blog .post .category-badge,
.archive .post .category-badge {
    position: absolute !important;
    bottom: 12px !important;
    left: 12px !important;
    z-index: 2 !important;
}

/* Category badge styling — works with GP's default output */
.blog .post .post-image .categories a,
.archive .post .post-image .categories a,
.blog .post .category-badge a,
.archive .post .category-badge a,
.blog .post .entry-terms,
.archive .post .entry-terms {
    display: inline-block !important;
    padding: 4px 12px !important;
    font-family: var(--font-body) !important;
    font-size: 0.7rem !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    border-radius: 9999px !important;
    text-decoration: none !important;
    line-height: 1 !important;
}

/* Default: teal accent for category pills */
.blog .post .post-image .categories a,
.archive .post .post-image .categories a,
.blog .post .category-badge a,
.archive .post .category-badge a {
    background: rgba(46, 196, 166, 0.9) !important;
    color: #0f1114 !important;
    backdrop-filter: blur(4px) !important;
}

/* ============================================
   CARD BODY (inside-article)
   ============================================ */
.blog .post .inside-article,
.archive .post .inside-article {
    padding: 1.25rem !important;
    background: transparent !important;
    display: flex !important;
    flex-direction: column !important;
    flex: 1 !important;
}

/* ============================================
   METADATA ROW
   Category | Date | Read Time
   ============================================ */
.blog .post .entry-meta,
.archive .post .entry-meta {
    display: flex !important;
    align-items: center !important;
    gap: 0.5rem !important;
    color: var(--color-body-alt) !important;
    font-size: 0.75rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
    margin-bottom: 0.75rem !important;
    flex-wrap: wrap !important;
}

.blog .post .entry-meta .posted-on,
.archive .post .entry-meta .posted-on {
    color: var(--color-body-alt) !important;
}

.blog .post .entry-meta .byline,
.archive .post .entry-meta .byline {
    color: var(--color-accent-2) !important;
    font-weight: 600 !important;
}

/* Separator dots between meta items */
.blog .post .entry-meta > *:not(:last-child)::after,
.archive .post .entry-meta > *:not(:last-child)::after {
    content: '•' !important;
    margin-left: 0.5rem !important;
    color: var(--color-border) !important;
}

/* ============================================
   ENTRY TITLE
   ============================================ */
.blog .post .entry-title,
.archive .post .entry-title {
    font-size: 1.1rem !important;
    line-height: 1.35 !important;
    margin-bottom: 0.5rem !important;
    font-family: var(--font-heading) !important;
    text-transform: none !important;
    letter-spacing: 0.02em !important;
}

.blog .post .entry-title a,
.archive .post .entry-title a {
    color: var(--color-heading) !important;
    text-decoration: none !important;
    transition: color 0.2s ease !important;
}

.blog .post .entry-title a:hover,
.archive .post .entry-title a:hover {
    color: var(--color-accent-2) !important;
    text-decoration: none !important;
}

/* ============================================
   EXCERPT
   Clamped to 3 lines for uniform card height
   ============================================ */
.blog .post .entry-summary,
.archive .post .entry-summary {
    color: var(--color-body) !important;
    font-size: 0.88rem !important;
    line-height: 1.6 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 3 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    flex: 1 !important;
    margin-bottom: 1rem !important;
}

.blog .post .entry-summary p,
.archive .post .entry-summary p {
    color: var(--color-body) !important;
    margin-bottom: 0 !important;
}

/* ============================================
   READ MORE CTA
   Teal arrow link at card bottom
   ============================================ */
.blog .post .entry-summary a,
.archive .post .entry-summary a,
.blog .post .read-more,
.archive .post .read-more,
.blog .post .cat-links a,
.archive .post .cat-links a {
    display: inline-flex !important;
    align-items: center !important;
    gap: 0.25rem !important;
    color: var(--color-accent-2) !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
    font-size: 0.78rem !important;
    text-decoration: none !important;
    margin-top: auto !important;
    transition: all 0.2s ease !important;
    border: none !important;
    background: none !important;
    padding: 0 !important;
}

.blog .post .entry-summary a::after,
.archive .post .entry-summary a::after,
.blog .post .read-more::after,
.archive .post .read-more::after {
    content: '→' !important;
    font-size: 1.1em !important;
    transition: transform 0.2s ease !important;
}

.blog .post .entry-summary a:hover,
.archive .post .entry-summary a:hover,
.blog .post .read-more:hover,
.archive .post .read-more:hover {
    color: var(--color-accent-hover) !important;
    text-decoration: none !important;
}

.blog .post .entry-summary a:hover::after,
.archive .post .entry-summary a:hover::after,
.blog .post .read-more:hover::after,
.archive .post .read-more:hover::after {
    transform: translateX(3px) !important;
}

/* ============================================
   CARD-WIDE CLICK AREA
   Makes the entire card clickable via :after
   ============================================ */
.blog .post .entry-title a::after,
.archive .post .entry-title a::after {
    content: '' !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    z-index: 1 !important;
}

/* Push interactive elements above the overlay */
.blog .post .post-image,
.archive .post .post-image,
.blog .post .read-more,
.archive .post .read-more {
    position: relative !important;
    z-index: 2 !important;
}

/* ============================================
   STAGGERED ENTRANCE ANIMATION
   Cards fade in with slight upward motion
   ============================================ */
@keyframes cardFadeIn {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.blog .post,
.archive .post {
    animation: cardFadeIn 0.5s ease-out both !important;
}

/* Staggered delays */
.blog .post:nth-child(1), .archive .post:nth-child(1) { animation-delay: 0.05s !important; }
.blog .post:nth-child(2), .archive .post:nth-child(2) { animation-delay: 0.1s !important; }
.blog .post:nth-child(3), .archive .post:nth-child(3) { animation-delay: 0.15s !important; }
.blog .post:nth-child(4), .archive .post:nth-child(4) { animation-delay: 0.2s !important; }
.blog .post:nth-child(5), .archive .post:nth-child(5) { animation-delay: 0.25s !important; }
.blog .post:nth-child(6), .archive .post:nth-child(6) { animation-delay: 0.3s !important; }
.blog .post:nth-child(7), .archive .post:nth-child(7) { animation-delay: 0.35s !important; }
.blog .post:nth-child(8), .archive .post:nth-child(8) { animation-delay: 0.4s !important; }
.blog .post:nth-child(n+9), .archive .post:nth-child(n+9) { animation-delay: 0.45s !important; }

/* ============================================
   RESPONSIVE BREAKPOINTS
   ============================================ */

/* Tablet: 2 columns */
@media (max-width: 1024px) {
    .blog .site-main,
    .archive .site-main,
    .search .site-main {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 1.5rem !important;
    }
}

/* Mobile: 1 column */
@media (max-width: 640px) {
    .blog .site-main,
    .archive .site-main,
    .search .site-main {
        grid-template-columns: 1fr !important;
        gap: 1.25rem !important;
        padding: 1rem !important;
    }

    .blog .post .inside-article,
    .archive .post .inside-article {
        padding: 1rem !important;
    }

    .blog .post .entry-title,
    .archive .post .entry-title {
        font-size: 1rem !important;
    }

    .blog .post .entry-summary,
    .archive .post .entry-summary {
        -webkit-line-clamp: 3 !important;
    }
}

/* ============================================
   PAGINATION (below grid)
   ============================================ */
.blog .paging-navigation,
.archive .paging-navigation {
    grid-column: 1 / -1 !important;
    margin-top: 3rem !important;
    text-align: center !important;
}

.blog .paging-navigation .nav-links,
.archive .paging-navigation .nav-links {
    display: flex !important;
    justify-content: center !important;
    gap: 0.5rem !important;
    flex-wrap: wrap !important;
}

.blog .paging-navigation a,
.archive .paging-navigation a,
.blog .paging-navigation .page-numbers,
.archive .paging-navigation .page-numbers {
    padding: 0.5rem 1rem !important;
    background: var(--color-surface) !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-sm) !important;
    color: var(--color-body) !important;
    font-family: var(--font-body) !important;
    font-weight: 600 !important;
    font-size: 0.85rem !important;
    text-decoration: none !important;
    transition: all 0.2s ease !important;
}

.blog .paging-navigation a:hover,
.archive .paging-navigation a:hover,
.blog .paging-navigation .page-numbers:hover,
.archive .paging-navigation .page-numbers:hover {
    background: var(--color-accent-2) !important;
    color: #0f1114 !important;
    border-color: var(--color-accent-2) !important;
}

.blog .paging-navigation .current,
.archive .paging-navigation .current {
    background: var(--color-accent-2) !important;
    color: #0f1114 !important;
    border-color: var(--color-accent-2) !important;
}

/* ============================================
   CATEGORY FILTER BAR
   Horizontal pill-style filter above the grid
   ============================================ */
.ftg-category-filter {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 0.5rem !important;
    padding: 1.5rem 1rem !important;
    max-width: 1200px !important;
    margin: 0 auto !important;
    justify-content: flex-start !important;
}

.ftg-category-filter .filter-btn {
    display: inline-block !important;
    padding: 0.4rem 1.2rem !important;
    font-family: var(--font-body) !important;
    font-size: 0.78rem !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
    border-radius: 9999px !important;
    border: 1px solid var(--color-border) !important;
    background: var(--color-surface-alt) !important;
    color: var(--color-body) !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    text-decoration: none !important;
}

.ftg-category-filter .filter-btn:hover {
    border-color: var(--color-accent-2) !important;
    color: var(--color-accent-2) !important;
    background: rgba(46, 196, 166, 0.1) !important;
}

.ftg-category-filter .filter-btn.active {
    background: var(--color-accent-2) !important;
    color: #0f1114 !important;
    border-color: var(--color-accent-2) !important;
}
