.typing-tutor-container{--tutor-bg:#1e1e1e;--tutor-text:#e0e0e0;--tutor-muted:#a0a0a0;--tutor-dimmed:#606060;--tutor-accent:#7d9dcc;--tutor-secondary:#7c6f9f;--tutor-success:#99d1a0;--tutor-error:#f38ba8;--tutor-warning:#c9a84c;--tutor-heading:#d9c9a0;--tutor-neutral-bg:#282828;--tutor-dark-bg:#3c3836;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:var(--tutor-text);display:flex;flex-direction:column;align-items:center;padding:2rem}.typing-tutor-header{text-align:center;margin-bottom:2rem}.typing-tutor-header h1{color:var(--tutor-heading);font-size:2.5rem;margin-bottom:1rem}.tab-bar{display:flex;gap:.25rem;justify-content:center;border-bottom:1px solid var(--tutor-dimmed);padding-bottom:0}.tab-btn{padding:.6rem 1.25rem;font-size:1rem;border:none;border-bottom:2px solid transparent;background:transparent;color:var(--tutor-muted);cursor:pointer;transition:all .2s ease;margin-bottom:-1px}.tab-btn:hover{color:var(--tutor-text)}.tab-btn.active{color:var(--tutor-accent);border-bottom-color:var(--tutor-accent)}.start-content{display:flex;flex-direction:column;gap:1.25rem;max-width:500px;margin:2rem auto;padding:2rem;background:var(--tutor-bg);border-radius:12px;text-align:center}.start-mode h3{color:var(--tutor-heading);font-size:1.1rem;margin-bottom:.3rem}.start-mode p{color:var(--tutor-muted);font-size:.95rem;margin:0;line-height:1.4}.keyboard-toggle{display:flex;gap:1.5rem;justify-content:center;padding:.75rem 1rem;margin-bottom:.5rem;flex-wrap:wrap;background:linear-gradient(to bottom,rgba(0,0,0,.4),transparent);border-radius:8px 8px 0 0}.toggle-group{display:flex;align-items:center;gap:.35rem}.toggle-label{color:var(--tutor-muted);font-size:.75rem}.keyboard-btn{padding:.3rem .7rem;font-size:.75rem;border:1px solid var(--tutor-secondary);background:transparent;color:var(--tutor-secondary);border-radius:6px;cursor:pointer;transition:all .2s ease}.keyboard-btn:hover,.keyboard-btn.active{background:var(--tutor-secondary);color:var(--tutor-neutral-bg)}.show-keyboard-btn{position:fixed;bottom:.75rem;left:50%;transform:translate(-50%);z-index:100;padding:.4rem 1rem;font-size:.8rem;border:1px solid var(--tutor-secondary);background:var(--tutor-bg);color:var(--tutor-secondary);border-radius:6px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0006}.show-keyboard-btn:hover{background:var(--tutor-secondary);color:var(--tutor-neutral-bg)}.stats-container{display:flex;gap:3rem;margin-bottom:2rem}.stat{text-align:center}.stat-value{font-size:2.5rem;font-weight:700;color:var(--tutor-secondary)}.stat-label{font-size:.9rem;color:var(--tutor-muted);text-transform:uppercase;letter-spacing:1px}.main-container{width:100%;max-width:900px;padding-bottom:320px}.lesson-selector{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:2rem;margin-bottom:1rem;justify-content:center}.letter-mastery{display:flex;flex-wrap:wrap;gap:.35rem;align-items:center;justify-content:center;margin-bottom:1.5rem}.letter-indicator{width:28px;height:28px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-family:Consolas,Monaco,monospace;font-size:.8rem;font-weight:700;transition:all .3s ease;text-transform:uppercase}.letter-indicator.locked{background:var(--tutor-dark-bg);color:var(--tutor-dimmed)}.letter-indicator.new{background:#f38ba833;color:var(--tutor-error);border:1px solid var(--tutor-error)}.letter-indicator.learning{background:#d9c9a033;color:var(--tutor-heading);border:1px solid var(--tutor-heading)}.letter-indicator.confident{background:#99d1a033;color:var(--tutor-success);border:1px solid var(--tutor-success)}.mastery-reset-btn{height:28px;padding:0 6px;font-size:.7rem;border:1px solid var(--tutor-dimmed);background:var(--tutor-dark-bg);color:var(--tutor-dimmed);border-radius:4px;cursor:pointer;transition:all .2s ease;margin-top:.625rem}.mastery-reset-btn:hover{border-color:var(--tutor-error);color:var(--tutor-error)}.unlock-notification{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-top:1rem;animation:unlock-reveal .6s ease-out}.unlock-letter{width:48px;height:48px;background:#99d1a033;border:2px solid var(--tutor-success);border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:Consolas,Monaco,monospace;font-size:1.5rem;font-weight:700;color:var(--tutor-success);box-shadow:0 0 20px #99d1a04d}.unlock-text{color:var(--tutor-success);font-size:.9rem;font-weight:700;text-transform:uppercase;letter-spacing:1px}@keyframes unlock-reveal{0%{opacity:0;transform:scale(.5)}50%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.challenge-notification{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-top:1rem;animation:unlock-reveal .6s ease-out}.challenge-letter{width:48px;height:48px;background:#d9c9a033;border:2px solid var(--tutor-heading);border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:Consolas,Monaco,monospace;font-size:1.5rem;font-weight:700;color:var(--tutor-heading);box-shadow:0 0 20px #d9c9a04d}.challenge-text{color:var(--tutor-heading);font-size:.9rem;font-weight:700;text-transform:uppercase;letter-spacing:1px}.challenge-retry{color:var(--tutor-error);font-size:.9rem;font-weight:700;text-transform:uppercase;letter-spacing:1px}.notes-controls{display:none;flex-direction:column;align-items:center;gap:1rem;margin-bottom:1.5rem}.notes-controls.visible{display:flex}.category-select{padding:.75rem 2.5rem .75rem 1rem;font-size:1rem;border:2px solid var(--tutor-secondary);background:var(--tutor-bg);color:var(--tutor-text);border-radius:8px;min-width:200px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23a0a0a0' stroke-width='2' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center}.category-select:focus{outline:none;border-color:var(--tutor-accent)}.notes-list{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;max-width:100%}.note-btn{padding:.5rem 1rem;font-size:.9rem;border:1px solid var(--tutor-secondary);background:transparent;color:var(--tutor-text);border-radius:6px;cursor:pointer;transition:all .2s ease;position:relative;max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.note-btn:hover,.note-btn.active{background:var(--tutor-secondary);color:var(--tutor-neutral-bg)}.typing-area{background:var(--tutor-bg);border-radius:12px;padding:2rem;margin-bottom:1.5rem;min-height:200px;position:relative}.typing-text{font-family:Consolas,Monaco,monospace;font-size:1.4rem;line-height:2;word-wrap:break-word}.word{white-space:nowrap;display:inline}.char{transition:color .1s ease}.char.current{background:var(--tutor-heading);color:var(--tutor-neutral-bg);border-radius:2px}.char.correct{color:var(--tutor-text)}.char.incorrect{color:var(--tutor-error);text-decoration:underline}.char.pending{color:var(--syntax-color, #808080)}.char.wildcard.pending,.char.wildcard.correct{color:var(--tutor-success)}.char.code-block{background:#1e1e1e99;border-radius:1px}.char.code-block.pending{color:color-mix(in srgb,var(--syntax-color, #808080) 40%,transparent)}.char.code-block.correct{color:var(--syntax-color, var(--tutor-success))}.char.code-block.current{background:var(--tutor-heading)}.progress-bar{height:4px;background:#404040;border-radius:2px;margin-bottom:1rem;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--tutor-secondary),var(--tutor-accent));border-radius:2px;transition:width .3s ease}.infinite-progress{display:flex;gap:1.5rem;margin-bottom:1rem}.infinite-bar-group{flex:1;display:flex;flex-direction:column}.infinite-bar-label{display:flex;justify-content:space-between;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:gray;margin-bottom:.3rem}.infinite-bar-label span:last-child{font-family:JetBrains Mono,monospace;color:var(--tutor-secondary)}.infinite-bar-group .progress-bar{margin-bottom:0}@keyframes bar-glow-green{0%{box-shadow:0 0 8px 2px #99d1a0cc}to{box-shadow:0 0 #99d1a000}}@keyframes bar-glow-red{0%{box-shadow:0 0 8px 2px #f38ba8cc}to{box-shadow:0 0 #f38ba800}}.bar-flash-green{animation:bar-glow-green .5s ease-out}.bar-flash-red{animation:bar-glow-red .5s ease-out}.message{text-align:center;padding:1rem;color:var(--tutor-muted);font-style:italic}.results{display:none;background:var(--tutor-bg);border-radius:12px;padding:2rem;text-align:center;margin-top:3rem}.results.visible{display:block}.results h2{color:var(--tutor-heading);margin-bottom:1.5rem}.results-stats{display:flex;justify-content:center;gap:3rem;margin-bottom:1.5rem}.result-stat{text-align:center}.result-value{font-size:3rem;font-weight:700;color:var(--tutor-success)}.result-label{color:var(--tutor-muted);text-transform:uppercase;letter-spacing:1px}.best-score{color:var(--tutor-heading);margin-bottom:1.5rem}.next-level{background:#00000040;border-left:3px solid var(--tutor-accent);border-radius:6px;padding:.75rem 1rem;margin-bottom:1.5rem;text-align:left}.next-level:empty{display:none}.next-level .next-level-label{text-transform:uppercase;letter-spacing:1px;font-size:.7rem;color:var(--tutor-accent);margin-bottom:.4rem;font-weight:600}.next-level .next-level-content{color:var(--tutor-heading);font-size:.85rem;line-height:1.4}.next-level .next-level-progress{display:flex;align-items:center;gap:.6rem;margin-top:.5rem}.next-level .next-level-bar{flex:1;height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.next-level .next-level-bar-fill{height:100%;background:var(--tutor-accent);border-radius:2px;transition:width .3s ease}.next-level .next-level-bar-label{font-size:.75rem;color:var(--tutor-muted);white-space:nowrap}.next-level .next-level-keys{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.5rem}.next-level .next-level-key{display:inline-flex;align-items:center;justify-content:center;width:1.6rem;height:1.6rem;font-size:.75rem;font-weight:600;text-transform:uppercase;border-radius:4px;background:#ffffff0f;border:1px solid rgba(255,255,255,.15);color:var(--tutor-text)}.next-level .next-level-key.needs-work{border-color:var(--tutor-warning);color:var(--tutor-heading)}.result-actions{display:flex;gap:1rem;justify-content:center}.action-btn{padding:.75rem 1.5rem;font-size:1rem;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.action-btn.primary{background:var(--tutor-accent);color:var(--tutor-neutral-bg)}.action-btn.secondary{background:transparent;border:2px solid var(--tutor-secondary);color:var(--tutor-secondary)}.action-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.done-container{position:fixed;bottom:1rem;right:1rem;z-index:101}.done-btn{padding:.75rem 1.5rem;font-size:1rem;border:2px solid var(--tutor-secondary);background:var(--tutor-bg);color:var(--tutor-secondary);border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #0006}.done-btn:hover{background:var(--tutor-secondary);color:var(--tutor-neutral-bg)}.missed-keys{margin:1.5rem 0;padding:1rem;background:#252525;border-radius:8px}.missed-keys-label{font-size:.85rem;color:var(--tutor-muted);margin-bottom:1rem;text-transform:uppercase;letter-spacing:1px}.missed-keys-table{margin:0 auto;border-collapse:separate;border-spacing:0 .35rem}.missed-keys-table td{padding:.25rem .5rem;font-size:.85rem;color:var(--tutor-muted);vertical-align:middle}.missed-keys-table td:first-child{width:40px;padding-right:.75rem;text-align:center}.missed-keys-table td:last-child{text-align:right;white-space:nowrap}.missed-key-cap{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 6px;background:var(--tutor-dark-bg);border:1px solid var(--tutor-error);border-radius:4px;font-family:Consolas,Monaco,monospace;font-size:.8rem;font-weight:700;color:var(--tutor-error)}.cli-controls{display:none;flex-direction:column;align-items:center;gap:1rem;margin-bottom:1.5rem}.cli-controls.visible{display:flex}.cli-tier-selector{display:flex;align-items:center;gap:.5rem}.cli-tier-btn{width:36px;height:36px;border:2px solid var(--tutor-secondary);background:transparent;color:var(--tutor-secondary);border-radius:8px;cursor:pointer;font-size:1rem;font-weight:700;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.cli-tier-btn:hover,.cli-tier-btn.active{background:var(--tutor-secondary);color:var(--tutor-neutral-bg)}.cli-tier-description{color:var(--tutor-muted);font-size:.9rem;font-style:italic}.cli-round-settings{display:flex;gap:1.5rem;align-items:center;flex-wrap:wrap;justify-content:center}.cli-setting{display:flex;align-items:center;gap:.5rem;accent-color:var(--tutor-secondary)}.cli-number-input{width:60px;padding:.4rem .5rem;font-size:1rem;border:2px solid var(--tutor-secondary);background:var(--tutor-bg);color:var(--tutor-text);border-radius:8px;text-align:center}.cli-feedback{width:100%;max-width:900px;display:flex;flex-direction:column;gap:.5rem}.cli-feedback-card{background:var(--tutor-bg);border-left:3px solid var(--tutor-success);border-radius:0 8px 8px 0;padding:.75rem 1rem;animation:cli-fade-in .3s ease-out}@keyframes cli-fade-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.cli-feedback-command{font-family:Consolas,Monaco,monospace;color:var(--tutor-heading);font-size:.95rem;margin-bottom:.25rem}.cli-prompt-symbol{color:var(--tutor-success);margin-right:.5rem}.cli-feedback-description{color:silver;font-size:.85rem;margin-bottom:.25rem}.cli-feedback-stats{color:var(--tutor-secondary);font-size:.8rem}.cli-mode-toggle{display:flex;gap:.5rem;justify-content:center;margin-bottom:.5rem}.cli-mode-btn{padding:.4rem 1rem;font-size:.85rem;border:2px solid var(--tutor-secondary);background:transparent;color:var(--tutor-secondary);border-radius:8px;cursor:pointer;transition:all .2s ease}.cli-mode-btn:hover,.cli-mode-btn.active{background:var(--tutor-secondary);color:var(--tutor-neutral-bg)}.cli-round-settings.infinite-mode .rounds-only{display:none}@keyframes flash-glow-green{0%{box-shadow:0 0 15px 3px #99d1a0b3}}@keyframes flash-glow-red{0%{box-shadow:0 0 15px 3px #f38ba8b3}}@keyframes flash-glow-green-kb{0%{box-shadow:0 -4px 20px #00000080,0 0 15px 3px #99d1a0b3}}@keyframes flash-glow-red-kb{0%{box-shadow:0 -4px 20px #00000080,0 0 15px 3px #f38ba8b3}}.typing-area.flash-green{animation:flash-glow-green .4s ease-out}.typing-area.flash-red{animation:flash-glow-red .4s ease-out}#keyboard.flash-green{animation:flash-glow-green-kb .4s ease-out}#keyboard.flash-red{animation:flash-glow-red-kb .4s ease-out}.cli-infinite-status{text-align:center;font-size:.9rem;font-weight:700;padding:.5rem;animation:cli-fade-in .3s ease-out}.typing-tutor-container .hidden{display:none!important}.focus-keys-container{flex:0 0 100%;display:flex;flex-direction:column;align-items:center;gap:.75rem;margin-top:.75rem}.focus-keys-toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer;color:var(--tutor-muted);font-size:.9rem;accent-color:var(--tutor-secondary)}.focus-key-grid{display:flex;justify-content:center;gap:.35rem;margin-bottom:1.5rem}.focus-key-btn{width:28px;height:28px;background:var(--tutor-dark-bg);color:var(--tutor-dimmed);border:1px solid transparent;border-radius:4px;cursor:pointer;font-family:Consolas,Monaco,monospace;font-size:.8rem;font-weight:700;text-transform:uppercase;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.focus-key-btn:hover{background:#7d9dcc26;color:var(--tutor-accent)}.focus-key-btn.active{background:#7d9dcc33;color:var(--tutor-accent);border:1px solid var(--tutor-accent)}#keyboardContainer{position:fixed;bottom:0;left:50%;transform:translate(-50%);z-index:100}#keyboard{display:block;border-radius:8px 8px 0 0;background:var(--tutor-bg);padding:1rem;box-shadow:0 -4px 20px #00000080}.keyboard-close-btn{position:absolute;top:4px;right:4px;background:transparent;border:none;color:#666;font-size:1rem;cursor:pointer;z-index:101;padding:.25rem .5rem;border-radius:4px;transition:color .2s}.keyboard-close-btn:hover{color:var(--tutor-muted)}.points-counter{position:absolute;top:.5rem;right:.75rem;font-family:JetBrains Mono,Consolas,monospace;font-size:.9rem;font-weight:700;color:var(--tutor-heading);pointer-events:none;z-index:10}.points-counter.zero{opacity:.35}.points-counter.bump{animation:counter-bump .2s ease-out}@keyframes counter-bump{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}.points-popup{position:absolute;top:.5rem;right:3.5rem;font-family:JetBrains Mono,Consolas,monospace;font-size:.85rem;font-weight:700;pointer-events:none;z-index:10;animation:points-float .6s ease-out forwards}.points-popup.positive{color:var(--tutor-success)}.points-popup.negative{color:var(--tutor-error)}.points-popup.wildcard{color:var(--tutor-warning)}@keyframes points-float{0%{transform:translateY(0);opacity:1}to{transform:translateY(-30px);opacity:0}}.streak-word{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.8rem;font-weight:700;color:var(--tutor-heading);pointer-events:none;z-index:10;animation:streak-pop .8s ease-out forwards}@keyframes streak-pop{0%{transform:translate(-50%,-50%) scale(0);opacity:0}30%{transform:translate(-50%,-50%) scale(1.2);opacity:1}70%{opacity:1}to{transform:translate(-50%,-50%) scale(1);opacity:0}}.speed-bonus-reveal{display:inline-block;animation:bonus-slam .4s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes bonus-slam{0%{transform:scale(1.5);opacity:0}60%{transform:scale(.95);opacity:1}to{transform:scale(1);opacity:1}}@media(max-width:600px){.typing-tutor-container{padding:1rem}.typing-tutor-header h1{font-size:1.8rem}.typing-text{font-size:1.1rem}.stats-container{gap:1.5rem}.stat-value{font-size:1.8rem}}
