/* ── Blog listing ── */
.blog-listing{padding:64px 24px 96px;background:var(--bg,#f9fafb)}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;max-width:1120px;margin:0 auto}

.blog-card{
  background:#fff;
  border:1px solid var(--neutral);
  border-radius:16px;
  overflow:hidden;
  transition:all .25s;
  display:flex;flex-direction:column;
}
.blog-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px rgba(7,55,99,.10)}

.blog-card-img{width:100%;aspect-ratio:16/10;object-fit:cover;display:block}
.blog-card-body{padding:20px 24px 24px;display:flex;flex-direction:column;flex:1}
.blog-card-title{
  font-size:18px;font-weight:700;line-height:1.4;color:var(--dark);
  margin:0 0 10px;
}
.blog-card-title a{color:inherit;text-decoration:none}
.blog-card-title a:hover{color:var(--secondary)}
.blog-card-excerpt{font-size:14px;line-height:1.6;color:#666;margin:0 0 12px;flex:1}
.blog-card-meta{font-size:13px;color:#888;margin-top:auto;display:flex;gap:12px;align-items:center}
.blog-card-author{font-weight:600;color:#555}
.blog-card-date{color:#999}

/* ── Load more ── */
.blog-load-more{text-align:center;padding:32px 0 0}
.blog-load-more button{
  padding:10px 28px;font-size:14px;font-family:inherit;
  border:1px solid var(--neutral);border-radius:8px;
  background:#fff;color:var(--dark);cursor:pointer;
  transition:all .2s;
}
.blog-load-more button:hover{border-color:var(--accent);background:var(--accent3)}
.blog-load-more button:disabled{opacity:.5;cursor:default}

/* ── Article page ── */
.blog-post{max-width:780px;margin:0 auto;padding:48px 24px 64px}
.blog-post h2{font-size:22px;font-weight:700;color:var(--dark);margin:40px 0 12px}
.blog-post h3{font-size:18px;font-weight:700;color:var(--dark);margin:32px 0 8px}
.blog-post h4{font-size:16px;font-weight:600;color:var(--dark);margin:24px 0 8px}
.blog-post p{font-size:16px;line-height:1.8;color:#444;margin:0 0 18px}
.blog-post a{color:var(--secondary);text-decoration:underline}
.blog-post a:hover{color:var(--primary)}
.blog-post img{max-width:100%;height:auto;border-radius:8px;margin:24px 0}
.blog-post blockquote{
  border-left:3px solid var(--accent);margin:24px 0;padding:0 0 0 20px;
  font-style:italic;color:#555;
}
.blog-post ul,.blog-post ol{margin:0 0 18px;padding-left:24px;color:#444;line-height:1.8}
.blog-post li{margin-bottom:8px}
.blog-post strong{color:var(--dark)}

.blog-hero-meta{font-size:15px;opacity:.85;margin-top:6px;display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.blog-hero-author{font-weight:600}

/* ── Featured image ── */
.blog-featured-img{
  max-width:780px;margin:0 auto;padding:0 24px;
}
.blog-featured-img img{
  width:100%;border-radius:12px;aspect-ratio:16/9;object-fit:cover;display:block;
}

/* ── Related posts ── */
.blog-related{padding:64px 24px;background:var(--bg,#f9fafb)}
.blog-related h2{text-align:center;font-size:28px;margin:0 0 32px;color:var(--dark)}
.blog-related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;max-width:1120px;margin:0 auto}

/* ── Responsive ── */
@media(max-width:900px){
  .blog-grid{grid-template-columns:1fr 1fr}
  .blog-related-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .blog-grid{grid-template-columns:1fr}
  .blog-related-grid{grid-template-columns:1fr}
  .blog-listing{padding:40px 16px 64px}
  .blog-post{padding:32px 16px 48px}
  .blog-card-title{font-size:16px}
  .blog-featured-img{padding:0 16px}
}
