/* ============================================================
   kata.css · the deep Kata page (kata.html)
   ============================================================ */

.kata-hero h1 { max-width: 18ch; }
.kata-built { font-family: var(--font-mono); font-size: 0.8rem; color: var(--muted); margin-top: var(--s-6); }
.kata-note {
  margin-top: var(--s-6); max-width: 64ch;
  font-family: var(--font-mono); font-size: 0.82rem; color: var(--muted);
  border: 1px dashed var(--hairline); border-radius: var(--radius); padding: var(--s-4) var(--s-6);
}

.kata-h2 { font-size: var(--t-display-2); max-width: 20ch; line-height: 1.05; margin-top: var(--s-4); }
.kata-h3 { font-size: var(--t-heading); margin: var(--s-12) 0 var(--s-6); }
.kata-lede { color: var(--muted); max-width: 60ch; margin-top: var(--s-5); font-size: 1.08rem; }

/* ---- 01 pipeline ---- */
.kata-pipeline {
  display: flex; align-items: stretch; gap: var(--s-3); flex-wrap: wrap;
  margin-top: var(--s-12);
}
.kata-step {
  flex: 1 1 180px;
  display: flex; flex-direction: column; gap: 6px;
  padding: var(--s-6);
  border: 1px solid var(--hairline); border-radius: var(--radius); background: var(--surface);
}
.kata-step__n { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent); }
.kata-step__t { font-family: var(--font-display); font-size: 1.35rem; }
.kata-step__s { font-size: 0.92rem; color: var(--muted); }
.kata-arrow { align-self: center; color: var(--muted); font-size: 1.3rem; }
@media (max-width: 760px) { .kata-arrow { transform: rotate(90deg); align-self: flex-start; margin-left: var(--s-6); } .kata-step { flex-basis: 100%; } }

/* ---- 02 rubric ---- */
.kata-rubric { display: grid; grid-template-columns: 1fr 1fr; gap: 0; margin-top: var(--s-12); border-top: 1px solid var(--hairline); }
.kata-dim { padding: var(--s-6) var(--s-6) var(--s-6) 0; border-bottom: 1px solid var(--hairline); }
.kata-dim:nth-child(odd) { border-right: 1px solid var(--hairline); padding-right: var(--s-8); }
.kata-dim:nth-child(even) { padding-left: var(--s-8); }
.kata-dim__h { font-family: var(--font-display); font-size: 1.3rem; display: block; margin-bottom: 8px; }
.kata-dim__h b { font-family: var(--font-mono); font-size: 0.8rem; color: var(--accent); font-weight: 700; margin-right: 8px; }
.kata-dim p { color: var(--muted); font-size: 0.98rem; }
@media (max-width: 680px) {
  .kata-rubric { grid-template-columns: 1fr; }
  .kata-dim:nth-child(odd) { border-right: none; padding-right: 0; }
  .kata-dim:nth-child(even) { padding-left: 0; }
}

/* ---- 03 prompt ---- */
.kata-prompt {
  margin-top: var(--s-10);
  background: #1E1A14;
  color: #EFE7D8;
  border-radius: var(--radius-lg);
  padding: clamp(20px, 3vw, 36px);
  overflow-x: auto;
  border: 1px solid #2E281F;
}
.kata-prompt code {
  font-family: var(--font-mono); font-size: 0.82rem; line-height: 1.7;
  white-space: pre; color: inherit;
}

/* ---- 04 table ---- */
.kata-table-wrap { margin-top: var(--s-10); overflow-x: auto; }
.kata-table { min-width: 560px; }
.kata-table td:last-child, .kata-table th:last-child { font-variant-numeric: tabular-nums; }
.kata-tablecap { font-family: var(--font-mono); font-size: 0.74rem; color: var(--muted); margin-top: var(--s-4); }

