@import url('https://fonts.googleapis.com/css2?family=Newsreader:ital,opsz,wght@0,6..72,300..600;1,6..72,300..500&family=IBM+Plex+Mono:ital,wght@0,400;0,500;0,600;1,400&display=swap');

:root {
  --paper: oklch(0.972 0.006 85);
  --paper-2: oklch(0.987 0.004 85);
  --paper-3: oklch(0.945 0.008 82);
  --ink: oklch(0.235 0.012 60);
  --ink-2: oklch(0.43 0.012 60);
  --ink-3: oklch(0.585 0.010 62);
  --ink-4: oklch(0.70 0.008 65);
  --line: oklch(0.865 0.009 75);
  --line-2: oklch(0.915 0.006 78);
  --accent: oklch(0.42 0.095 248);
  --accent-soft: oklch(0.93 0.028 248);
  --accent-line: oklch(0.84 0.05 248);
  --ok: oklch(0.50 0.085 152);
  --ok-soft: oklch(0.935 0.03 152);
  --ok-line: oklch(0.82 0.06 152);
  --warn: oklch(0.585 0.105 66);
  --warn-soft: oklch(0.94 0.045 76);
  --warn-line: oklch(0.83 0.08 76);
  --bad: oklch(0.52 0.135 27);
  --bad-soft: oklch(0.935 0.04 27);
  --bad-line: oklch(0.84 0.08 27);
  --slate: oklch(0.55 0.012 62);
  --slate-soft: oklch(0.93 0.006 70);
  --serif: "Newsreader", Georgia, serif;
  --mono: "IBM Plex Mono", ui-monospace, Menlo, monospace;
  --shadow-lg: 0 2px 4px oklch(0.4 0.02 60 / 0.06), 0 20px 48px -20px oklch(0.4 0.02 60 / 0.30);
  /* Locked to 1168×755 — fixed width; height scales only above that viewport */
  --type-vh-ref: 755;
  --type-page-max: 1000px;
  --type-page-pad-x: 28px;
  --type-page-pad-y: 18px;
  --type-stack-gap: 20px;
  --type-intro-size: 17px;
  --type-privacy-size: 15px;
  --type-prompt-size: 30px;
  --type-compose-size: 16px;
  --type-stat-value-size: 22px;
  --type-card-pad: 16px;
  --type-label-size: 10.5px;
  --type-mono-sm: 11px;
  --type-gap-sm: 6px;
  --type-gap-md: 14px;
  --type-compose-pad-y: 16px;
  --type-compose-pad-x: 18px;
  --type-char-pad-y: 12px;
  --type-char-pad-x: 18px;
  --type-btn-pad-y: 9px;
  --type-btn-pad-x: 14px;
}

@media (min-height: 756px) {
  :root {
    --type-page-pad-y: calc(18 * 100vh / var(--type-vh-ref));
    --type-stack-gap: calc(20 * 100vh / var(--type-vh-ref));
    --type-intro-size: calc(17 * 100vh / var(--type-vh-ref));
    --type-privacy-size: calc(15 * 100vh / var(--type-vh-ref));
    --type-prompt-size: calc(30 * 100vh / var(--type-vh-ref));
    --type-compose-size: calc(16 * 100vh / var(--type-vh-ref));
    --type-stat-value-size: calc(22 * 100vh / var(--type-vh-ref));
    --type-card-pad: calc(16 * 100vh / var(--type-vh-ref));
    --type-label-size: calc(10.5 * 100vh / var(--type-vh-ref));
    --type-mono-sm: calc(11 * 100vh / var(--type-vh-ref));
    --type-gap-md: calc(14 * 100vh / var(--type-vh-ref));
    --type-compose-pad-y: calc(16 * 100vh / var(--type-vh-ref));
    --type-char-pad-y: calc(12 * 100vh / var(--type-vh-ref));
    --type-btn-pad-y: calc(9 * 100vh / var(--type-vh-ref));
  }
  .type-compose {
    min-height: calc(1.6em * 3 + 32 * 100vh / var(--type-vh-ref));
  }
  .type-char-progress-track {
    height: calc(6 * 100vh / var(--type-vh-ref));
  }
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; min-height: 100%; }
body {
  font-family: var(--serif);
  font-size: 16px;
  color: var(--ink);
  background-color: var(--paper);
  background-image: radial-gradient(oklch(0.4 0.02 60 / 0.022) 0.5px, transparent 0.5px);
  background-size: 4px 4px;
  -webkit-font-smoothing: antialiased;
}

