:root{--bg:#fff;--surface:#f8f8f8;--surface-alt:#eee;--text:#1a1a1a;--text-muted:#666;--accent:#d97706;--accent-dim:#d9770644;--accent-glow:#d9770622;--success:#16a34a;--success-dim:#16a34a44;--error:#dc2626;--error-dim:#dc262644;--warning:#ea580c;--border:#d4d4d4;--font-mono:"JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--transition-fast:0s;--transition-normal:0s}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-mono);background:var(--bg);color:var(--text);min-height:100vh}#app{flex-direction:column;gap:1rem;max-width:800px;min-height:100vh;margin:0 auto;padding:1.5rem;display:flex}#app-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding-bottom:.75rem;display:flex}#app-header h1{letter-spacing:.05em;color:var(--accent);font-size:1rem;font-weight:600}#mode-indicator{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;transition:color var(--transition-normal);font-size:.75rem}#prompt-area{background:var(--surface);border:1px solid var(--border);transition:border-color var(--transition-normal), opacity var(--transition-normal);border-radius:6px;padding:1rem 1.25rem}#prompt-area.transitioning{opacity:0}#prompt-intent{transition:color var(--transition-normal);margin-bottom:.5rem;font-size:.95rem;font-weight:500}#prompt-explanation{color:var(--text-muted);font-size:.8rem;line-height:1.5}.prompt-example code{background:var(--surface-alt);color:var(--accent);border-radius:3px;padding:.15em .4em}#editor-area{border:1px solid var(--border);min-height:200px;transition:border-color var(--transition-normal);border-radius:6px;flex:1;overflow:hidden}#editor{height:100%}.cm-editor{height:100%;font-size:.95rem}.cm-editor .cm-scroller{font-family:var(--font-mono)}.cm-editor.cm-focused{outline:none}.cm-correct{-webkit-text-decoration:underline 2px var(--accent);text-decoration:underline 2px var(--accent);text-underline-offset:3px}.cm-incorrect{-webkit-text-decoration:underline 2px var(--error);text-decoration:underline 2px var(--error);text-underline-offset:3px}.cm-incomplete{-webkit-text-decoration:underline 2px var(--text-muted);text-decoration:underline 2px var(--text-muted);text-underline-offset:3px;text-decoration-style:dotted}#feedback-area{justify-content:space-between;align-items:center;gap:1rem;display:flex}#progress-rail{flex:1;gap:4px;display:flex}.rail-segment{flex-direction:column;flex:1;align-items:center;gap:4px;display:flex}.rail-segment:before{content:"";background:var(--border);width:100%;height:6px;transition:background var(--transition-fast), box-shadow var(--transition-normal);border-radius:3px;display:block}.rail-segment.correct:before{background:var(--success)}.rail-segment.incorrect:before{background:var(--error)}.rail-segment.incomplete:before{background:var(--text-muted)}.rail-label{color:var(--text-muted);text-transform:lowercase;white-space:nowrap;transition:color var(--transition-fast);font-size:.6rem}.rail-segment.correct .rail-label{color:var(--success)}.rail-segment.incorrect .rail-label{color:var(--error)}#prompt-intent.complete{color:var(--accent)}#editor-area.complete{border-color:var(--accent)}.rail-segment.complete-flash:before{background:var(--accent);box-shadow:0 0 8px var(--accent-glow)}@keyframes rail-pulse{0%{box-shadow:0 0 0px var(--accent-glow);transform:scaleY(1)}50%{box-shadow:0 0 12px var(--accent);transform:scaleY(1.5)}to{box-shadow:0 0 8px var(--accent-glow);transform:scaleY(1)}}.drill-fade-out{animation:fadeOut var(--transition-normal) forwards}.drill-fade-in{animation:fadeIn var(--transition-normal) forwards}@keyframes fadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-4px)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.hint-info{color:var(--text-muted)}.hint-warning{color:var(--warning)}.hint-error{color:var(--error)}.theme-goal{color:var(--text-muted);font-style:italic}.cm-scaffold-static{color:var(--text-muted)}.cm-scaffold-blank{border-bottom:2px dashed var(--accent-dim)}#timer{color:var(--text-muted);font-variant-numeric:tabular-nums;transition:color var(--transition-fast);font-size:.8rem}#timer.complete{color:var(--accent)}#status-bar{border-top:1px solid var(--border);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;gap:1.5rem;padding-top:.75rem;font-size:.7rem;display:flex}#shortcut-hint{color:var(--text-muted);opacity:.6;text-align:right;font-size:.65rem}
