/* Single Blog Post — layered on top of style.css */

.post-wrap{max-width:860px;margin:0 auto;padding:32px 4px 80px}

/* Hero */
.post-hero{margin-bottom:28px}
.post-breadcrumb{
  display:flex;gap:8px;align-items:center;color:var(--muted);
  font-size:.85rem;margin-bottom:18px;
}
.post-breadcrumb a{color:var(--muted);transition:.2s}
.post-breadcrumb a:hover{color:var(--accent)}
.post-breadcrumb .sep{opacity:.5}

.post-title{
  font-size:clamp(2rem,4vw,3rem);line-height:1.2;
  font-weight:700;margin:0 0 18px;letter-spacing:-.02em;
}
.post-lede{
  font-size:1.15rem;color:var(--muted);
  margin:0 0 26px;line-height:1.65;
}

.post-meta-row{
  display:flex;align-items:center;gap:14px;
  padding:16px 0;border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);margin-bottom:32px;
}
.post-author-mini{display:flex;align-items:center;gap:10px}
.post-avatar{
  width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  display:grid;place-items:center;color:#fff;font-weight:600;
}
.post-author-mini-info{display:flex;flex-direction:column;line-height:1.3}
.post-author-mini-info strong{font-size:.92rem}
.post-author-mini-info span{color:var(--muted);font-size:.8rem}
.post-meta-dot{width:3px;height:3px;border-radius:50%;background:var(--muted);opacity:.6}
.post-meta-row .meta-item{color:var(--muted);font-size:.85rem}
.post-share{margin-left:auto;display:flex;gap:8px}
.post-share a{
  width:34px;height:34px;border:1px solid var(--border);border-radius:8px;
  display:grid;place-items:center;color:var(--muted);font-size:.7rem;transition:.2s;
}
.post-share a:hover{color:var(--accent);border-color:var(--accent)}

/* Featured image */
.post-featured{
  border-radius:14px;overflow:hidden;margin-bottom:36px;
  border:1px solid var(--border);
}
.post-featured img{width:100%;height:auto;display:block}

