/* ==========================================================================
   BLOG.CSS — Archive e Single de Posts — Pontual Parabrisas
   ========================================================================== */

/* ─── ARCHIVE ─────────────────────────────────────────────────────────── */
.blog-archive { padding: 3rem 0 5rem; }

.blog-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}
@media (min-width: 640px)  { .blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .blog-grid { grid-template-columns: repeat(3, 1fr); } }

.blog-card {
    background: var(--pp-surface);
    border: 1px solid var(--pp-border);
    border-radius: var(--radius-card);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: all var(--transition-base);
}
.blog-card:hover { border-color: var(--pp-border-gold); transform: translateY(-4px); box-shadow: var(--shadow-gold); }

.blog-card__img-wrapper { aspect-ratio: 16/9; overflow: hidden; }
.blog-card__img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transition-slow); }
.blog-card:hover .blog-card__img { transform: scale(1.05); }

.blog-card__content { padding: 1.25rem; display: flex; flex-direction: column; flex-grow: 1; }
.blog-card__cat {
    display: inline-flex;
    font-family: var(--font-heading);
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--pp-gold);
    margin-bottom: 0.625rem;
}
.blog-card__title {
    font-family: var(--font-heading);
    font-size: 1.1rem;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--pp-white);
    margin-bottom: 0.625rem;
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.blog-card__excerpt { font-size: 0.85rem; color: var(--pp-text-muted); line-height: 1.5; margin-bottom: 1rem; flex-grow: 1; }
.blog-card__date { font-size: 0.75rem; color: rgba(255,255,255,0.35); }

/* ─── SINGLE POST ─────────────────────────────────────────────────────── */
.single-post-wrap { padding: 2rem 0 5rem; }

.post-header { margin-bottom: 2rem; }
.post-header__cat { color: var(--pp-gold); font-family: var(--font-heading); font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.12em; margin-bottom: 0.75rem; display: block; }
.post-header__title { font-family: var(--font-heading); font-size: clamp(1.75rem, 4vw, 2.75rem); font-weight: 800; text-transform: uppercase; color: var(--pp-white); line-height: 1.1; margin-bottom: 1rem; }
.post-header__meta { font-size: 0.8rem; color: var(--pp-text-muted); }

.post-featured-img { width: 100%; border-radius: var(--radius-lg); overflow: hidden; margin-bottom: 2rem; }
.post-featured-img img { width: 100%; height: auto; }

.post-content {
    color: rgba(255,255,255,0.9);
    font-size: 1rem;
    line-height: 1.8;
    max-width: 72ch;
}
.post-content h2, .post-content h3 { margin: 2rem 0 1rem; }
.post-content p { margin-bottom: 1.25rem; }
.post-content a { color: var(--pp-gold); text-decoration: underline; }
.post-content ul, .post-content ol { padding-left: 1.5rem; margin-bottom: 1.25rem; }
.post-content li { margin-bottom: 0.5rem; list-style: disc; }
.post-content img { border-radius: var(--radius-md); margin: 1.5rem 0; }
