/* ============================================================
   components.css — Thư viện pattern infographic dùng chung
   Hệ "editorial blueprint": hairline, mực serif, chip icon line.
   ============================================================ */

/* ---------- 1. TOPIC HERO (panel mực blueprint) ---------- */
.hero {
  position: relative; overflow: hidden;
  background: var(--brand-900);
  color: #f3ede0; border-radius: var(--radius-lg);
  padding: clamp(1.75rem, 1.2rem + 4vw, 3.75rem);
  box-shadow: var(--shadow-lg);
}
/* lưới blueprint chỉ sống TRONG panel mực, không phủ trang */
.hero::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(128,168,207,.10) 1px, transparent 1px),
    linear-gradient(90deg, rgba(128,168,207,.10) 1px, transparent 1px);
  background-size: 30px 30px;
  mask-image: radial-gradient(120% 110% at 88% 0, #000 10%, transparent 72%);
}
.hero::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(80% 90% at 92% 4%, rgba(128,168,207,.18), transparent 55%);
}
.hero > * { position: relative; }
.hero .kicker { display: flex; align-items: center; gap: var(--s-3); margin-bottom: var(--s-5); flex-wrap: wrap; }
.hero .topic-no {
  font-family: var(--font-mono); font-weight: 600; font-size: var(--fs-tiny); letter-spacing: .1em;
  color: var(--brand-300); border: 1px solid rgba(128,168,207,.4); border-radius: 6px; padding: 3px 9px;
}
.hero h1 { color: #fff; font-size: var(--fs-hero); letter-spacing: -0.022em; line-height: 1.04; max-width: 18ch; }
.hero .subtitle-en { color: var(--brand-300); font-family: var(--font-mono); font-size: .95rem;
  letter-spacing: .02em; margin-top: var(--s-3); }
.hero .lede { color: #d7dce4; font-size: 1.12rem; max-width: 60ch; margin-top: var(--s-5);
  padding-top: var(--s-5); border-top: 1px solid rgba(128,168,207,.22); }
.hero strong { color: #fff; }
.hero .lede strong { color: #fff; box-shadow: inset 0 -0.5em 0 rgba(128,168,207,.22); }

/* Huy hiệu */
.badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: var(--fs-tiny); font-weight: 600; letter-spacing: .04em;
  padding: 4px 10px; border-radius: 999px; text-transform: uppercase; white-space: nowrap;
  background: rgba(243,237,224,.1); color: #f3ede0; border: 1px solid rgba(243,237,224,.22);
}
.badge.solid { background: var(--accent); border-color: transparent; color: #fff; }
.badge.ghost { background: var(--accent-bg); color: var(--accent); border-color: transparent; }
.badge .ic { width: 1em; height: 1em; }

/* ---------- 2. CARD nền chung ---------- */
.card {
  background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--radius); padding: var(--s-5); box-shadow: var(--shadow-sm);
}

/* ---------- 3. CONCEPT CARDS (lưới) ---------- */
.grid { display: grid; gap: var(--s-4); }
.grid.cols-2 { grid-template-columns: repeat(auto-fit, minmax(248px, 1fr)); }
.grid.cols-3 { grid-template-columns: repeat(auto-fit, minmax(216px, 1fr)); }

.concept {
  position: relative; background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--radius); padding: var(--s-5);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.concept:hover { transform: translateY(-3px); box-shadow: var(--shadow); border-color: var(--line-strong); }
.concept .ic-chip {
  width: 38px; height: 38px; border-radius: 9px; display: grid; place-items: center;
  background: var(--accent-bg); color: var(--accent); margin-bottom: var(--s-4);
  border: 1px solid color-mix(in srgb, var(--accent) 18%, transparent);
}
.concept .ic-chip .ic { width: 20px; height: 20px; }
.concept h3 { margin-bottom: 3px; font-size: 1.08rem; }
.concept .term-en { font-family: var(--font-mono); font-size: var(--fs-tiny); color: var(--muted);
  letter-spacing: .01em; margin-bottom: var(--s-3); }
.concept p { font-size: var(--fs-small); margin: 0; }
.concept .tag {
  display: inline-block; font-family: var(--font-mono); font-size: var(--fs-tiny);
  background: var(--surface-2); color: var(--ink-soft); border: 1px solid var(--line);
  padding: 3px 8px; border-radius: 6px; margin-top: var(--s-4); line-height: 1.5; }

/* ---------- 4. STAT / NUMBER CALLOUT ---------- */
.stats { display: grid; gap: var(--s-4); grid-template-columns: repeat(auto-fit, minmax(150px,1fr)); }
.stat { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
  padding: var(--s-5); }
.stat .num { font-family: var(--font-num); font-size: 2.7rem; font-weight: 600; color: var(--accent);
  line-height: 1; letter-spacing: -0.02em; }
.stat .lbl { font-size: var(--fs-small); color: var(--muted); margin-top: var(--s-2); }

/* ---------- 5. RATING — chấm tròn (đặc tính kiến trúc) ---------- */
.ratings { display: grid; gap: 0; border: 1px solid var(--line); border-radius: var(--radius);
  overflow: hidden; background: var(--surface); }
.rating { display: grid; grid-template-columns: 1fr auto; align-items: center; gap: var(--s-4);
  padding: var(--s-3) var(--s-5); border-bottom: 1px solid var(--line-soft); }
.rating:last-child { border-bottom: 0; }
.rating .rlabel { font-weight: 500; color: var(--ink); }
.rating .rlabel small { display: block; color: var(--muted); font-weight: 400; font-size: var(--fs-tiny); font-family: var(--font-mono); }
.stars { --on: var(--accent); display: inline-flex; gap: 5px; white-space: nowrap; }
.stars i { width: 9px; height: 9px; border-radius: 50%; background: var(--line-strong);
  display: inline-block; font-size: 0; }
.stars i.on { background: var(--on); }

/* ---------- 6. ƯU / NHƯỢC (pros & cons) ---------- */
.proscons { display: grid; gap: var(--s-4); grid-template-columns: repeat(auto-fit, minmax(280px,1fr)); }
.pc { border-radius: var(--radius); padding: var(--s-5); border: 1px solid var(--line); background: var(--surface); }
.pc h4 { display: flex; align-items: center; gap: var(--s-2); margin-bottom: var(--s-4);
  font-family: var(--font-mono); text-transform: uppercase; letter-spacing: .08em; font-size: var(--fs-small); }
.pc h4 .ic { width: 1.1em; height: 1.1em; padding: 3px; border-radius: 5px; box-sizing: content-box; }
.pc.pros { border-top: 3px solid var(--pro); }
.pc.cons { border-top: 3px solid var(--con); }
.pc.pros h4 { color: var(--pro); } .pc.pros h4 .ic { background: var(--pro-bg); }
.pc.cons h4 { color: var(--con); } .pc.cons h4 .ic { background: var(--con-bg); }
.pc ul { margin: 0; padding: 0; list-style: none; }
.pc li { position: relative; margin-bottom: var(--s-3); padding-left: var(--s-4); color: var(--ink-soft); font-size: var(--fs-small); }
.pc li:last-child { margin-bottom: 0; }
.pc li::before { content: ""; position: absolute; left: 0; top: .62em; width: 5px; height: 5px;
  border-radius: 50%; background: var(--line-strong); }
.pc.pros li::before { background: var(--pro); }
.pc.cons li::before { background: var(--con); }

/* ---------- 7. BẢNG SO SÁNH ---------- */
.table-wrap { overflow-x: auto; border: 1px solid var(--line); border-radius: var(--radius); }
table.cmp { width: 100%; border-collapse: collapse; font-size: var(--fs-small); background: var(--surface); }
table.cmp th, table.cmp td { padding: var(--s-3) var(--s-4); text-align: left; border-bottom: 1px solid var(--line-soft); vertical-align: middle; }
table.cmp thead th { background: var(--surface-2); font-family: var(--font-mono); font-weight: 600;
  text-transform: uppercase; letter-spacing: .06em; font-size: var(--fs-tiny); color: var(--ink-soft);
  position: sticky; top: 0; border-bottom: 2px solid var(--ink); }
table.cmp tbody tr:last-child td { border-bottom: 0; }
table.cmp tbody tr:hover { background: var(--surface-2); }
table.cmp td:first-child { font-weight: 600; color: var(--ink); }

/* ---------- 8. FLOW / TIMELINE STEPS ---------- */
.flow { display: grid; gap: 0; counter-reset: step;
  border-left: 2px solid var(--line); margin-left: 16px; }
.flow .step { position: relative; padding: 0 0 var(--s-5) var(--s-6); }
.flow .step:last-child { padding-bottom: 0; }
.flow .step::before {
  counter-increment: step; content: counter(step, decimal-leading-zero);
  position: absolute; left: -17px; top: -2px;
  width: 32px; height: 32px; border-radius: 50%; display: grid; place-items: center;
  background: var(--surface); color: var(--accent); border: 2px solid var(--accent);
  font-family: var(--font-mono); font-weight: 600; font-size: var(--fs-tiny); }
.flow .step h4 { margin-bottom: 2px; font-size: 1.05rem; }
.flow .step p { font-size: var(--fs-small); margin: 0; }

/* Bậc thang (thang độ mạnh) */
.ladder { display: grid; gap: 6px; }
.ladder .rung { display: grid; grid-template-columns: 116px 1fr; gap: var(--s-4); align-items: center;
  padding: var(--s-3) var(--s-4); border-radius: var(--radius-sm); border: 1px solid var(--line); background: var(--surface); }
.ladder .rung .side { font-family: var(--font-mono); font-size: var(--fs-tiny); font-weight: 600; }
.ladder .rung .bar { height: 8px; border-radius: 4px; background: linear-gradient(90deg, var(--pro), var(--warn), var(--con)); }

/* ---------- 9. QUOTE / CALLOUT ---------- */
.quote {
  position: relative; margin: var(--s-6) 0; padding: var(--s-2) 0 var(--s-2) var(--s-6);
  border-left: 3px solid var(--accent);
}
.quote p { font-family: var(--font-display); font-size: 1.4rem; line-height: 1.4; font-style: italic;
  color: var(--ink); font-weight: 500; letter-spacing: -0.01em; }
.quote cite { display: block; margin-top: var(--s-3); font-style: normal; font-family: var(--font-mono);
  font-size: var(--fs-tiny); text-transform: uppercase; letter-spacing: .08em; color: var(--muted); }

.callout { display: grid; grid-template-columns: auto 1fr; gap: var(--s-4); align-items: start;
  border: 1px solid var(--line); border-left: 3px solid var(--info); background: var(--surface);
  padding: var(--s-4) var(--s-5); border-radius: var(--radius); margin: var(--s-5) 0; }
.callout.key { border-left-color: var(--accent); }
.callout .ic-chip { width: 30px; height: 30px; border-radius: 8px; display: grid; place-items: center;
  background: var(--info-bg); color: var(--info); flex: none; }
.callout.key .ic-chip { background: var(--accent-bg); color: var(--accent); }
.callout .ic-chip .ic { width: 17px; height: 17px; }
.callout p { margin: 0; font-size: var(--fs-small); color: var(--ink-soft); align-self: center; }
.callout strong { color: var(--ink); }

/* ---------- 10. CODE BLOCK ---------- */
.code { margin: var(--s-5) 0; border-radius: var(--radius); overflow: hidden;
  border: 1px solid var(--brand-900); box-shadow: var(--shadow-sm); }
.code .code-head { display: flex; align-items: center; gap: 7px; background: var(--brand-900); padding: 9px 14px; }
.code .code-head .dot { width: 10px; height: 10px; border-radius: 50%; background: #3b4d68; }
.code .code-head .fn { margin-left: var(--s-3); font-family: var(--font-mono); font-size: var(--fs-tiny);
  color: #8aa3c2; letter-spacing: .02em; }
.code pre { margin: 0; }
.code pre code.hljs { padding: var(--s-4) var(--s-5); font-size: var(--fs-small); line-height: 1.65; background: #0f1c30; }
.code .note { font-size: var(--fs-tiny); color: var(--muted); padding: 9px 14px; background: var(--surface-2);
  border-top: 1px solid var(--line); }

/* ---------- 10b. BAD → GOOD (đối chiếu code bẩn ↔ sạch) ---------- */
/* Cặp panel code XẾP DỌC: ❌ Bẩn (viền đỏ) trên → ✅ Sạch (viền xanh) dưới, kèm 1 dòng "vì sao".
   Xếp dọc full chiều rộng cho dễ đọc (cột đọc hẹp, chia 2 cột làm code bị chật). */
.badgood { display: grid; gap: var(--s-3); grid-template-columns: 1fr; margin: var(--s-5) 0; }
.badgood .code { margin: 0; }
.badgood .code.bad { border-color: var(--con); }
.badgood .code.good { border-color: var(--pro); }
.badgood .code.bad .code-head { background: #2a1517; }
.badgood .code.good .code-head { background: #0f2519; }
.bg-tag { margin-left: auto; display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--font-mono); font-weight: 600; text-transform: uppercase; letter-spacing: .07em;
  font-size: var(--fs-tiny); padding: 2px 9px; border-radius: 999px; }
.code.bad .bg-tag { color: #ffadad; background: rgba(196,72,72,.22); }
.code.good .bg-tag { color: #9be6b6; background: rgba(48,168,104,.22); }
.bg-why { display: grid; grid-template-columns: auto 1fr; gap: var(--s-3); align-items: start;
  margin: calc(-1 * var(--s-2)) 0 var(--s-5); padding: var(--s-3) var(--s-4);
  border: 1px solid var(--line); border-left: 3px solid var(--pro); border-radius: var(--radius);
  background: var(--surface); font-size: var(--fs-small); color: var(--ink-soft); }
.bg-why .ic-chip { width: 26px; height: 26px; border-radius: 7px; display: grid; place-items: center;
  background: var(--pro-bg); color: var(--pro); flex: none; }
.bg-why .ic-chip .ic { width: 15px; height: 15px; }
.bg-why p { margin: 0; align-self: center; }
.bg-why strong { color: var(--ink); }

/* ---------- 11. DIAGRAM ---------- */
.diagram { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
  padding: var(--s-6) var(--s-5); text-align: center; }
.diagram svg { max-width: 100%; height: auto; }
.diagram .cap { font-size: var(--fs-tiny); color: var(--muted); margin-top: var(--s-4);
  text-align: left; line-height: 1.6; }
.mermaid { display: flex; justify-content: center; }

/* ---------- 12. CITATION FOOTER (trong topic) ---------- */
.cite-foot {
  margin-top: var(--s-8); padding: var(--s-5);
  border: 1px solid var(--line); border-left: 3px solid var(--accent); border-radius: var(--radius);
  background: var(--surface); font-size: var(--fs-small); color: var(--ink-soft);
  display: grid; grid-template-columns: auto 1fr; gap: var(--s-4); align-items: start; }
.cite-foot .ic-chip { width: 30px; height: 30px; border-radius: 8px; display: grid; place-items: center;
  background: var(--accent-bg); color: var(--accent); flex: none; }
.cite-foot .ic-chip .ic { width: 17px; height: 17px; }
.cite-foot .lab { display: block; font-family: var(--font-mono); text-transform: uppercase;
  letter-spacing: .1em; font-size: var(--fs-tiny); color: var(--muted); margin-bottom: 3px; }

/* ---------- NAV PREV / NEXT ---------- */
.pager { display: grid; gap: var(--s-4); grid-template-columns: repeat(auto-fit, minmax(240px,1fr)); margin-top: var(--s-8); }
.pager a { display: flex; flex-direction: column; gap: 3px; padding: var(--s-4) var(--s-5);
  border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface);
  box-shadow: var(--shadow-sm); transition: border-color .15s, transform .15s; }
.pager a:hover { border-color: var(--accent); transform: translateY(-2px); text-decoration: none; }
.pager .dir { font-family: var(--font-mono); font-size: var(--fs-tiny); color: var(--muted);
  text-transform: uppercase; letter-spacing: .08em; display: flex; align-items: center; gap: 6px; }
.pager .ttl { font-family: var(--font-display); font-size: 1.1rem; font-weight: 600; color: var(--ink); }
.pager a.next { text-align: right; align-items: flex-end; }
.pager a.disabled { opacity: .45; pointer-events: none; }

/* ============================================================
   HUB (index.html)
   ============================================================ */
.hub-cover { display: grid; grid-template-columns: 1fr; gap: var(--s-8); align-items: center;
  padding-block: var(--s-10) var(--s-8); }
@media (min-width: 900px) { .hub-cover { grid-template-columns: 1.15fr .85fr; gap: var(--s-10); } }
.hub-cover .lede-h1 { font-size: var(--fs-hero); letter-spacing: -0.025em; line-height: 1.02;
  max-width: 16ch; margin-top: var(--s-4); }
.hub-cover .lede-h1 em { color: var(--brand-700); font-style: normal;
  box-shadow: inset 0 -0.12em 0 var(--brand-300); }
.hub-cover p { font-size: 1.16rem; max-width: 46ch; margin-top: var(--s-5); }
.hub-cover .spec { display: flex; flex-wrap: wrap; gap: 0; margin-top: var(--s-6);
  border-top: 1px solid var(--line); }
.hub-cover .spec .item { display: flex; align-items: center; gap: var(--s-3);
  padding: var(--s-4) var(--s-5) var(--s-4) 0; }
.hub-cover .spec .item + .item { border-left: 1px solid var(--line); padding-left: var(--s-5); }
.hub-cover .spec .ic { color: var(--brand-700); width: 20px; height: 20px; flex: none; }
.hub-cover .spec b { color: var(--ink); font-weight: 600; }
.hub-cover .spec span { display: block; font-size: var(--fs-small); color: var(--muted); line-height: 1.4; }

/* Panel "bìa" blueprint bên phải */
.cover-panel { position: relative; overflow: hidden; border-radius: var(--radius-lg);
  background: var(--brand-900); color: #f3ede0; padding: var(--s-6); box-shadow: var(--shadow-lg);
  min-height: 280px; display: flex; flex-direction: column; justify-content: space-between; }
.cover-panel::before { content: ""; position: absolute; inset: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(128,168,207,.12) 1px, transparent 1px),
    linear-gradient(90deg, rgba(128,168,207,.12) 1px, transparent 1px);
  background-size: 26px 26px; mask-image: radial-gradient(120% 120% at 80% 10%, #000 20%, transparent 78%); }
.cover-panel > * { position: relative; }
.cover-panel .pmark { width: 46px; height: 46px; border-radius: 11px; display: grid; place-items: center;
  background: rgba(243,237,224,.08); border: 1px solid rgba(128,168,207,.3); color: #f3ede0; }
.cover-panel .pmark .ic { width: 26px; height: 26px; }
.cover-panel .big { display: flex; align-items: baseline; gap: var(--s-5); margin-top: var(--s-5); }
.cover-panel .big .figure { font-family: var(--font-num); font-size: 4.6rem; font-weight: 600;
  line-height: .9; color: #fff; letter-spacing: -0.03em; }
.cover-panel .big .figure small { display: block; font-family: var(--font-mono); font-size: .68rem;
  font-weight: 500; letter-spacing: .14em; text-transform: uppercase; color: var(--brand-300); margin-top: var(--s-2); }
.cover-panel .src { margin-top: var(--s-6); padding-top: var(--s-4); border-top: 1px solid rgba(128,168,207,.22);
  font-family: var(--font-mono); font-size: var(--fs-tiny); letter-spacing: .04em; color: var(--brand-300); }
.cover-panel .src b { color: #f3ede0; font-weight: 600; }

/* Tiêu đề PHẦN */
.part-head { display: grid; grid-template-columns: auto auto 1fr; align-items: center; gap: var(--s-4);
  margin: var(--s-10) 0 var(--s-5); }
.part-head .pnum { font-family: var(--font-num); font-weight: 600; font-size: 2.7rem; line-height: 1;
  color: var(--accent); letter-spacing: -0.02em; }
.part-head h2 { font-size: 1.5rem; line-height: 1.05; }
.part-head .part-en { display: block; font-family: var(--font-mono); font-size: var(--fs-tiny);
  text-transform: uppercase; letter-spacing: .1em; color: var(--muted); margin-top: 3px; }

/* Lưới topic */
.topic-grid { display: grid; gap: var(--s-4); grid-template-columns: repeat(auto-fill, minmax(270px,1fr)); }
.topic-card {
  position: relative; display: flex; flex-direction: column; gap: var(--s-2); overflow: hidden;
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
  padding: var(--s-5); min-height: 168px;
  transition: transform .18s, box-shadow .18s, border-color .18s;
}
.topic-card .tno { font-family: var(--font-num); font-size: 2.4rem; font-weight: 600; line-height: 1;
  color: var(--accent); letter-spacing: -0.02em; }
.topic-card h3 { color: var(--ink); font-size: 1.14rem; margin-top: 2px; }
.topic-card .ten { font-family: var(--font-mono); font-size: var(--fs-tiny); color: var(--muted); letter-spacing: .01em; }
.topic-card p { font-size: var(--fs-small); margin-top: var(--s-2); margin-bottom: 0; }
.topic-card .tc-go { position: absolute; right: var(--s-5); bottom: var(--s-5); color: var(--accent);
  opacity: 0; transform: translateX(-6px); transition: opacity .18s, transform .18s; }
.topic-card .tc-go .ic { width: 20px; height: 20px; }
.topic-card:not(.soon):hover { transform: translateY(-4px); box-shadow: var(--shadow);
  border-color: var(--accent); text-decoration: none; }
.topic-card:not(.soon):hover .tc-go { opacity: 1; transform: translateX(0); }
/* watermark số mờ */
.topic-card::after { content: ""; }
.topic-card.soon { background: var(--surface-2); }
.topic-card.soon .tno, .topic-card.soon h3 { color: var(--muted); }
.topic-card.soon .ten { opacity: .8; }
.topic-card .chip { position: absolute; top: var(--s-5); right: var(--s-5);
  display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--font-mono); font-size: var(--fs-tiny); letter-spacing: .04em;
  background: var(--surface); color: var(--muted); border: 1px solid var(--line); border-radius: 999px; padding: 3px 9px; white-space: nowrap; }
.topic-card .chip .ic { width: 12px; height: 12px; }

/* ---------- responsive nhỏ ---------- */
@media (max-width: 560px) {
  .ladder .rung { grid-template-columns: 90px 1fr; }
  .rating { grid-template-columns: 1fr; gap: var(--s-2); }
  .cover-panel .big { flex-wrap: wrap; gap: var(--s-4); }
  .cover-panel .big .figure { font-size: 3.4rem; }
}
