/* Blog & Post Pages — Red & White Theme */

/* ── Hero ── */
.blog-hero {
    padding: 10rem 0 5rem 0;
    background-color: #111111;
    border-bottom: 4px solid var(--color-primary);
    position: relative; overflow: hidden;
}
.blog-hero-eyebrow {
    color: rgba(255,255,255,0.5); font-family: var(--font-heading);
    font-size: 0.78rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: 3px; margin-bottom: 0.8rem; display: block;
}
.blog-hero-title {
    font-size: 3rem; font-weight: 900; text-transform: uppercase;
    margin-bottom: 1.2rem; color: rgba(255,255,255,0.85); line-height: 1.05;
}
.blog-hero-title span { color: var(--color-primary); }
.blog-hero-desc { font-size: 1.05rem; color: rgba(255,255,255,0.6); line-height: 1.7; max-width: 700px; }

/* ── Blog section ── */
.blog-section { padding: 5rem 0; background-color: var(--color-bg); }

/* ── Blog Grid ── */
.blog-grid {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 2.2rem; margin-bottom: 4rem;
}

.blog-card {
    background-color: #ffffff;
    border: 1.5px solid var(--color-border);
    border-radius: var(--radius-lg); overflow: hidden;
    transition: var(--transition-normal);
    display: flex; flex-direction: column; height: 100%;
}
.blog-card:hover { transform: translateY(-7px); border-color: var(--color-primary); box-shadow: var(--shadow-md); }

.blog-card-image {
    position: relative; aspect-ratio: 16/10; overflow: hidden;
    background-color: var(--color-bg-alt);
}
.blog-card-image img { width: 100%; height: 100%; object-fit: cover; transition: var(--transition-slow); }
.blog-card:hover .blog-card-image img { transform: scale(1.05); }

.blog-card-badge {
    position: absolute; top: 1rem; left: 1rem;
    background-color: var(--color-primary); color: white;
    font-family: var(--font-heading); font-size: 0.72rem; font-weight: 700;
    text-transform: uppercase; padding: 0.35rem 0.75rem;
    border-radius: var(--radius-sm); letter-spacing: 0.5px; z-index: 2;
}

.blog-card-content { padding: 1.6rem; display: flex; flex-direction: column; flex-grow: 1; }

.blog-card-meta {
    font-size: 0.78rem; color: var(--color-text-muted); margin-bottom: 0.7rem;
    display: flex; align-items: center; gap: 0.5rem;
}
.blog-card-meta svg { width: 13px; height: 13px; fill: currentColor; }

.blog-card-title {
    font-size: 1.1rem; font-weight: 700; line-height: 1.3;
    margin-bottom: 0.8rem; text-transform: uppercase; color: var(--color-text);
}
.blog-card:hover .blog-card-title { color: var(--color-primary); }

.blog-card-excerpt { color: var(--color-text-muted); font-size: 0.88rem; margin-bottom: 1.4rem; line-height: 1.6; flex-grow: 1; }

.blog-card-link {
    font-family: var(--font-heading); font-size: 0.78rem; font-weight: 700;
    text-transform: uppercase; color: var(--color-primary);
    display: inline-flex; align-items: center; gap: 0.4rem;
}
.blog-card-link svg { width: 13px; height: 13px; fill: currentColor; transition: var(--transition-fast); }
.blog-card:hover .blog-card-link svg { transform: translateX(4px); }

/* ── Pagination ── */
.pagination { display: flex; justify-content: center; gap: 0.8rem; margin-top: 2rem; margin-bottom: 4rem; }
.page-num {
    width: 40px; height: 40px;
    background-color: #ffffff; border: 1.5px solid var(--color-border);
    border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center;
    font-family: var(--font-heading); font-size: 0.88rem; font-weight: 700;
    color: var(--color-text); transition: var(--transition-fast);
}
.page-num:hover, .page-num.active {
    background-color: var(--color-primary); border-color: var(--color-primary); color: white;
}

/* ── Post Detail ── */
.post-layout { max-width: 800px; margin: 0 auto; padding: 10rem 0 6rem 0; }
.post-header { margin-bottom: 3rem; }

.post-category {
    color: var(--color-primary); font-family: var(--font-heading);
    font-size: 0.82rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: 1.5px; margin-bottom: 1rem; display: inline-block;
}
.post-title {
    font-size: 2.6rem; font-weight: 800; line-height: 1.15;
    margin-bottom: 1.5rem; text-transform: uppercase; color: var(--color-text);
}
.post-meta {
    display: flex; gap: 2rem; color: var(--color-text-muted); font-size: 0.88rem;
    border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border);
    padding: 1rem 0;
}
.post-meta-item { display: flex; align-items: center; gap: 0.5rem; }
.post-meta-item svg { width: 15px; height: 15px; fill: currentColor; }

.post-featured-image {
    width: 100%; aspect-ratio: 16/9; border-radius: var(--radius-lg);
    overflow: hidden; margin-bottom: 3rem; border: 1.5px solid var(--color-border);
}
.post-featured-image img { width: 100%; height: 100%; object-fit: cover; }

.post-content { font-size: 1.05rem; line-height: 1.85; color: var(--color-text-muted); }
.post-content p { margin-bottom: 1.8rem; }
.post-content h2, .post-content h3 { margin: 2.5rem 0 1.2rem 0; text-transform: uppercase; color: var(--color-text); }
.post-content h2 { font-size: 1.7rem; }
.post-content h3 { font-size: 1.3rem; }
.post-content blockquote {
    border-left: 4px solid var(--color-primary); padding-left: 1.5rem;
    margin: 2rem 0; font-style: italic; color: var(--color-text-muted);
    background-color: var(--color-bg-alt); padding: 1.2rem 1.5rem; border-radius: 0 var(--radius-md) var(--radius-md) 0;
}
.post-content ul, .post-content ol { margin-bottom: 1.8rem; padding-left: 2rem; }
.post-content li { margin-bottom: 0.5rem; color: var(--color-text-muted); }
.post-content strong { color: var(--color-text); }

.post-footer {
    margin-top: 4rem; padding-top: 2rem;
    border-top: 1px solid var(--color-border);
    display: flex; justify-content: space-between; align-items: center;
}
.post-tags { display: flex; gap: 0.7rem; flex-wrap: wrap; }
.post-tag {
    background-color: var(--color-bg-alt); border: 1.5px solid var(--color-border);
    padding: 0.35rem 0.75rem; font-size: 0.78rem;
    border-radius: var(--radius-sm); color: var(--color-text-muted);
    transition: var(--transition-fast);
}
.post-tag:hover { border-color: var(--color-primary); color: var(--color-primary); }

/* ── Responsive ── */
@media (max-width: 992px) {
    .blog-hero-title { font-size: 2.4rem; }
    .blog-grid { grid-template-columns: repeat(2, 1fr); gap: 1.6rem; }
}
@media (max-width: 768px) {
    .blog-hero-title, .post-title { font-size: 2rem; }
    .blog-grid { grid-template-columns: 1fr; }
    .post-meta { flex-direction: column; gap: 0.5rem; }
}