.type-header {
  background: var(--paper-2);
  border-bottom: 1px solid var(--line);
  position: sticky;
  top: 0;
  z-index: 50;
}
.type-header-inner {
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 0 28px;
  height: 60px;
  max-width: 1100px;
  margin: 0 auto;
}
.type-mark-title {
  font-family: var(--mono);
  font-size: 15px;
  font-weight: 600;
  letter-spacing: 0.02em;
}
.type-tagline {
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 9.5px;
  color: var(--ink-4);
}
.type-motto {
  margin-left: auto;
  font-size: 12px;
  color: var(--ink-3);
  font-style: italic;
}

.type-main {
  width: 100%;
  max-width: var(--type-page-max);
  margin: 0 auto;
  padding: var(--type-page-pad-y) var(--type-page-pad-x) 6px;
}
.type-intro {
  width: 100%;
  margin-bottom: var(--type-stack-gap);
}
.type-intro-lead {
  font-size: var(--type-intro-size);
  line-height: 1.4;
  color: var(--ink);
  margin: 0 0 10px;
}
.type-intro-privacy {
  font-size: var(--type-privacy-size);
  line-height: 1.5;
  color: var(--ink-2);
  margin: 0;
  padding: 14px 16px;
  border-left: 3px solid var(--ok-line);
  background: var(--ok-soft);
  border-radius: 0 6px 6px 0;
}
.type-intro strong {
  font-weight: 600;
  color: var(--ink);
}
.type-label {
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: 0.13em;
  font-size: 10.5px;
  color: var(--ink-3);
  margin-bottom: 10px;
}
.type-label-sm {
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 9.5px;
  color: var(--ink-4);
}
.type-h1 {
  font-family: var(--serif);
  font-size: 40px;
  font-weight: 400;
  letter-spacing: -0.02em;
  margin: 0;
  line-height: 1.05;
}
.type-lead {
  font-size: 16.5px;
  color: var(--ink-2);
  margin-top: 10px;
  max-width: 600px;
  line-height: 1.5;
}
.type-session-id {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--ink-3);
  margin-top: 12px;
  letter-spacing: 0.04em;
}
.type-error {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--bad);
  margin-top: 10px;
}

.type-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr);
  gap: 24px;
  margin-top: 0;
  align-items: start;
  width: 100%;
}
.type-grid > * {
  min-width: 0;
}
@media (max-width: 800px) {
  .type-grid { grid-template-columns: 1fr; }
}
@media (min-height: 756px) {
  .type-grid { gap: calc(24 * 100vh / var(--type-vh-ref)); }
}

