.typing-main{--fg-p:var(--violet-500);--fg-r:var(--sky-500);--fg-m:var(--mint-500);--fg-i:var(--coral-500);--fg-t:var(--sun-500)}.tp-sec{margin-top:30px}.tp-sec>h3{font-family:var(--font-display);align-items:center;gap:10px;margin:0 0 12px;font-size:18px;font-weight:600;display:flex}.tp-sec>h3 .lbl{font-weight:700}.tp-grid{grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px;display:grid}.tp-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);flex-direction:column;gap:8px;padding:18px 20px;text-decoration:none;transition:transform .16s,box-shadow .16s,border-color .16s;display:flex}.tp-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary);transform:translateY(-3px)}.tp-card h4{font-family:var(--font-display);color:var(--text);margin:0;font-size:17px;font-weight:600}.tp-card .desc{color:var(--text-muted);font-size:13px;line-height:1.5}.tp-card .meta{font-family:var(--font-mono);color:var(--text-subtle);letter-spacing:.04em;margin-top:auto;font-size:11px}.tp-statbar{flex-wrap:wrap;align-items:center;gap:10px;margin:18px 0 14px;display:flex}.tp-stat{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-md);flex-direction:column;gap:2px;min-width:86px;padding:8px 14px;display:flex}.tp-stat .num{font-family:var(--font-mono);color:var(--text);font-size:18px;font-weight:700}.tp-stat .num small{color:var(--text-subtle);margin-left:2px;font-size:11px;font-weight:600}.tp-stat .lbl{font-size:11px}.tp-statbar .spacer{margin-left:auto}.tp-chip{font-family:var(--font-body);cursor:pointer;background:var(--surface);border:1.5px solid var(--border);color:var(--text-muted);border-radius:999px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:700;display:inline-flex}.tp-chip.is-on{background:var(--primary-soft);border-color:var(--primary);color:var(--primary)}.tp-text{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-sm);font-family:var(--font-mono);letter-spacing:.02em;max-height:280px;padding:22px 26px;font-size:clamp(17px,2.2vw,22px);line-height:2;overflow-y:auto}.tp-ch{white-space:pre-wrap;border-radius:4px;transition:background .1s,color .1s}.tp-ch--enter{color:var(--text-subtle);font-size:.75em}.tp-ch.is-done{color:var(--mint-600)}.tp-ch.is-fixed{color:var(--sun-600,#b07c00)}.tp-ch.is-active{background:var(--primary-soft);color:var(--primary);outline:2px solid var(--primary);outline-offset:1px}.tp-ch.is-active.is-err{background:var(--danger-soft);color:var(--danger);outline-color:var(--danger)}.py-text{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-sm);flex-wrap:wrap;align-items:flex-end;gap:6px 2px;max-height:320px;padding:20px 24px;display:flex;overflow-y:auto}.py-break{flex-basis:100%;height:6px}.py-cell{border-radius:8px;flex-direction:column;align-items:center;gap:1px;padding:3px 4px 4px;transition:background .12s;display:flex}.py-cell .py{font-family:var(--font-mono);color:var(--text-subtle);white-space:pre;min-height:16px;font-size:12px;line-height:1.3}.py-cell .py b{color:var(--primary);font-weight:700}.py-cell .hz{font-family:var(--font-display);color:var(--text);font-size:clamp(22px,2.6vw,27px);line-height:1.35}.py-cell--punc .hz{color:var(--text-subtle)}.py-cell.is-done .hz{color:var(--mint-600)}.py-cell.is-done .py{color:var(--mint-600);opacity:.7}.py-cell.is-fixed .hz{color:var(--sun-600,#b07c00)}.py-cell.is-active{background:var(--primary-soft);outline:2px solid var(--primary)}.py-cell.is-active .hz{color:var(--primary)}.py-cell.is-active.is-err{background:var(--danger-soft);outline-color:var(--danger);animation:.22s tp-shake}.py-cell.is-active.is-err .hz{color:var(--danger)}@keyframes tp-shake{25%{transform:translate(-3px)}75%{transform:translate(3px)}}.kb{-webkit-user-select:none;user-select:none;flex-direction:column;gap:7px;margin-top:18px;display:flex}.kb-row{gap:7px;display:flex}.kb-row--space{justify-content:center}.kb-key{background:var(--surface);border:1.5px solid var(--border);min-width:0;height:52px;font-family:var(--font-mono);color:var(--text);border-bottom-width:4px;border-radius:9px;flex-direction:column;flex:1 1 0;justify-content:center;align-items:center;gap:1px;display:flex;position:relative}.kb-row--space .kb-key{flex:0 0 52%}.kb-key__shift{color:var(--text-subtle);font-size:10px;line-height:1}.kb-key__base{text-transform:uppercase;font-size:15px;font-weight:700;line-height:1}.kb-key--fn .kb-key__base{color:var(--text-subtle);text-transform:none;font-size:11px}.kb-key[data-finger=lp],.kb-key[data-finger=rp]{border-bottom-color:color-mix(in srgb, var(--fg-p) 65%, var(--border))}.kb-key[data-finger=lr],.kb-key[data-finger=rr]{border-bottom-color:color-mix(in srgb, var(--fg-r) 65%, var(--border))}.kb-key[data-finger=lm],.kb-key[data-finger=rm]{border-bottom-color:color-mix(in srgb, var(--fg-m) 65%, var(--border))}.kb-key[data-finger=li],.kb-key[data-finger=ri]{border-bottom-color:color-mix(in srgb, var(--fg-i) 65%, var(--border))}.kb-key[data-finger=th]{border-bottom-color:color-mix(in srgb, var(--fg-t) 65%, var(--border))}.kb-key.is-target{background:var(--primary-soft);border-color:var(--primary);color:var(--primary);animation:.9s infinite kb-pulse}.kb-key.is-target .kb-key__base,.kb-key.is-target .kb-key__shift{color:var(--primary)}@keyframes kb-pulse{50%{box-shadow:0 0 0 4px color-mix(in srgb, var(--primary) 22%, transparent)}}.kb-legend{color:var(--text-muted);flex-wrap:wrap;justify-content:center;gap:14px;margin-top:10px;font-size:12px;display:flex}.kb-legend i{border-radius:3px;width:10px;height:10px;margin-right:4px;display:inline-block}.tp-fold{margin-top:26px}.tp-fold>summary{cursor:pointer;font-family:var(--font-body);color:var(--text-muted);-webkit-user-select:none;user-select:none;font-size:14px;font-weight:700}.tp-summary{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-sm);text-align:center;margin-top:18px;padding:30px}.tp-summary h3{font-family:var(--font-display);margin:0 0 6px;font-size:26px;font-weight:600}.tp-summary .sub{color:var(--text-muted);margin:0 0 22px;font-size:14px}.tp-summary__grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin-bottom:24px;display:grid}.tp-summary__cell{background:var(--surface-2);border-radius:var(--r-md);padding:14px 10px}.tp-summary__cell .num{font-family:var(--font-mono);color:var(--primary);font-size:24px;font-weight:700}.tp-summary__cell .num small{color:var(--text-subtle);margin-left:2px;font-size:12px}.tp-summary__cell .lbl{margin-top:4px}@media (max-width:720px){.tp-text{padding:16px 14px;font-size:16px}.py-text{padding:14px 12px}.kb-key{height:40px}.kb{gap:5px}.kb-row{gap:4px}.kb-key__shift{display:none}}
