/* =========================================================================
   kao-blog.css — Trang Blog (danh sách) + Chi tiết bài viết
   Kế thừa tokens (--kao-*). Scoped trong .kao-app.
   ========================================================================= */

/* ---------- Hero trang Blog ---------- */
.kao-blog-hero { padding: 40px 0 10px; }
.kao-blog-hero .eyebrow { font-family: var(--kao-font-mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--kao-accent-ink); }
.kao-blog-hero h1 { font-family: var(--kao-font-ui); font-weight: 700; font-size: clamp(30px, 5vw, 44px); letter-spacing: -0.025em; margin: 8px 0 10px; color: var(--kao-ink); }
.kao-blog-hero p { font-size: 16px; color: var(--kao-ink-soft); margin: 0; max-width: 58ch; line-height: 1.6; }

/* category filter */
.kao-blog-cats { display: flex; flex-wrap: wrap; gap: 8px; padding: 22px 0 6px; }
.kao-blog-cats a {
  font-family: var(--kao-font-ui); font-size: 13px; color: var(--kao-ink-soft); text-decoration: none;
  background: var(--kao-surface); border: 1px solid var(--kao-line); padding: 7px 14px; border-radius: 999px; transition: all .13s;
}
.kao-blog-cats a:hover { border-color: var(--kao-accent); color: var(--kao-accent-ink); background: var(--kao-accent-wash); }
.kao-blog-cats a.is-active { background: var(--kao-ink); border-color: var(--kao-ink); color: var(--kao-bg); }

/* ---------- Thumbnail kaomoji (thay ảnh) ---------- */
.kao-thumb {
  display: grid; place-items: center; border-radius: 14px; overflow: hidden; position: relative;
  font-family: var(--kao-font-kao); color: var(--kao-ink); background: var(--kao-accent-wash);
  border: 1px solid var(--kao-line);
}
.kao-thumb.t1 { background: oklch(0.95 0.03 20); }
.kao-thumb.t2 { background: oklch(0.95 0.035 330); }
.kao-thumb.t3 { background: oklch(0.95 0.03 265); }
.kao-thumb.t4 { background: oklch(0.95 0.035 155); }
.kao-thumb.t5 { background: oklch(0.95 0.04 75); }
.kao-thumb.t6 { background: oklch(0.95 0.03 200); }
.kao-thumb .big { font-size: 38px; opacity: .92; }

