/* =========================================================================
   kao-pages.css — Thành phần cho trang chủ đề (/meo) + widget trang chủ
   Kế thừa tokens (--kao-*) từ style.css. Mọi thứ scoped trong .kao-app.
   ========================================================================= */

/* ---------- Breadcrumb + Hero bài viết ---------- */
.kao-crumb { display: flex; gap: 8px; align-items: center; padding: 20px 0 0; font-size: 13px; color: var(--kao-ink-faint); }
.kao-crumb a { color: var(--kao-ink-soft); text-decoration: none; }
.kao-crumb a:hover { color: var(--kao-accent-ink); }
.kao-crumb .sep { opacity: .5; }

.kao-hero { display: flex; gap: 20px; align-items: flex-start; padding: 18px 0 6px; }
.kao-hero-glyph {
  font-family: var(--kao-font-kao); font-size: 40px; line-height: 1; color: var(--kao-accent);
  background: var(--kao-accent-wash); border: 1px solid color-mix(in oklab, var(--kao-accent) 22%, transparent);
  border-radius: 18px; padding: 16px 18px; flex: none;
}
.kao-hero-body { min-width: 0; }
.kao-hero h1 {
  font-family: var(--kao-font-ui); font-weight: 700; font-size: clamp(26px, 4vw, 36px);
  line-height: 1.1; letter-spacing: -0.02em; margin: 2px 0 8px; color: var(--kao-ink);
}
.kao-hero p { font-size: 15.5px; line-height: 1.6; color: var(--kao-ink-soft); margin: 0 0 10px; max-width: 64ch; text-wrap: pretty; }
.kao-hero-meta { display: flex; gap: 16px; flex-wrap: wrap; }
.kao-hero-meta span { display: inline-flex; align-items: center; gap: 6px; font-size: 12.5px; color: var(--kao-ink-faint); }
.kao-hero-meta b { color: var(--kao-accent-ink); font-weight: 600; }

/* ---------- Section wrapper ---------- */
.kao-sec { padding: 30px 0 6px; }
.kao-sec-head { display: flex; align-items: baseline; gap: 12px; margin-bottom: 16px; }
.kao-sec-head h2 {
  font-family: var(--kao-font-ui); font-weight: 700; font-size: 20px; letter-spacing: -0.01em;
  margin: 0; color: var(--kao-ink); display: flex; align-items: center; gap: 9px;
}
.kao-sec-head .kao-fire { color: var(--kao-accent); font-size: 18px; }
.kao-sec-head .kao-sub2 { font-size: 13px; color: var(--kao-ink-faint); }
.kao-sec-head .kao-more { margin-left: auto; font-size: 13px; color: var(--kao-accent-ink); text-decoration: none; white-space: nowrap; }
.kao-sec-head .kao-more:hover { text-decoration: underline; }

/* ---------- Bảng xếp hạng "Top tuần" ---------- */
.kao-rank { display: grid; gap: 8px; }
.kao-rank.cols { grid-template-columns: 1fr 1fr; gap: 8px 20px; }
.kao-rankrow {
  display: flex; align-items: center; gap: 14px; padding: 11px 14px; cursor: pointer;
  background: var(--kao-surface); border: 1px solid var(--kao-line); border-radius: 12px;
  transition: border-color .14s, box-shadow .14s, transform .08s; position: relative;
}
.kao-rankrow:hover { border-color: color-mix(in oklab, var(--kao-accent) 50%, var(--kao-line)); box-shadow: 0 6px 18px -12px rgba(0,0,0,.22); }
.kao-rankrow:active { transform: translateY(1px); }
.kao-rank-num {
  font-family: var(--kao-font-mono); font-size: 14px; font-weight: 700; color: var(--kao-ink-faint);
  width: 26px; text-align: center; flex: none;
}
.kao-rankrow.top1 .kao-rank-num, .kao-rankrow.top2 .kao-rank-num, .kao-rankrow.top3 .kao-rank-num { color: var(--kao-accent); }
.kao-rank-face { font-family: var(--kao-font-kao); font-size: 20px; color: var(--kao-ink); flex: 1; min-width: 0; word-break: break-word; }
.kao-rank-meta { display: flex; align-items: center; gap: 10px; flex: none; }
.kao-rank-count { font-size: 12.5px; color: var(--kao-ink-faint); white-space: nowrap; }
.kao-rank-count b { color: var(--kao-ink-soft); font-weight: 600; }
.kao-rank-copy {
  width: 30px; height: 30px; display: grid; place-items: center; border-radius: 8px;
  border: 1px solid var(--kao-line); background: var(--kao-surface); color: var(--kao-ink-soft);
  opacity: 0; transition: all .12s; flex: none;
}
.kao-rankrow:hover .kao-rank-copy { opacity: 1; }
.kao-rank-copy:hover { color: var(--kao-accent-ink); border-color: var(--kao-accent); background: var(--kao-accent-wash); }
.kao-rank-copy svg { width: 15px; height: 15px; }
.kao-rankrow.is-flash { border-color: var(--kao-accent); }
.kao-rankrow.is-flash .kao-rank-face::after { content: " ✓ đã chép"; font-family: var(--kao-font-ui); font-size: 12px; color: var(--kao-accent-ink); }
.kao-cat-tag { font-family: var(--kao-font-mono); font-size: 9.5px; letter-spacing: .05em; text-transform: uppercase; color: var(--kao-ink-faint); }

