:root { --blog-max: 980px; }
body.blog .container { max-width: 1120px; }
.blog-main { padding: 28px 0 72px; }
.blog-hero { padding: 46px 0 22px; }
.blog-hero-inner { max-width: var(--blog-max); margin: 0 auto; }
.blog-badge { display:inline-flex; align-items:center; gap:8px; padding:6px 10px; border-radius: 999px; border:1px solid rgba(15,23,42,.10); background: rgba(255,255,255,.75); color: var(--muted); font-size: 12px; letter-spacing: .12em; text-transform: uppercase; }
.blog-hero h1 { font-size: 44px; line-height: 1.1; margin: 14px 0 10px; letter-spacing: -0.02em; }
.blog-hero p { margin: 0; color: var(--muted); font-size: 16px; }
.blog-hero-meta { display:flex; gap:10px; flex-wrap:wrap; margin-top: 14px; }
.blog-pill { border: 1px solid rgba(15,23,42,.10); background: rgba(255,255,255,.7); padding: 6px 10px; border-radius: 999px; color: var(--muted); font-size: 13px; }
.post-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; max-width: var(--blog-max); margin: 18px auto 0; }
@media (max-width: 900px) { .post-grid { grid-template-columns: 1fr; } .blog-hero h1 { font-size: 36px; } }
.post-card { display:flex; flex-direction:column; gap: 10px; padding: 16px; border-radius: 18px; border: 1px solid rgba(15,23,42,.10); background: rgba(255,255,255,.86); box-shadow: 0 14px 30px rgba(15, 23, 42, 0.06); }
.post-card:hover { border-color: rgba(31,59,179,.22); box-shadow: 0 18px 46px rgba(15, 23, 42, 0.10); }
.post-card-top { display:flex; align-items:flex-start; justify-content:space-between; gap: 10px; }
.post-tags { display:flex; gap: 8px; flex-wrap:wrap; }
.tag { display:inline-flex; align-items:center; padding: 4px 10px; border-radius:999px; font-size: 12px; font-weight: 700; background: rgba(31,59,179,.10); color: var(--primary); border: 1px solid rgba(31,59,179,.18); }
.post-meta { display:flex; gap: 10px; flex-wrap:wrap; justify-content:flex-end; color: var(--muted); font-size: 12px; }
.post-title { margin: 0; font-size: 18px; line-height: 1.25; letter-spacing: -0.01em; }
.post-title a { color: var(--text); }
.post-excerpt { margin: 0; color: var(--muted); font-size: 14px; line-height: 1.6; display:-webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.post-actions { margin-top: 4px; display:flex; justify-content:flex-start; }
.post-actions .btn { padding: 10px 12px; border-radius: 14px; }

/* Article page */
.post-shell { max-width: var(--blog-max); margin: 0 auto; }
.post-back { display:inline-flex; gap: 8px; align-items:center; margin-top: 10px; color: var(--primary); font-weight: 800; }
.post-header { padding: 14px 0 10px; }
.post-header h1 { font-size: 44px; line-height: 1.08; margin: 12px 0 10px; letter-spacing: -0.02em; }
@media (max-width: 720px) { .post-header h1 { font-size: 34px; } }
.post-dek { margin: 0; color: var(--muted); font-size: 16px; }
.prose { margin-top: 14px; background: rgba(255,255,255,.90); border: 1px solid rgba(15,23,42,.10); border-radius: 18px; padding: 18px; box-shadow: 0 14px 30px rgba(15, 23, 42, 0.06); }
.prose h2 { font-size: 18px; margin: 22px 0 10px; }
.prose p { color: var(--muted); margin: 10px 0; }
.prose ul, .prose ol { color: var(--muted); padding-left: 18px; }
.prose li { margin: 8px 0; }
.post-footer { margin-top: 14px; }
.post-nav { display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
@media (max-width: 720px) { .post-nav { grid-template-columns: 1fr; } }
.post-nav .nav-card { display: block; padding: 14px; border-radius: 18px; border: 1px solid rgba(15,23,42,.10); background: rgba(255,255,255,.86); }
.post-nav .nav-card::before,
.post-nav .nav-card::after { content: none; }
.post-nav .nav-card .label { font-size: 12px; color: var(--muted); letter-spacing: .12em; text-transform: uppercase; }
.post-nav .nav-card .title { margin: 8px 0 0; font-weight: 900; line-height: 1.2; }