.type-panel {
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: hidden;
  background: var(--paper-2);
  box-shadow: var(--shadow-lg);
}
.type-panel-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 14px;
  border-bottom: 1px solid var(--line);
  background: var(--paper-3);
}
.type-dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--line);
  display: inline-block;
}
.type-panel-body { padding: 26px 28px; }
.type-question-block {
  width: 100%;
  box-sizing: border-box;
  margin-top: 0;
  margin-bottom: var(--type-stack-gap);
  padding: 14px 28px;
  border: 1px solid var(--accent-line);
  border-radius: 8px;
  background: var(--accent-soft);
  box-shadow: var(--shadow-lg);
}
.type-question-label {
  font-family: var(--mono);
  font-size: var(--type-label-size);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 10px;
}
.type-prompt-wrap {
  margin: 0;
}
.type-prompt {
  font-family: var(--serif);
  font-size: var(--type-prompt-size);
  font-weight: 400;
  margin: 0 0 10px;
  line-height: 1.25;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.type-prompt-change {
  font-family: var(--mono);
  font-size: var(--type-mono-sm);
  letter-spacing: 0.04em;
  color: var(--ink-2);
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.type-prompt-change:hover { color: var(--ink); }

.type-widget {
  border: 1px solid var(--accent-line);
  border-radius: 7px;
  overflow: hidden;
}
.type-widget.opt-out { border-color: var(--line); }
.type-widget-head {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 8px 12px;
  background: var(--paper-3);
  border-bottom: 1px solid var(--line-2);
}
.type-recdot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--bad);
  animation: recpulse 1.6s ease-out infinite;
}
.type-save-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--line);
  flex-shrink: 0;
  transition: background 0.25s, box-shadow 0.25s;
}
.type-save-dot.saving {
  background: var(--warn);
  animation: recpulse 1s ease-out infinite;
}
.type-save-dot.saved {
  background: var(--ok);
  box-shadow: 0 0 0 3px var(--ok-soft);
}
.type-save-dot.error {
  background: var(--bad);
  box-shadow: 0 0 0 3px var(--bad-soft);
}
.type-save-label {
  margin-right: 8px;
  color: var(--ink-4);
}
.type-save-label.on { color: var(--ok); }
.type-autosave-bar {
  padding: 12px 14px;
  border-top: 1px solid var(--line-2);
  background: var(--accent-soft);
  border-bottom: 1px solid var(--line-2);
}
.type-autosave-toggle {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 4px 10px;
  cursor: pointer;
  align-items: center;
}
.type-autosave-toggle input {
  accent-color: var(--accent);
  width: 15px;
  height: 15px;
  margin: 0;
}
.type-autosave-title {
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink);
}
.type-autosave-hint {
  grid-column: 1 / -1;
  font-family: var(--serif);
  font-size: 13px;
  line-height: 1.45;
  color: var(--ink-2);
  padding-left: 25px;
}
@keyframes recpulse {
  0% { box-shadow: 0 0 0 0 var(--bad-line); }
  70% { box-shadow: 0 0 0 6px transparent; }
  100% { box-shadow: 0 0 0 0 transparent; }
}
.type-strip-wrap { margin-left: auto; flex: 1; max-width: 150px; min-height: 34px; }
.type-compose-col {
  display: flex;
  flex-direction: column;
  gap: var(--type-gap-md);
  min-width: 0;
}
.type-compose {
  width: 100%;
  min-height: calc(1.6em * 3 + 32px);
  border: 1px solid var(--accent-line);
  border-radius: 8px;
  outline: none;
  resize: vertical;
  padding: var(--type-compose-pad-y) var(--type-compose-pad-x);
  font-family: var(--serif);
  font-size: var(--type-compose-size);
  line-height: 1.6;
  color: var(--ink);
  background: var(--paper-2);
  box-shadow: var(--shadow-lg);
  box-sizing: border-box;
}
.type-compose:disabled { background: var(--paper-3); }
.type-char-target {
  padding: var(--type-char-pad-y) var(--type-char-pad-x);
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--paper-3);
}
.type-char-target-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 8px;
}
.type-char-target-label {
  font-family: var(--mono);
  font-size: var(--type-label-size);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-2);
}
.type-char-target-status {
  font-family: var(--mono);
  font-size: var(--type-label-size);
  letter-spacing: 0.04em;
  color: var(--ink-3);
}
.type-char-target.status-below .type-char-target-status { color: var(--accent); }
.type-char-target.status-in-range .type-char-target-status { color: var(--ok); }
.type-char-progress-track {
  position: relative;
  height: 6px;
  border-radius: 3px;
  background: var(--line);
  overflow: hidden;
}
.type-char-progress-fill {
  height: 100%;
  width: 0%;
  border-radius: 3px;
  background: var(--accent);
  transition: width 0.15s ease, background 0.15s ease;
}
.type-char-target.status-in-range .type-char-progress-fill { background: var(--ok); }
.type-char-target-detail {
  margin: 6px 0 0;
  font-family: var(--mono);
  font-size: var(--type-mono-sm);
  letter-spacing: 0.03em;
  color: var(--ink-2);
}
.type-char-target.status-in-range .type-char-target-detail { color: var(--ok); }
.type-compose-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  width: 100%;
}
.type-opt-label {
  display: flex;
  align-items: center;
  gap: 7px;
  font-family: var(--mono);
  font-size: 10.5px;
  color: var(--ink-2);
  letter-spacing: 0.04em;
  cursor: pointer;
}
.type-word-count {
  margin: 0;
  min-width: 0;
  font-family: var(--mono);
  font-size: var(--type-label-size);
  color: var(--ink-3);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.type-btn {
  font-family: var(--mono);
  font-size: var(--type-mono-sm);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--paper);
  background: var(--ink);
  border: none;
  padding: var(--type-btn-pad-y) var(--type-btn-pad-x);
  flex-shrink: 0;
  border-radius: 5px;
  cursor: pointer;
}
.type-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.type-btn.secondary { background: var(--ink-2); }