/* ---------- Featured post ---------- */
.kao-feature {
  display: grid; grid-template-columns: 1.15fr 1fr; gap: 26px; align-items: stretch; text-decoration: none;
  background: var(--kao-surface); border: 1px solid var(--kao-line); border-radius: 18px; overflow: hidden;
  margin-top: 12px; cursor: pointer; transition: border-color .14s, box-shadow .14s;
}
.kao-feature:hover { border-color: color-mix(in oklab, var(--kao-accent) 45%, var(--kao-line)); box-shadow: 0 12px 40px -20px rgba(0,0,0,.3); }
.kao-feature .kao-thumb { border: 0; border-radius: 0; min-height: 300px; }
.kao-feature .kao-thumb .big { font-size: 56px; }
.kao-feature .fbody { padding: 32px 34px 30px; display: flex; flex-direction: column; justify-content: center; }
.kao-feature .badge { align-self: flex-start; font-family: var(--kao-font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: #fff; background: var(--kao-accent); padding: 4px 9px; border-radius: 6px; }
.kao-feature h2 { font-family: var(--kao-font-ui); font-weight: 700; font-size: 27px; line-height: 1.18; letter-spacing: -0.02em; margin: 14px 0 10px; color: var(--kao-ink); }
.kao-feature p { font-size: 15px; line-height: 1.65; color: var(--kao-ink-soft); margin: 0 0 18px; text-wrap: pretty; }

/* ---------- Lưới bài viết ---------- */
.kao-posts { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; padding: 8px 0 10px; }
.kao-post {
  display: flex; flex-direction: column; background: var(--kao-surface); border: 1px solid var(--kao-line);
  border-radius: 16px; overflow: hidden; cursor: pointer; transition: border-color .14s, box-shadow .14s, transform .1s; text-decoration: none;
}
.kao-post:hover { border-color: color-mix(in oklab, var(--kao-accent) 45%, var(--kao-line)); box-shadow: 0 10px 30px -18px rgba(0,0,0,.28); transform: translateY(-2px); }
.kao-post .kao-thumb { border: 0; border-radius: 0; aspect-ratio: 16 / 10; }
.kao-post .pbody { padding: 18px 18px 20px; display: flex; flex-direction: column; flex: 1; }
.kao-post .pcat { font-family: var(--kao-font-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--kao-accent-ink); }
.kao-post h3 { font-family: var(--kao-font-ui); font-weight: 600; font-size: 18px; line-height: 1.3; letter-spacing: -0.01em; margin: 8px 0 8px; color: var(--kao-ink); }
.kao-post p { font-size: 13.5px; line-height: 1.6; color: var(--kao-ink-soft); margin: 0 0 16px; flex: 1; }
.kao-post .pmeta { display: flex; gap: 12px; align-items: center; font-size: 12px; color: var(--kao-ink-faint); white-space: nowrap; }
.kao-post .pmeta .dot { width: 3px; height: 3px; border-radius: 50%; background: var(--kao-ink-faint); }

/* ---------- Pagination ---------- */
.kao-pager { display: flex; gap: 6px; justify-content: center; padding: 30px 0 10px; }
.kao-pager a, .kao-pager span {
  min-width: 38px; height: 38px; display: grid; place-items: center; border-radius: 10px;
  font-family: var(--kao-font-ui); font-size: 14px; color: var(--kao-ink-soft); text-decoration: none;
  border: 1px solid var(--kao-line); background: var(--kao-surface); transition: all .12s; padding: 0 6px;
}
.kao-pager a:hover { border-color: var(--kao-accent); color: var(--kao-accent-ink); }
.kao-pager .is-active { background: var(--kao-ink); border-color: var(--kao-ink); color: var(--kao-bg); }
.kao-pager .nope { opacity: .4; pointer-events: none; }

/* =========================================================================
   CHI TIẾT BÀI VIẾT
   ========================================================================= */
.kao-article { display: grid; grid-template-columns: 1fr; max-width: 820px; margin: 0 auto; }
.kao-art-head { padding: 14px 0 6px; }
.kao-art-head .pcat { font-family: var(--kao-font-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--kao-accent-ink); }
.kao-art-head h1 { font-family: var(--kao-font-ui); font-weight: 700; font-size: clamp(28px, 4.4vw, 40px); line-height: 1.12; letter-spacing: -0.025em; margin: 12px 0 14px; color: var(--kao-ink); text-wrap: balance; }
.kao-art-meta { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; font-size: 13.5px; color: var(--kao-ink-faint); }
.kao-art-meta .who { display: flex; align-items: center; gap: 9px; }
.kao-art-meta .av { width: 30px; height: 30px; border-radius: 50%; background: var(--kao-accent-wash); border: 1px solid var(--kao-line); display: grid; place-items: center; font-family: var(--kao-font-kao); font-size: 12px; color: var(--kao-accent-ink); }
.kao-art-meta .who b { color: var(--kao-ink-soft); font-weight: 600; }
.kao-art-meta .dot { width: 3px; height: 3px; border-radius: 50%; background: var(--kao-ink-faint); }

.kao-art-cover { margin: 22px 0 8px; min-height: 320px; border-radius: 18px; }
.kao-art-cover .big { font-size: 64px; }

/* nội dung */
.kao-prose { font-size: 17px; line-height: 1.75; color: var(--kao-ink); }
.kao-prose > * { margin: 0 0 22px; }
.kao-prose h2 { font-family: var(--kao-font-ui); font-weight: 700; font-size: 25px; letter-spacing: -0.02em; margin: 40px 0 14px; color: var(--kao-ink); scroll-margin-top: 80px; }
.kao-prose h3 { font-family: var(--kao-font-ui); font-weight: 600; font-size: 20px; margin: 28px 0 10px; color: var(--kao-ink); }
.kao-prose p { color: var(--kao-ink-soft); text-wrap: pretty; }
.kao-prose strong { color: var(--kao-ink); font-weight: 600; }
.kao-prose a { color: var(--kao-accent-ink); text-decoration: underline; text-underline-offset: 2px; }
.kao-prose ul, .kao-prose ol { padding-left: 22px; color: var(--kao-ink-soft); }
.kao-prose li { margin: 6px 0; }
.kao-prose blockquote {
  border-left: 3px solid var(--kao-accent); background: var(--kao-accent-wash); margin: 26px 0;
  padding: 14px 20px; border-radius: 0 12px 12px 0; color: var(--kao-ink); font-size: 16px;
}

/* kaomoji chèn trong bài — bấm để chép */
.kao-inline {
  display: inline-flex; align-items: center; gap: 8px; cursor: pointer; vertical-align: middle;
  font-family: var(--kao-font-kao); background: var(--kao-accent-wash);
  border: 1px solid color-mix(in oklab, var(--kao-accent) 25%, transparent); color: var(--kao-ink);
  padding: 2px 10px; border-radius: 8px; transition: all .12s; font-size: .95em;
}
.kao-inline:hover { border-color: var(--kao-accent); background: color-mix(in oklab, var(--kao-accent-wash) 65%, var(--kao-surface)); }
.kao-inline .ci { width: 13px; height: 13px; color: var(--kao-accent-ink); opacity: .55; }
.kao-inline:hover .ci { opacity: 1; }

/* khối kaomoji nổi bật trong bài (grid bấm chép) */
.kao-prose .kao-grid { margin: 24px 0; }
.kao-prose .kao-card { min-height: 96px; }

/* callout */
.kao-callout {
  display: flex; gap: 14px; align-items: flex-start; background: var(--kao-surface);
  border: 1px solid var(--kao-line); border-radius: 14px; padding: 18px 20px; margin: 26px 0; font-size: 15px; color: var(--kao-ink-soft);
}
.kao-callout .ce { font-family: var(--kao-font-kao); font-size: 26px; color: var(--kao-accent); flex: none; line-height: 1.2; }
.kao-callout b { color: var(--kao-ink); }

/* mục lục */
.kao-toc {
  background: var(--kao-surface); border: 1px solid var(--kao-line); border-radius: 14px; padding: 18px 20px; margin: 4px 0 28px;
}
.kao-toc .tl { font-family: var(--kao-font-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--kao-ink-faint); margin-bottom: 10px; }
.kao-toc ol { margin: 0; padding-left: 20px; }
.kao-toc li { margin: 6px 0; }
.kao-toc a { color: var(--kao-ink-soft); text-decoration: none; font-size: 14.5px; }
.kao-toc a:hover { color: var(--kao-accent-ink); }

/* tags + share */
.kao-art-foot { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; padding: 26px 0; border-top: 1px solid var(--kao-line); margin-top: 30px; }
.kao-tags { display: flex; gap: 8px; flex-wrap: wrap; }
.kao-tags a { font-size: 12.5px; color: var(--kao-ink-soft); text-decoration: none; background: var(--kao-line-soft); padding: 5px 12px; border-radius: 999px; }
.kao-tags a:hover { background: var(--kao-accent-wash); color: var(--kao-accent-ink); }
.kao-share { margin-left: auto; display: flex; gap: 8px; }
.kao-share button { width: 36px; height: 36px; border-radius: 10px; border: 1px solid var(--kao-line); background: var(--kao-surface); color: var(--kao-ink-soft); cursor: pointer; display: grid; place-items: center; transition: all .12s; }
.kao-share button:hover { border-color: var(--kao-accent); color: var(--kao-accent-ink); }
.kao-share svg { width: 16px; height: 16px; }

/* author box */
.kao-author { display: flex; gap: 16px; align-items: center; background: var(--kao-accent-wash); border: 1px solid color-mix(in oklab, var(--kao-accent) 16%, transparent); border-radius: 16px; padding: 20px 22px; margin: 8px 0 30px; }
.kao-author .av { width: 52px; height: 52px; border-radius: 50%; background: var(--kao-surface); border: 1px solid var(--kao-line); display: grid; place-items: center; font-family: var(--kao-font-kao); font-size: 20px; color: var(--kao-accent); flex: none; }
.kao-author .an { font-family: var(--kao-font-ui); font-weight: 700; font-size: 15px; color: var(--kao-ink); }
.kao-author .ad { font-size: 13px; color: var(--kao-ink-soft); margin-top: 2px; }

/* related */
.kao-related { max-width: 1180px; margin: 10px auto 0; }
.kao-related .kao-posts { grid-template-columns: repeat(3, 1fr); }

@media (max-width: 880px) {
  .kao-feature { grid-template-columns: 1fr; }
  .kao-feature .kao-thumb { min-height: 200px; }
  .kao-posts, .kao-related .kao-posts { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .kao-posts, .kao-related .kao-posts { grid-template-columns: 1fr; }
}
