[data-v-ef41de5e]:root{--color-bg: #ffffff;--color-text: #374151;--color-text-strong: #111827;--color-text-muted: #6b7280;--color-border: #e5e7eb;--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--layout-max-width: 1200px;--font-family: -apple-system, BlinkMacSystemFont, Segoe UI, Microsoft YaHei, sans-serif}.dev-tool-page__header[data-v-ef41de5e]{margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #e5e7eb}.dev-tool-page__header h1[data-v-ef41de5e]{margin:0 0 8px;font-size:24px;font-weight:700;color:#111827;letter-spacing:-.01em;line-height:1.3}.dev-tool-page__subtitle[data-v-ef41de5e]{margin:0 0 16px;font-size:14px;color:#6b7280;line-height:1.5}.dev-tool-page__actions[data-v-ef41de5e]{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}.dev-tool-page__mode[data-v-ef41de5e],.dev-tool-page__buttons[data-v-ef41de5e]{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.dev-tool-page button[data-v-ef41de5e]{padding:8px 14px;min-height:36px;background:#fafbfc;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;font-weight:500;color:#374151;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease,transform .12s ease}.dev-tool-page button[data-v-ef41de5e]:hover{border-color:#2563eb;color:#2563eb}.dev-tool-page button[data-v-ef41de5e]:focus-visible{outline:2px solid #2563eb;outline-offset:2px}.dev-tool-page button[data-v-ef41de5e]:active{transform:scale(.97)}.dev-tool-page button[data-v-ef41de5e]:disabled{opacity:.45;cursor:not-allowed;transform:none}.dev-tool-page button.active[data-v-ef41de5e]{background:#2563eb;border-color:#2563eb;color:#fff}.dev-tool-page__primary[data-v-ef41de5e]{background:#2563eb!important;border-color:#2563eb!important;color:#fff!important;font-weight:600!important}.dev-tool-page__primary[data-v-ef41de5e]:hover{background:#1d4ed8!important;border-color:#1d4ed8!important;color:#fff!important}.dev-tool-page__link[data-v-ef41de5e]{padding:0;min-height:unset;border:none;background:none;color:#2563eb;font-size:13px;font-weight:400}.dev-tool-page__link[data-v-ef41de5e]:hover{text-decoration:underline;color:#1d4ed8}.dev-tool-page__link[data-v-ef41de5e]:focus-visible{outline:2px solid #2563eb;outline-offset:2px}.dev-tool-page__main[data-v-ef41de5e]{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:32px}@media(max-width:768px){.dev-tool-page__main[data-v-ef41de5e]{grid-template-columns:1fr}}.dev-tool-page__panel[data-v-ef41de5e]{display:flex;flex-direction:column;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden;background:#fafbfc}.dev-tool-page__panel-head[data-v-ef41de5e]{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f6f8fa;border-bottom:1px solid #e5e7eb;font-weight:600;font-size:13px;color:#111827}.dev-tool-page__editor[data-v-ef41de5e]{width:100%;min-height:360px;padding:16px;border:none;resize:vertical;outline:none;font-family:Fira Code,Cascadia Code,Consolas,monospace;font-size:14px;line-height:1.6;color:#111827;background:#fff}.dev-tool-page__editor[data-v-ef41de5e]:focus-visible{box-shadow:inset 0 0 0 2px #2563eb}.dev-tool-page__editor--readonly[data-v-ef41de5e]{background:#fefdf7;cursor:default}.dev-tool-page__error[data-v-ef41de5e]{margin:0;padding:12px 16px;background:#fef2f2;color:#dc2626;font-size:13px;font-family:monospace;border-top:1px solid #fee2e2}.dev-tool-page__tips[data-v-ef41de5e]{padding:16px 24px;border:1px solid #e5e7eb;border-radius:10px;background:#f8fafb}.dev-tool-page__tips h2[data-v-ef41de5e]{margin:0 0 8px;font-size:15px;font-weight:600;color:#111827}.dev-tool-page__tips p[data-v-ef41de5e]{margin:0;font-size:14px;line-height:1.65;color:#6b7280}.dev-tool-page__tips p strong[data-v-ef41de5e]{color:#374151;font-weight:600}.typing-speed-test__header[data-v-ef41de5e]{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #e5e7eb}.typing-speed-test__header h1[data-v-ef41de5e]{margin:0 0 6px;font-size:22px;font-weight:600;color:#111827}.typing-speed-test__subtitle[data-v-ef41de5e]{margin:0;font-size:14px;color:#6b7280}.typing-speed-test__toolbar[data-v-ef41de5e]{display:flex;flex-wrap:wrap;align-items:flex-start;gap:12px;margin-top:16px}.typing-speed-test__toolbar-group[data-v-ef41de5e]{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.typing-speed-test__select[data-v-ef41de5e]{padding:8px 12px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;background:#fff;color:#374151;cursor:pointer}.typing-speed-test__select[data-v-ef41de5e]:focus{outline:none;border-color:#2563eb}.typing-speed-test__custom-area[data-v-ef41de5e]{margin-top:16px}.typing-speed-test__custom-textarea[data-v-ef41de5e]{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:10px;font-size:14px;font-family:Fira Code,Consolas,monospace;outline:none;transition:border-color .2s;background:#fff;color:#111827;resize:vertical}.typing-speed-test__custom-textarea[data-v-ef41de5e]:focus{border-color:#2563eb}.typing-speed-test__custom-textarea[data-v-ef41de5e]::placeholder{color:#6b7280}.typing-speed-test__custom-hint[data-v-ef41de5e]{margin:8px 0 0;font-size:13px;color:#6b7280}.typing-speed-test__stats[data-v-ef41de5e]{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:24px}.typing-speed-test__stat-card[data-v-ef41de5e]{padding:16px;border-radius:12px;background:#eff6ff;border:1px solid #2563eb;text-align:center}.typing-speed-test__stat-value[data-v-ef41de5e]{font-size:28px;font-weight:700;color:#2563eb;margin-bottom:4px}.typing-speed-test__stat-label[data-v-ef41de5e]{font-size:13px;color:#6b7280}.typing-speed-test__live-stats[data-v-ef41de5e]{display:flex;gap:24px;padding:12px 16px;margin-bottom:16px;border-radius:8px;background:#f0fdf4;border:1px solid #bbf7d0;font-size:14px;color:#166534;font-weight:500}.typing-speed-test__progress[data-v-ef41de5e]{display:flex;align-items:center;gap:12px;margin-bottom:16px}.typing-speed-test__progress-bar[data-v-ef41de5e]{flex:1;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.typing-speed-test__progress-fill[data-v-ef41de5e]{height:100%;background:#2563eb;border-radius:4px;transition:width .15s}.typing-speed-test__progress-text[data-v-ef41de5e]{font-size:13px;color:#6b7280;white-space:nowrap}.typing-speed-test__text-display[data-v-ef41de5e]{margin-bottom:20px;padding:20px;border-radius:12px;background:#f8fafc;border:1px solid #e5e7eb;min-height:120px;max-height:300px;overflow-y:auto}.typing-speed-test__text-content[data-v-ef41de5e]{font-size:18px;line-height:1.8;font-family:Fira Code,Consolas,monospace;color:#6b7280;word-break:break-all;white-space:pre-wrap}.typing-speed-test__text-content span[data-v-ef41de5e]{padding:2px 1px;border-radius:3px;transition:background .15s,color .15s}.typing-speed-test__text-content span.is-correct[data-v-ef41de5e]{color:#16a34a;background:#dcfce7}.typing-speed-test__text-content span.is-incorrect[data-v-ef41de5e]{color:#dc2626;background:#fee2e2}.typing-speed-test__text-content span.is-current[data-v-ef41de5e]{background:#eff6ff;border-bottom:3px solid #2563eb;animation:blink-ef41de5e 1s infinite}.typing-speed-test__input-area[data-v-ef41de5e]{margin-bottom:24px}.typing-speed-test__input[data-v-ef41de5e]{width:100%;padding:14px 16px;border:2px solid #e5e7eb;border-radius:10px;font-size:16px;font-family:Fira Code,Consolas,monospace;outline:none;transition:border-color .2s;background:#fff;color:#111827}.typing-speed-test__input[data-v-ef41de5e]:focus{border-color:#2563eb}.typing-speed-test__input[data-v-ef41de5e]::placeholder{color:#6b7280}.typing-speed-test__placeholder[data-v-ef41de5e]{text-align:center;padding:48px 24px;color:#6b7280;font-size:16px}.typing-speed-test__placeholder p[data-v-ef41de5e]:first-child{font-size:18px;font-weight:500;margin-bottom:8px}.typing-speed-test__hint[data-v-ef41de5e]{font-size:14px;color:#6b7280}@keyframes blink-ef41de5e{0%,to{opacity:1}50%{opacity:.3}}