.type-sidebar {
  display: flex;
  flex-direction: column;
  align-self: start;
}
.type-card {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--paper-2);
  padding: var(--type-card-pad);
}
.type-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  padding: var(--type-card-pad);
  width: 100%;
  box-sizing: border-box;
}
.type-stat-wpm {
  grid-column: 1 / -1;
}
.type-stat-label {
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 9.5px;
  color: var(--ink-4);
}
.type-stat-value {
  font-family: var(--mono);
  font-size: var(--type-stat-value-size);
  font-weight: 500;
  color: var(--ink);
  line-height: 1;
  margin-top: 4px;
}
.type-verdict {
  font-size: 14.5px;
  color: var(--ink-2);
  text-align: center;
  line-height: 1.5;
  font-style: italic;
  margin: 0;
}

.type-badge {
  width: 100%;
  max-width: 252px;
  border-radius: 5px;
  overflow: hidden;
  background: var(--paper-2);
  border: 1px solid var(--line);
}
.type-badge-head {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 9px 12px;
  border-bottom: 1px solid var(--line);
}
.type-badge-title {
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}
.type-badge-foot {
  display: flex;
  justify-content: space-between;
  padding: 7px 12px;
  font-family: var(--mono);
  font-size: 10px;
  color: var(--ink-2);
}
.type-badge.state-verified .type-badge-head { background: var(--ok-soft); border-color: var(--ok-line); color: var(--ok); }
.type-badge.state-review .type-badge-head { background: var(--accent-soft); border-color: var(--accent-line); color: var(--accent); }
.type-badge.state-anomaly .type-badge-head { background: var(--warn-soft); border-color: var(--warn-line); color: var(--warn); }
.type-badge.state-static .type-badge-head { background: var(--slate-soft); color: var(--slate); }
.type-badge.state-failed .type-badge-head { background: var(--bad-soft); border-color: var(--bad-line); color: var(--bad); }
.type-badge.state-verifying .type-badge-head { background: var(--accent-soft); border-color: var(--accent-line); color: var(--accent); }
.type-badge.state-idle .type-badge-head { background: var(--paper-3); color: var(--ink-3); }

.type-cadence { padding: 12px 14px; }
.type-cadence svg { width: 100%; display: block; }
.type-replay-note {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--ink-3);
  line-height: 1.7;
  margin: 0;
}

.type-nav { margin-top: 24px; font-family: var(--mono); font-size: 12px; }
.type-nav a { color: var(--accent); }

.type-header-nav {
  display: flex;
  gap: 4px;
  margin-left: 24px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.04em;
}
.type-header-nav a {
  color: var(--ink-3);
  text-decoration: none;
  padding: 6px 11px;
  border-radius: 5px;
}
.type-header-nav a:hover { color: var(--ink); }
.type-header-nav a.active {
  color: var(--ink);
  background: var(--paper-3);
}
.type-header-inner .type-motto { margin-left: auto; }

.type-main-wide { max-width: 1080px; }
.type-back {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--ink-3);
  letter-spacing: 0.06em;
  text-decoration: none;
  display: inline-block;
  margin-bottom: 20px;
}
.type-back:hover { color: var(--ink); }