/* outcome + grade chips */
.kchip {
  display: inline-block; font-family: var(--font-mono); font-size: 0.66rem;
  letter-spacing: 0.04em; padding: 4px 10px; border-radius: 999px;
  background: var(--surface-2); color: var(--muted); border: 1px solid var(--hairline);
}
.kchip--hot    { background: color-mix(in srgb, var(--accent) 16%, transparent); color: var(--accent); border-color: color-mix(in srgb, var(--accent) 30%, transparent); }
.kchip--strong { background: color-mix(in srgb, var(--support) 16%, transparent); color: var(--support); border-color: color-mix(in srgb, var(--support) 30%, transparent); }
.kchip--warm   { background: color-mix(in srgb, #E6A766 22%, transparent); color: #9a6b2e; border-color: color-mix(in srgb, #E6A766 36%, transparent); }
.kchip--comp   { background: color-mix(in srgb, var(--support) 12%, transparent); color: var(--support); }
.kchip--long   { color: var(--muted); }
.kchip--dead   { color: var(--muted); opacity: 0.8; }
.kchip--weak   { background: color-mix(in srgb, var(--accent) 14%, transparent); color: var(--accent); }
:root[data-theme="dark"] .kchip--warm { color: #E6A766; }

/* ---- 05 detailed review ---- */
.kata-callmeta {
  display: flex; flex-wrap: wrap; gap: var(--s-8);
  margin-top: var(--s-10); padding: var(--s-6) 0; border-top: 1px solid var(--hairline); border-bottom: 1px solid var(--hairline);
}
.kata-callmeta > div { display: flex; flex-direction: column; gap: 4px; }
.kata-callmeta .label { color: var(--muted); }
.kata-callmeta strong { font-family: var(--font-display); font-size: 1.2rem; font-weight: 460; }

.kata-scorecard { margin-top: var(--s-6); border-top: 1px solid var(--hairline); }
.kata-srow {
  display: grid; grid-template-columns: 150px 1fr auto; gap: var(--s-6); align-items: center;
  padding: var(--s-5) 0; border-bottom: 1px solid var(--hairline);
}
.kata-srow__name { font-family: var(--font-display); font-size: 1.15rem; }
.kata-srow__note { color: var(--muted); font-size: 0.96rem; }
.kata-score {
  font-family: var(--font-mono); font-weight: 700; font-size: 0.95rem;
  width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center;
  background: var(--surface-2); color: var(--muted);
}
.kata-score--top, .kata-score--hi { background: color-mix(in srgb, var(--support) 18%, transparent); color: var(--support); }
.kata-score--mid { background: var(--surface-2); color: var(--muted); }
.kata-score--lo { background: color-mix(in srgb, var(--accent) 16%, transparent); color: var(--accent); }
@media (max-width: 640px) {
  .kata-srow { grid-template-columns: 1fr auto; grid-template-areas: "name score" "note note"; gap: var(--s-2) var(--s-4); }
  .kata-srow__name { grid-area: name; }
  .kata-score { grid-area: score; }
  .kata-srow__note { grid-area: note; }
}

.kata-summary {
  display: flex; gap: var(--s-10); align-items: center; flex-wrap: wrap;
  margin-top: var(--s-8); padding: var(--s-8); border-radius: var(--radius-lg); background: var(--surface);
  border: 1px solid var(--hairline);
}
.kata-summary__overall { display: flex; flex-direction: column; gap: 6px; }
.kata-summary__num { font-family: var(--font-display); font-size: clamp(2.6rem, 6vw, 4rem); line-height: 1; color: var(--accent); }
.kata-summary__num small { font-size: 0.9rem; color: var(--muted); }
.kata-summary__verdict { flex: 1; min-width: 240px; display: flex; flex-direction: column; align-items: flex-start; gap: var(--s-3); }
.kata-summary__verdict p { color: var(--muted); }

/* ---- 06 objections ---- */
.kata-objections { display: grid; gap: var(--s-4); margin-top: var(--s-10); }
.kata-obj { border: 1px solid var(--hairline); border-radius: var(--radius); padding: var(--s-6); background: var(--surface); }
.kata-obj__quote { font-family: var(--font-display); font-size: 1.4rem; line-height: 1.2; margin-bottom: var(--s-5); }
.kata-obj__meta { display: grid; grid-template-columns: 140px 1fr auto; gap: var(--s-6); align-items: start; }
.kata-obj__meta .label { display: block; margin-bottom: 4px; }
.kata-obj__meta > div > span:not(.label):not(.kchip) { color: var(--muted); font-size: 0.96rem; }
@media (max-width: 680px) { .kata-obj__meta { grid-template-columns: 1fr; gap: var(--s-4); } }

/* ---- 07 actions ---- */
.kata-actions { margin-top: var(--s-8); border-top: 1px solid var(--hairline); }
.kata-actions li { display: grid; grid-template-columns: auto 1fr; gap: var(--s-4); padding: var(--s-5) 0; border-bottom: 1px solid var(--hairline); }
.kata-actions__a { color: var(--accent); font-size: 1.1rem; }
.kata-actions li p { font-size: 1.08rem; margin-bottom: 4px; }
.kata-actions__meta { font-family: var(--font-mono); font-size: 0.74rem; color: var(--muted); }

/* ---- 08 loops ---- */
.kata-loops { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-4); margin-top: var(--s-12); }
.kata-loop { border: 1px solid var(--hairline); border-radius: var(--radius-lg); padding: clamp(20px, 2.6vw, 32px); background: var(--surface); }
.kata-loop__when { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent); }
.kata-loop h4 { font-family: var(--font-display); font-size: 1.4rem; font-weight: 460; margin: var(--s-4) 0 var(--s-3); }
.kata-loop p { color: var(--muted); font-size: 0.96rem; }
@media (max-width: 760px) { .kata-loops { grid-template-columns: 1fr; } }
