/* Speech recognition as cooperating knowledge sources — Raj Reddy's blackboard idea.
   The same sounds can be carved into different words ("recognize speech" vs "wreck a
   nice beach"). On the acoustic signal alone they score about equally — the machine
   can't choose. Add a language model that knows which word sequences are plausible
   and the ambiguity collapses to what was meant. Vanilla JS, no deps, no build.
   Dark theme. Palette shared with siblings: cyan = acoustic, green = the recognized
   sentence (the win). No red. */

#speech-lattice {
  --sl-feat: #5ac8fa;
  --sl-win: #30d158;
  font-family: var(--font-family, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
  background: var(--color-bg-elevated, #111111);
  border: 1px solid var(--color-border, rgba(255, 255, 255, 0.1));
  border-radius: 16px; padding: clamp(16px, 3vw, 26px); margin: 2.5rem 0;
  color: var(--color-text-primary, #ffffff);
}
.sl-title { font-size: 1rem; font-weight: 650; letter-spacing: -0.01em; }
.sl-explain { font-size: 0.9rem; line-height: 1.55; margin: 8px 0 16px; color: var(--color-text-secondary, rgba(255,255,255,0.7)); }

.sl-signal { font-family: var(--font-mono, monospace); font-size: 0.84rem; letter-spacing: 1px; color: var(--sl-feat); background: #0c0c0f; border: 1px solid var(--color-border-subtle, rgba(255,255,255,0.08)); border-radius: 9px; padding: 12px 14px; text-align: center; margin-bottom: 16px; }
.sl-signal .sl-siglabel { display: block; font-family: var(--font-family, sans-serif); font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.09em; color: var(--color-text-tertiary, rgba(255,255,255,0.42)); margin-bottom: 6px; }

.sl-modes { display: inline-flex; gap: 4px; padding: 4px; border-radius: 10px; background: var(--color-bg-surface, #1a1a1a); margin-bottom: 16px; }
.sl-mode { appearance: none; cursor: pointer; font: inherit; font-size: 0.84rem; font-weight: 600; border: 0; background: transparent; color: var(--color-text-secondary, rgba(255,255,255,0.55)); padding: 7px 14px; border-radius: 7px; transition: color 0.18s, background 0.18s; }
.sl-mode:hover { color: var(--color-text-primary, #fff); }
.sl-mode.is-on { color: #0b0b0b; background: var(--color-accent, #fff); }

.sl-cands { display: flex; flex-direction: column; gap: 12px; }
.sl-cand { background: var(--color-bg-surface, #1a1a1a); border: 1px solid var(--color-border-subtle, rgba(255,255,255,0.08)); border-radius: 12px; padding: 12px 14px; transition: border-color 0.25s; }
.sl-cand.win { border-color: var(--sl-win); }
.sl-cand-top { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; }
.sl-words { font-size: 1.05rem; font-weight: 600; color: #fff; }
.sl-cand.win .sl-words { color: var(--sl-win); }
.sl-pct { font-family: var(--font-mono, monospace); font-size: 0.95rem; color: var(--color-text-secondary, rgba(255,255,255,0.7)); font-variant-numeric: tabular-nums; }
.sl-cand.win .sl-pct { color: var(--sl-win); }
.sl-track { height: 9px; border-radius: 5px; background: rgba(255,255,255,0.06); margin-top: 9px; overflow: hidden; }
.sl-fill { height: 100%; width: 50%; border-radius: 5px; background: var(--sl-feat); transition: width 0.6s cubic-bezier(.2,.7,.2,1), background 0.3s; }
.sl-cand.win .sl-fill { background: var(--sl-win); }

.sl-caption { margin-top: 16px; font-size: 0.9rem; line-height: 1.55; color: var(--color-text-secondary, rgba(255,255,255,0.78)); min-height: 2.6em; }
.sl-caption b { color: #fff; }
.sl-caption .sl-hl { color: var(--sl-win); font-weight: 650; }
.sl-noscript { font-size: 0.9rem; color: var(--color-text-secondary, rgba(255,255,255,0.65)); line-height: 1.6; }
