:root{font-family:Inter,system-ui,sans-serif;line-height:1.5;font-weight:400;color:#0f172a;background-color:#f8fafc;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:#f1f5f9}h1,h2,h3,p{margin:0}.app{max-width:1200px;margin:0 auto;padding:2.5rem 1.5rem 3rem;display:flex;flex-direction:column;gap:1.5rem}.app-header{display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;align-items:center}.eyebrow{text-transform:uppercase;font-size:.75rem;letter-spacing:.12em;color:#6b7280;margin:0 0 .4rem}.subtitle{margin:.5rem 0 0;color:#6b7280;max-width:40rem}.controls{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.level-select{display:flex;flex-direction:column;gap:.35rem;font-size:.85rem;color:#374151}.level-select select{padding:.45rem .75rem;border-radius:.6rem;border:1px solid #d1d5db;background:#fff;font-size:.95rem}.content-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr);gap:1.5rem}.card{background:#fff;border-radius:1rem;padding:1.5rem;box-shadow:0 10px 25px #0f172a0f;border:1px solid #eef2f7}.typing-card{display:flex;flex-direction:column;gap:1rem}.target-text{font-size:1.4rem;line-height:1.6;padding:1rem;border-radius:.8rem;background:#f8fafc;border:1px solid #e2e8f0;min-height:5.5rem}.target-char{padding:.05rem .1rem;border-radius:.25rem}.target-char.correct{background:#dcfce7;color:#166534}.target-char.incorrect{background:#fee2e2;color:#b91c1c}.input-area{width:100%;border-radius:.8rem;border:1px solid #d1d5db;padding:.85rem;font-size:1rem;resize:vertical;min-height:5.5rem}.status-bar{display:flex;flex-wrap:wrap;gap:.5rem}.badge{background:#f1f5f9;color:#334155;font-size:.85rem;padding:.25rem .6rem;border-radius:999px}.actions{display:flex;gap:.75rem;flex-wrap:wrap}.metrics{margin-bottom:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.metrics-section{display:flex;flex-direction:column;gap:.75rem}.metrics-section h3{font-size:.8rem;color:#64748b;margin:0;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #e2e8f0;padding-bottom:.35rem}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem}.metric-label{color:#6b7280;font-size:.8rem;margin:0 0 .2rem}.metric-value{font-size:1.2rem;font-weight:600;margin:0}.help-panel{display:flex;flex-direction:column;gap:.8rem}.help-header{display:flex;justify-content:space-between;align-items:center}.help-block{background:#f8fafc;border-radius:.8rem;padding:.8rem}.help-label{margin:0 0 .35rem;font-weight:600;color:#334155}.pill{font-size:.75rem;background:#e0f2fe;color:#0369a1;padding:.2rem .55rem;border-radius:999px}.callout{border-radius:.75rem;padding:.75rem 1rem;font-size:.9rem}.callout.warning{background:#fef9c3;color:#854d0e;border:1px solid #fde68a}.callout.error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.success{color:#15803d;font-weight:600}.empty-state{color:#6b7280;font-style:italic}button{border-radius:.6rem;border:1px solid transparent;padding:.6rem 1rem;font-size:.95rem;font-weight:600;background:#2563eb;color:#fff;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}button:disabled{cursor:not-allowed;opacity:.6;box-shadow:none}button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #2563eb33}button.secondary{background:#0f172a}button.ghost{background:#fff;color:#0f172a;border:1px solid #cbd5f5}@media(max-width:960px){.content-grid{grid-template-columns:1fr}}.modal-overlay{position:fixed;inset:0;background:#0f172ab3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1.5rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{width:100%;max-width:400px;animation:modalIn .3s cubic-bezier(.16,1,.3,1)}@keyframes modalIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}