/* Article body */
.post-body{font-size:1.02rem;line-height:1.8;color:var(--text)}
.post-body > * + *{margin-top:1.1em}
.post-body h2{
  font-size:1.6rem;font-weight:600;margin-top:2.2em;
  letter-spacing:-.01em;line-height:1.3;
}
.post-body h3{font-size:1.25rem;font-weight:600;margin-top:1.8em;line-height:1.35}
.post-body p{color:#cfd4dc}
.post-body a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.post-body a:hover{color:var(--accent-2)}
.post-body strong{color:var(--text);font-weight:600}
.post-body ul,.post-body ol{padding-left:22px;color:#cfd4dc}
.post-body li{margin:.4em 0}
.post-body li::marker{color:var(--accent)}
.post-body img{
  width:100%;height:auto;border-radius:12px;
  border:1px solid var(--border);margin:1.4em 0;
}
.post-body figure{margin:1.6em 0}
.post-body figure img{margin:0}
.post-body figcaption{
  text-align:center;font-size:.85rem;color:var(--muted);
  margin-top:10px;font-style:italic;
}

/* Inline code */
.post-body code{
  background:rgba(255,1,79,.08);
  color:#ff6b94;
  padding:2px 7px;border-radius:5px;
  font-family:'JetBrains Mono','Fira Code',Consolas,monospace;
  font-size:.88em;
}

/* Code block */
.code-block{
  background:#0a0c0f;border:1px solid var(--border);
  border-radius:12px;margin:1.6em 0;overflow:hidden;
}
.code-block-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;background:#111418;
  border-bottom:1px solid var(--border);
  font-size:.78rem;color:var(--muted);
}
.code-block-lang{
  display:inline-flex;align-items:center;gap:6px;
  color:var(--accent);font-weight:500;letter-spacing:.05em;text-transform:uppercase;
}
.code-block-copy{
  background:transparent;border:1px solid var(--border);
  color:var(--muted);padding:4px 10px;border-radius:6px;
  font-size:.72rem;cursor:pointer;transition:.2s;
}
.code-block-copy:hover{color:var(--accent);border-color:var(--accent)}
.code-block pre{
  margin:0;padding:18px 18px 20px;overflow-x:auto;
  font-family:'JetBrains Mono','Fira Code',Consolas,monospace;
  font-size:.86rem;line-height:1.6;color:#e6e9ef;
}
.code-block pre code{background:none;color:inherit;padding:0;font-size:inherit}

/* naive token colors */
.tok-key{color:#ff6b94}
.tok-str{color:#9bd17a}
.tok-num{color:#e3b341}
.tok-com{color:#6a737d;font-style:italic}
.tok-fn{color:#79c0ff}
.tok-typ{color:#ffa657}

/* Blockquote */
.post-body blockquote{
  border-left:3px solid var(--accent);
  padding:6px 0 6px 22px;margin:1.6em 0;
  font-size:1.15rem;line-height:1.6;color:var(--text);
  font-style:italic;
}
.post-body blockquote cite{
  display:block;margin-top:10px;font-style:normal;
  font-size:.85rem;color:var(--muted);
}
.post-body blockquote cite::before{content:"— "}

/* Callout */
.post-callout{
  background:rgba(255,1,79,.06);
  border:1px solid rgba(255,1,79,.2);
  border-radius:12px;padding:16px 18px;margin:1.6em 0;
  display:flex;gap:14px;
}
.post-callout-icon{
  flex-shrink:0;width:30px;height:30px;border-radius:50%;
  background:var(--accent);color:#fff;display:grid;place-items:center;
  font-weight:700;font-size:.9rem;
}
.post-callout-body{font-size:.95rem;color:#cfd4dc}
.post-callout-body strong{color:var(--text)}

/* Tags row */
.post-tags{
  display:flex;flex-wrap:wrap;gap:8px;
  margin:40px 0 0;padding-top:28px;border-top:1px solid var(--border);
}
.post-tags a{
  padding:6px 14px;border-radius:999px;
  border:1px solid var(--border);color:var(--muted);
  font-size:.82rem;transition:.2s;
}
.post-tags a:hover{color:var(--accent);border-color:var(--accent)}

/* Author bio */
.post-author-card{
  display:flex;gap:18px;align-items:center;
  padding:24px;border:1px solid var(--border);border-radius:14px;
  background:var(--bg-2);margin-top:40px;
}
.post-author-card .post-avatar{width:64px;height:64px;font-size:1.2rem}
.post-author-card h4{margin:0 0 4px;font-size:1.05rem}
.post-author-card p{margin:0;color:var(--muted);font-size:.9rem;line-height:1.5}

/* Comments */
.comments-section{margin-top:60px}
.comments-head{
  display:flex;align-items:baseline;gap:10px;margin-bottom:24px;
}
.comments-head h3{margin:0;font-size:1.4rem}
.comments-head span{color:var(--muted);font-size:.9rem}

.comment-form{
  background:var(--bg-2);border:1px solid var(--border);
  border-radius:12px;padding:20px;margin-bottom:32px;
}
.comment-form-row{display:flex;gap:12px;margin-bottom:12px}
.comment-form-row > *{flex:1}
.comment-form input,
.comment-form textarea{
  width:100%;background:#0a0c0f;border:1px solid var(--border);
  border-radius:8px;padding:11px 14px;color:var(--text);
  font-family:inherit;font-size:.92rem;transition:.2s;
}
.comment-form textarea{min-height:110px;resize:vertical;line-height:1.6}
.comment-form input:focus,
.comment-form textarea:focus{outline:none;border-color:var(--accent)}
.comment-form button{
  background:var(--accent);color:#fff;border:none;padding:11px 24px;
  border-radius:8px;font-weight:500;cursor:pointer;transition:.2s;
}
.comment-form button:hover{background:var(--accent-2)}

.comment-list{display:flex;flex-direction:column;gap:22px}
.comment{
  display:flex;gap:14px;padding-bottom:22px;
  border-bottom:1px solid var(--border);
}
.comment:last-child{border-bottom:none}
.comment.reply{margin-left:54px}
.comment-avatar{
  width:42px;height:42px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,#3a4858,#1f2630);
  display:grid;place-items:center;color:var(--text);font-weight:600;
}
.comment-body{flex:1}
.comment-head{display:flex;align-items:baseline;gap:10px;margin-bottom:6px}
.comment-head strong{font-size:.95rem}
.comment-head time{color:var(--muted);font-size:.78rem}
.comment-text{color:#cfd4dc;font-size:.93rem;line-height:1.65;margin:0}
.comment-actions{display:flex;gap:14px;margin-top:8px}
.comment-actions button{
  background:none;border:none;color:var(--muted);
  font-size:.8rem;cursor:pointer;padding:0;transition:.2s;
}
.comment-actions button:hover{color:var(--accent)}

/* Related posts */
.related-section{margin-top:72px;padding-top:48px;border-top:1px solid var(--border)}
.related-section h3{margin:0 0 24px;font-size:1.4rem}
.related-grid{
  display:grid;gap:18px;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
}
.related-card{
  border:1px solid var(--border);border-radius:12px;overflow:hidden;
  background:var(--bg-2);transition:.25s;
}
.related-card:hover{border-color:var(--accent);transform:translateY(-3px)}
.related-card img{width:100%;height:140px;object-fit:cover;display:block}
.related-card-body{padding:14px 16px 18px}
.related-card .tag{
  display:inline-block;padding:3px 9px;border-radius:999px;
  background:rgba(255,1,79,.1);color:var(--accent);
  font-size:.7rem;letter-spacing:.05em;text-transform:uppercase;margin-bottom:8px;
}
.related-card h4{margin:0 0 6px;font-size:1rem;line-height:1.35}
.related-card p{margin:0;color:var(--muted);font-size:.82rem}

@media (max-width:720px){
  .post-wrap{padding:20px 4px 60px}
  .post-meta-row{flex-wrap:wrap;gap:10px}
  .post-share{margin-left:0;width:100%}
  .comment-form-row{flex-direction:column}
  .comment.reply{margin-left:24px}
  .post-author-card{flex-direction:column;text-align:center}
}
