/*
 * kitsune-b — page-local widgets built on the Kintsugi token system.
 * Uses --kin-* vars defined in tokens.css. No framework, no JS.
 */

/* ---------- Page shell ---------- */
.k-topnav {
  display: flex;
  flex-wrap: wrap;
  gap: 1.25rem;
  padding: 1rem 2rem;
  border-bottom: 1px solid var(--kin-rule, #E2E8F0);
  font-family: var(--kin-font-body, Carlito, Calibri, sans-serif);
  font-size: 0.9rem;
  letter-spacing: 0.02em;
}
.k-topnav__brand {
  font-family: var(--kin-font-display, Georgia, serif);
  font-size: 1.1rem;
  font-weight: 600;
  margin-right: 2rem;
  color: var(--kin-text-heading, #1C2541);
}
.k-topnav__brand small {
  display: block;
  font-family: var(--kin-font-body);
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--kin-text-muted, #64748B);
  font-weight: 400;
}
.k-topnav a {
  color: var(--kin-text-default, #1C2541);
  border-bottom: none !important;
  padding-bottom: 2px;
}
.k-topnav a.active {
  border-bottom: 2px solid var(--kin-primary, #0F766E) !important;
  color: var(--kin-text-heading);
}

.k-page {
  max-width: 1180px;
  margin: 0 auto;
  padding: 2rem;
}
.k-page h1 {
  font-size: 1.9rem;
  margin: 0 0 0.25rem;
}
.k-page .k-subtitle {
  color: var(--kin-text-muted, #475569);
  margin-bottom: 1.75rem;
  font-size: 0.95rem;
}

/* ---------- Generic card ---------- */
.k-card {
  background: var(--kin-bg-surface, #FFFFFF);
  border: 1px solid var(--kin-rule, #E2E8F0);
  padding: 1.25rem 1.5rem;
  margin-bottom: 1.25rem;
}
.k-card h3 {
  font-family: var(--kin-font-display);
  font-size: 1.05rem;
  margin: 0 0 0.75rem;
  letter-spacing: 0.02em;
}
.k-eyebrow {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--kin-text-muted, #64748B);
  margin-bottom: 0.35rem;
}

/* ---------- Stat strip (orig · rewrite · lift · hostile · gap · status) ---------- */
.k-stat-strip {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 0;
  border: 1px solid var(--kin-rule, #E2E8F0);
  margin: 0.75rem 0 1.5rem;
}
.k-stat-strip--list { grid-template-columns: repeat(4, 1fr); }
.k-stat {
  padding: 0.7rem 0.9rem;
  border-right: 1px solid var(--kin-rule, #E2E8F0);
}
.k-stat:last-child { border-right: none; }
.k-stat__label {
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--kin-text-muted, #64748B);
}
.k-stat__value {
  font-family: var(--kin-font-display);
  font-size: 1.25rem;
  color: var(--kin-text-heading, #1C2541);
  margin-top: 0.15rem;
}
.k-stat__value--pos { color: #0F766E; }
.k-stat__value--neg { color: #B91C1C; }
.k-stat__value--warn { color: #B45309; }

/* ---------- Tables ---------- */
.k-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}
.k-table th, .k-table td {
  border-bottom: 1px solid var(--kin-rule, #E2E8F0);
  padding: 0.55rem 0.75rem;
  text-align: left;
  vertical-align: top;
}
.k-table th {
  font-family: var(--kin-font-body);
  font-weight: 600;
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--kin-text-muted);
}
.k-table tr:hover { background: var(--kin-bg-warm, #F3F1E9); }

/* ---------- Score bar (single dimension) ---------- */
.k-bar {
  display: inline-grid;
  grid-template-columns: 1fr 2.8rem;
  align-items: center;
  gap: 0.5rem;
  min-width: 180px;
}
.k-bar__track {
  position: relative;
  height: 6px;
  background: var(--kin-rule, #E2E8F0);
}
.k-bar__fill {
  position: absolute; left: 0; top: 0; bottom: 0;
  background: var(--kin-primary, #0F766E);
}
.k-bar__value {
  font-family: var(--kin-font-mono, 'JetBrains Mono', monospace);
  font-size: 0.8rem;
  text-align: right;
}

/* ---------- Pill / Badge ---------- */
.k-pill {
  display: inline-block;
  padding: 0.12rem 0.55rem;
  border: 1px solid var(--kin-rule, #E2E8F0);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--kin-text-muted);
  background: var(--kin-bg-warm, #F3F1E9);
}
.k-pill--ok   { color: #065F46; border-color: #065F46; }
.k-pill--warn { color: #B45309; border-color: #B45309; }
.k-pill--bad  { color: #B91C1C; border-color: #B91C1C; }
.k-pill--info { color: #1E3A8A; border-color: #1E3A8A; }

/* ---------- Radar (SVG container) ---------- */
.k-radar {
  width: 320px;
  height: 320px;
  display: block;
  margin: 0 auto;
}
.k-radar .axis { stroke: var(--kin-rule, #E2E8F0); stroke-width: 1; }
.k-radar .grid { fill: none; stroke: var(--kin-rule, #E2E8F0); stroke-width: 1; }
.k-radar .poly-orig    { fill: rgba(180, 83, 9, 0.15); stroke: #B45309; stroke-width: 1.5; }
.k-radar .poly-rewrite { fill: rgba(15, 118, 110, 0.18); stroke: #0F766E; stroke-width: 1.8; }
.k-radar .label { font: 10px var(--kin-font-body); fill: var(--kin-text-muted); }

.k-legend { display: flex; gap: 1rem; justify-content: center; margin-top: 0.5rem; font-size: 0.8rem; color: var(--kin-text-muted); }
.k-legend__dot { display: inline-block; width: 10px; height: 10px; margin-right: 0.35rem; vertical-align: middle; }

/* ---------- Diff viewer (side-by-side turns) ---------- */
.k-diff {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border: 1px solid var(--kin-rule);
}
.k-diff__col {
  padding: 0;
  border-right: 1px solid var(--kin-rule);
}
.k-diff__col:last-child { border-right: none; }
.k-diff__head {
  padding: 0.5rem 0.8rem;
  background: var(--kin-bg-warm, #F3F1E9);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--kin-text-muted);
  border-bottom: 1px solid var(--kin-rule);
}
.k-turn {
  padding: 0.55rem 0.8rem;
  border-bottom: 1px dashed var(--kin-rule);
  font-size: 0.88rem;
  line-height: 1.5;
}
.k-turn__who {
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--kin-text-muted);
  margin-bottom: 0.18rem;
}
.k-turn--agent    { background: #FFFFFF; }
.k-turn--prospect { background: var(--kin-bg-warm, #F3F1E9); }
.k-turn--changed  { box-shadow: inset 3px 0 0 var(--kin-primary, #0F766E); }
.k-turn__rationale {
  margin-top: 0.3rem;
  font-size: 0.78rem;
  font-style: italic;
  color: var(--kin-text-muted);
}

/* ---------- Heatmap (8 dims × N periods / SDRs) ---------- */
.k-heatmap {
  display: grid;
  gap: 2px;
  background: var(--kin-rule, #E2E8F0);
  padding: 2px;
  border: 1px solid var(--kin-rule);
  width: fit-content;
}
.k-heatmap__cell {
  padding: 0.45rem 0.6rem;
  min-width: 72px;
  font-family: var(--kin-font-mono, monospace);
  font-size: 0.8rem;
  text-align: center;
  background: var(--kin-bg-surface, #FFFFFF);
  color: var(--kin-text-heading);
}
.k-heatmap__cell--header {
  background: var(--kin-bg-warm, #F3F1E9);
  font-family: var(--kin-font-body);
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--kin-text-muted);
  text-align: left;
  padding: 0.45rem 0.8rem;
}
.k-score-5 { background: #14B8A6 !important; color: #fff !important; }
.k-score-4 { background: #5EEAD4 !important; color: #0F172A !important; }
.k-score-3 { background: #FCD34D !important; color: #0F172A !important; }
.k-score-2 { background: #FDBA74 !important; color: #0F172A !important; }
.k-score-1 { background: #FCA5A5 !important; color: #0F172A !important; }
.k-score-na { background: var(--kin-bg-surface) !important; color: var(--kin-text-muted) !important; }

/* ---------- Segment list (single transcript view) ---------- */
.k-segments { border: 1px solid var(--kin-rule); }
.k-segment {
  display: grid;
  grid-template-columns: 5rem 1fr;
  padding: 0.5rem 0.8rem;
  border-bottom: 1px solid var(--kin-rule);
  font-size: 0.88rem;
  line-height: 1.5;
}
.k-segment:last-child { border-bottom: none; }
.k-segment__ts {
  font-family: var(--kin-font-mono, monospace);
  color: var(--kin-text-muted);
  font-size: 0.72rem;
  padding-top: 0.1rem;
}
.k-segment--agent    { background: #FFFFFF; }
.k-segment--prospect { background: var(--kin-bg-warm, #F3F1E9); }

/* ---------- Coaching moments / lists ---------- */
.k-moment {
  padding: 0.6rem 0.8rem;
  border-left: 3px solid var(--kin-primary);
  margin-bottom: 0.5rem;
  background: var(--kin-bg-warm, #F3F1E9);
  font-size: 0.88rem;
}
.k-moment--strength  { border-left-color: #0F766E; }
.k-moment--weakness  { border-left-color: #B45309; }
.k-moment__head {
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--kin-text-muted);
  margin-bottom: 0.2rem;
}

/* ---------- Tiles grid (overview dashboard) ---------- */
.k-tiles {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
}
.k-tile {
  background: var(--kin-bg-surface);
  border: 1px solid var(--kin-rule);
  padding: 1rem 1.1rem;
}
.k-tile__label {
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--kin-text-muted);
}
.k-tile__value {
  font-family: var(--kin-font-display);
  font-size: 1.8rem;
  line-height: 1;
  margin-top: 0.3rem;
  color: var(--kin-text-heading);
}
.k-tile__sub { font-size: 0.75rem; color: var(--kin-text-muted); margin-top: 0.3rem; }

/* ---------- Two-column page layout ---------- */
.k-split {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 1.25rem;
}
@media (max-width: 780px) {
  .k-split, .k-diff, .k-tiles { grid-template-columns: 1fr; }
  .k-stat-strip { grid-template-columns: repeat(2, 1fr); }
}

/* ---------- Footer caption ---------- */
.k-footnote {
  color: var(--kin-text-muted);
  font-size: 0.78rem;
  margin-top: 3rem;
  padding-top: 1rem;
  border-top: 1px solid var(--kin-rule);
}
.k-footnote code { font-family: var(--kin-font-mono, monospace); font-size: 0.78rem; }