.type-toolbar {
  display: flex;
  gap: 12px;
  align-items: center;
  margin: 22px 0 16px;
  flex-wrap: wrap;
}
.type-filter-bar {
  display: flex;
  border: 1px solid var(--line);
  border-radius: 5px;
  overflow: hidden;
  background: var(--paper-2);
}
.type-filter-btn {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 7px 13px;
  border: none;
  border-right: 1px solid var(--line-2);
  background: transparent;
  color: var(--ink-2);
  cursor: pointer;
}
.type-filter-btn:last-child { border-right: none; }
.type-filter-btn.active {
  background: var(--ink);
  color: var(--paper);
}
.type-search {
  flex: 1;
  min-width: 220px;
  padding: 8px 12px;
  border: 1px solid var(--line);
  border-radius: 5px;
  font-family: var(--mono);
  font-size: 12px;
  background: var(--paper-2);
  color: var(--ink);
}
.type-empty {
  text-align: center;
  padding: 30px;
  font-family: var(--mono);
  color: var(--ink-3);
}

.type-table-wrap {
  border: 1px solid var(--line);
  border-radius: 6px;
  overflow: hidden;
  background: var(--paper-2);
}
.type-table-head,
.type-table-row {
  display: grid;
  grid-template-columns: 1.4fr 1fr 0.9fr 0.7fr 110px 0.8fr;
  gap: 14px;
  align-items: center;
  padding: 11px 18px;
}
.type-table-head {
  background: var(--paper-3);
  border-bottom: 1px solid var(--line);
}
.type-table-row {
  text-decoration: none;
  color: inherit;
  border-bottom: 1px solid var(--line-3);
  cursor: pointer;
}
.type-table-row:last-child { border-bottom: none; }
.type-table-row:hover { background: var(--paper-3); }
.type-mono-cell {
  font-family: var(--mono);
  font-size: 12px;
  color: var(--ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.type-mono-cell.muted { font-size: 11px; color: var(--ink-2); }
.type-table-cadence { min-height: 24px; }
.type-state-pill {
  display: inline-flex;
  align-items: center;
  padding: 3px 9px;
  border-radius: 999px;
  border: 1px solid;
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.type-detail-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 30px;
  padding-bottom: 22px;
  border-bottom: 1px solid var(--line);
  flex-wrap: wrap;
}
.type-detail-id-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}
.type-detail-id {
  font-family: var(--mono);
  font-size: 20px;
  letter-spacing: -0.01em;
}
.type-detail-meta {
  display: flex;
  gap: 22px;
  flex-wrap: wrap;
}
.type-meta-field {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.type-verdict-block {
  padding: 26px 0 30px;
  border-bottom: 1px solid var(--line-2);
}
.type-verdict-title {
  font-family: var(--serif);
  font-size: 30px;
  font-weight: 400;
  line-height: 1.08;
  margin: 0;
  max-width: 640px;
}
.type-static-notice {
  margin: 24px 0;
  padding: 16px 20px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--paper-2);
  font-size: 15px;
  color: var(--ink-2);
  line-height: 1.5;
}

.type-replay-figure { margin: 30px 0 0; }
.type-replay-cap {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 12px;
}
.type-replay-pane {
  border: 1px solid var(--line);
  border-radius: 6px 6px 0 0;
  background: var(--paper-2);
  padding: 22px 26px;
  min-height: 168px;
  position: relative;
}
.type-replay-text {
  font-size: 17.5px;
  line-height: 1.62;
  white-space: pre-wrap;
  word-break: break-word;
}
.type-paste-span {
  background: var(--warn-soft);
  box-shadow: inset 0 -1px 0 var(--warn-line);
}
.type-replay-hint {
  position: absolute;
  top: 24px;
  left: 26px;
  font-family: var(--mono);
  font-size: 13px;
  color: var(--ink-4);
}
.type-caret {
  display: inline-block;
  width: 2px;
  height: 1.1em;
  background: var(--accent);
  margin-left: 1px;
  vertical-align: -2px;
  animation: caretblink 1.05s steps(1) infinite;
}
@keyframes caretblink {
  0%, 49% { opacity: 1; }
  50%, 100% { opacity: 0; }
}
.type-cadence-panel {
  border: 1px solid var(--line);
  border-top: none;
  background: var(--paper);
  padding: 14px 16px 10px;
}
.type-cadence-labels {
  display: flex;
  justify-content: space-between;
  margin-bottom: 6px;
}
.type-transport {
  border: 1px solid var(--line);
  border-top: none;
  border-radius: 0 0 6px 6px;
  background: var(--paper-3);
  padding: 10px 14px;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.type-icon-btn {
  width: 32px;
  height: 28px;
  border: 1px solid var(--line);
  border-radius: 4px;
  background: var(--paper-2);
  color: var(--ink-2);
  font-size: 12px;
  cursor: pointer;
}
.type-icon-btn.primary {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}
.type-icon-btn.warn {
  width: auto;
  padding: 0 11px;
  color: var(--warn);
  border-color: var(--warn-line);
}
.type-seek { flex: 1; min-width: 120px; accent-color: var(--accent); }
.type-speed-bar {
  display: flex;
  border: 1px solid var(--line);
  border-radius: 4px;
  overflow: hidden;
}
.type-speed-btn {
  font-family: var(--mono);
  font-size: 11px;
  padding: 5px 9px;
  border: none;
  background: var(--paper-2);
  color: var(--ink-2);
  cursor: pointer;
}
.type-speed-btn.active {
  background: var(--accent);
  color: var(--paper);
}

.type-metrics-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: 6px;
  overflow: hidden;
  margin: 26px 0;
}
@media (max-width: 900px) {
  .type-metrics-grid { grid-template-columns: repeat(3, 1fr); }
  .type-table-head, .type-table-row { grid-template-columns: 1fr 1fr; }
  .type-table-head span:nth-child(n+3),
  .type-table-row > *:nth-child(n+3) { display: none; }
}
.type-metric-cell {
  background: var(--paper-2);
  padding: 16px 18px;
}
.type-metric-cell .type-stat-value span {
  font-size: 11px;
  color: var(--ink-3);
  margin-left: 3px;
}

.type-diff-section, .type-event-section { margin-bottom: 30px; }
.type-diff-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}
.type-link-btn {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--accent);
  background: none;
  border: none;
  cursor: pointer;
}
.type-diff-banner {
  padding: 10px 16px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  border-bottom: 1px solid var(--line);
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.type-diff-banner.ok { background: var(--ok-soft); color: var(--ok); border-color: var(--ok-line); }
.type-diff-banner.bad { background: var(--bad-soft); color: var(--bad); border-color: var(--bad-line); }
.type-paste-note { margin-left: auto; color: var(--warn); font-size: 10.5px; }
.type-diff-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border: 1px solid var(--line);
  border-radius: 6px;
  overflow: hidden;
  background: var(--paper-2);
}
.type-diff-col {
  padding: 16px 20px;
}
.type-diff-col:first-child { border-right: 1px solid var(--line-2); }
.type-diff-unified {
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--paper-2);
  padding: 16px 20px;
}
.type-final-block {
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--paper-2);
  padding: 16px 20px;
  margin-top: 16px;
}
.type-final-block .type-label-sm { display: block; margin-bottom: 8px; }

.type-event-table { border: 1px solid var(--line); border-radius: 6px; overflow: hidden; background: var(--paper-2); }
.type-event-table.open { max-height: 360px; overflow-y: auto; }
.type-event-head,
.type-event-row {
  display: grid;
  grid-template-columns: 60px 90px 1fr 90px 90px;
  gap: 8px;
  padding: 7px 16px;
  font-family: var(--mono);
  font-size: 11.5px;
  border-bottom: 1px solid var(--line-3);
}
.type-event-head {
  background: var(--paper-3);
  position: sticky;
  top: 0;
}
.type-event-row.gap { text-align: center; color: var(--ink-4); }