/* ---------- Sort tabs ---------- */
.kao-sort { display: flex; gap: 6px; margin-left: auto; }
.kao-sort button {
  cursor: pointer; font-family: var(--kao-font-ui); font-size: 13px; color: var(--kao-ink-soft);
  background: transparent; border: 1px solid transparent; padding: 6px 12px; border-radius: 999px; transition: all .12s;
}
.kao-sort button:hover { background: var(--kao-line-soft); color: var(--kao-ink); }
.kao-sort button.is-active { background: var(--kao-ink); color: var(--kao-bg); }

/* card: badge "Mới" cho đóng góp + lượt chép nhỏ */
.kao-card .kao-new {
  position: absolute; left: 10px; top: 9px; font-family: var(--kao-font-mono); font-size: 9px;
  letter-spacing: .06em; text-transform: uppercase; color: #fff; background: var(--kao-accent);
  padding: 2px 6px; border-radius: 6px;
}
.kao-card .kao-cc {
  position: absolute; left: 10px; bottom: 9px; font-family: var(--kao-font-mono); font-size: 9.5px;
  color: var(--kao-ink-faint);
}

/* ---------- Trending search (nhóm kaomoji-text tìm nhiều) ---------- */
.kao-trend { display: flex; flex-wrap: wrap; gap: 10px; }
.kao-trend a {
  display: flex; align-items: center; gap: 10px; text-decoration: none;
  background: var(--kao-surface); border: 1px solid var(--kao-line); border-radius: 12px;
  padding: 10px 14px; transition: all .13s;
}
.kao-trend a:hover { border-color: var(--kao-accent); background: var(--kao-accent-wash); transform: translateY(-1px); }
.kao-trend .rank { font-family: var(--kao-font-mono); font-size: 12px; font-weight: 700; color: var(--kao-ink-faint); }
.kao-trend .term { font-family: var(--kao-font-ui); font-size: 15px; font-weight: 600; color: var(--kao-ink); }
.kao-trend .vol { font-size: 12px; color: var(--kao-ink-faint); }
.kao-trend .up { font-family: var(--kao-font-mono); font-size: 11px; font-weight: 700; padding: 2px 6px; border-radius: 6px; }
.kao-trend .up.pos { color: oklch(0.5 0.13 150); background: oklch(0.95 0.04 150); }
.kao-trend .up.neg { color: oklch(0.55 0.13 25); background: oklch(0.95 0.03 25); }
.kao-trend .up.hot { color: #fff; background: var(--kao-accent); }

/* ---------- Đóng góp ---------- */
.kao-contrib {
  background: var(--kao-surface); border: 1px solid var(--kao-line); border-radius: var(--kao-radius);
  padding: 22px; display: grid; gap: 14px;
}
.kao-contrib .ct-title { font-family: var(--kao-font-ui); font-weight: 700; font-size: 17px; color: var(--kao-ink); display: flex; align-items: center; gap: 8px; }
.kao-contrib .ct-sub { font-size: 13.5px; color: var(--kao-ink-soft); margin-top: -8px; }
.kao-contrib .ct-row { display: flex; gap: 10px; align-items: stretch; flex-wrap: wrap; }
.kao-contrib input[type=text] {
  flex: 1; min-width: 200px; border: 1px solid var(--kao-line); border-radius: 10px; padding: 12px 14px;
  font-family: var(--kao-font-kao); font-size: 18px; color: var(--kao-ink); background: var(--kao-bg); outline: 0;
  transition: border-color .14s, box-shadow .14s;
}
.kao-contrib input[type=text]:focus { border-color: var(--kao-accent); box-shadow: 0 0 0 4px var(--kao-accent-wash); background: var(--kao-surface); }
.kao-contrib input::placeholder { color: var(--kao-ink-faint); font-family: var(--kao-font-ui); font-size: 15px; }
.kao-contrib .ct-submit {
  border: 0; cursor: pointer; font-family: var(--kao-font-ui); font-weight: 600; font-size: 15px; color: #fff;
  background: var(--kao-accent); padding: 0 22px; border-radius: 10px; transition: filter .15s, transform .05s; white-space: nowrap;
}
.kao-contrib .ct-submit:hover { filter: brightness(1.05); }
.kao-contrib .ct-submit:active { transform: translateY(1px); }
.kao-contrib .ct-submit:disabled { opacity: .45; cursor: not-allowed; }
.kao-contrib .ct-hint { font-size: 12.5px; color: var(--kao-ink-faint); }
.kao-contrib .ct-hint b { color: var(--kao-accent-ink); }
.kao-contrib .ct-ok { display: none; align-items: center; gap: 8px; font-size: 14px; color: oklch(0.5 0.13 150); font-weight: 500; }
.kao-contrib.is-done .ct-ok { display: flex; }

/* ---------- Đánh giá bài viết ---------- */
.kao-rate {
  margin: 36px 0 10px; padding: 22px; border-radius: var(--kao-radius);
  background: var(--kao-accent-wash); border: 1px solid color-mix(in oklab, var(--kao-accent) 18%, transparent);
  display: flex; align-items: center; gap: 18px; flex-wrap: wrap; justify-content: center; text-align: center;
}
.kao-rate .rt-q { font-family: var(--kao-font-ui); font-weight: 600; font-size: 16px; color: var(--kao-ink); }
.kao-rate .rt-btns { display: flex; gap: 10px; }
.kao-rate .rt-btn {
  cursor: pointer; font-family: var(--kao-font-ui); font-size: 14px; font-weight: 500; color: var(--kao-ink);
  background: var(--kao-surface); border: 1px solid var(--kao-line); border-radius: 999px; padding: 10px 18px;
  display: inline-flex; align-items: center; gap: 8px; transition: all .13s;
}
.kao-rate .rt-btn:hover { border-color: var(--kao-accent); color: var(--kao-accent-ink); }
.kao-rate .rt-btn.is-picked { background: var(--kao-accent); border-color: var(--kao-accent); color: #fff; }
.kao-rate .rt-btn .n { font-family: var(--kao-font-mono); font-size: 12px; opacity: .8; }
.kao-rate .rt-thanks { display: none; font-size: 14.5px; color: var(--kao-accent-ink); font-weight: 600; }
.kao-rate.is-voted .rt-q, .kao-rate.is-voted .rt-btns { display: none; }
.kao-rate.is-voted .rt-thanks { display: flex; align-items: center; gap: 8px; }
.kao-rate-feedback { width: 100%; max-width: 520px; margin: 4px auto 0; display: none; gap: 8px; }
.kao-rate.show-fb .kao-rate-feedback { display: flex; }
.kao-rate-feedback textarea {
  flex: 1; border: 1px solid var(--kao-line); border-radius: 10px; padding: 10px 12px; resize: vertical;
  font-family: var(--kao-font-ui); font-size: 13.5px; color: var(--kao-ink); background: var(--kao-surface); outline: 0; min-height: 44px;
}
.kao-rate-feedback textarea:focus { border-color: var(--kao-accent); }
.kao-rate-feedback button {
  border: 0; cursor: pointer; background: var(--kao-ink); color: var(--kao-bg); border-radius: 10px;
  padding: 0 16px; font-family: var(--kao-font-ui); font-weight: 600; font-size: 13.5px;
}

/* ---------- Section divider trên trang chủ ---------- */
.kao-divider { height: 1px; background: var(--kao-line); margin: 8px 0; }

@media (max-width: 720px) {
  .kao-rank.cols { grid-template-columns: 1fr; }
  .kao-hero-glyph { font-size: 32px; padding: 12px 14px; }
}
@media (max-width: 560px) {
  .kao-hero { gap: 14px; }
  .kao-rank-count { display: none; }
}
