*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root[data-theme=light]{--bg-primary: #FAFAFA;--bg-secondary: #FFFFFF;--text-primary: #111111;--text-secondary: #666666;--accent-blue: #3B82F6;--success: #10B981;--error: #EF4444;--border: #E5E7EB;--shadow: rgba(0, 0, 0, .05);--shadow-md: rgba(0, 0, 0, .1)}:root[data-theme=dark]{--bg-primary: #0E0E0E;--bg-secondary: #1A1A1A;--text-primary: #EAEAEA;--text-secondary: #A0A0A0;--accent-blue: #60A5FA;--success: #34D399;--error: #F87171;--border: #2A2A2A;--shadow: rgba(0, 0, 0, .3);--shadow-md: rgba(0, 0, 0, .5)}*{transition:background-color .2s ease,color .2s ease,border-color .2s ease}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px;transition:background .2s ease}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}*{scrollbar-width:thin;scrollbar-color:var(--border) transparent}.app{min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary);display:flex;flex-direction:column}.header{height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 32px;border-bottom:1px solid var(--border);background-color:var(--bg-secondary)}.logo{font-size:24px;font-weight:700;color:var(--accent-blue);letter-spacing:-.5px}.header-controls{display:flex;align-items:center;gap:16px}.language-toggle{display:flex;background-color:var(--bg-primary);border:1px solid var(--border);border-radius:8px;overflow:hidden}.language-btn{padding:8px 16px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;font-size:14px;font-weight:500;transition:all .15s ease}.language-btn:disabled{opacity:.5;cursor:not-allowed}.language-btn.active{background-color:var(--accent-blue);color:#fff}.language-btn:hover:not(.active):not(:disabled){background-color:var(--border)}.theme-toggle{width:40px;height:40px;border-radius:8px;border:1px solid var(--border);background-color:var(--bg-primary);color:var(--text-primary);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.theme-toggle:hover{background-color:var(--border);transform:rotate(15deg)}.btn,.nav-btn{display:flex;align-items:center;justify-content:center;gap:8px}.text-success{color:var(--success)}.text-primary{color:var(--accent-blue)}.text-muted{color:var(--text-secondary)}.main-content{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 20px}.typing-container{display:grid;grid-template-columns:1fr 300px;gap:32px;max-width:1200px;width:100%}.words-input-section{display:flex;flex-direction:column;gap:16px}.word-display-container{background-color:var(--bg-secondary);border:2px solid var(--border);border-radius:12px;padding:24px;min-height:140px;max-height:140px;overflow:hidden;box-shadow:0 2px 8px var(--shadow)}.word-display-container[data-lang=tamil]{min-height:170px;max-height:170px}.word-display{display:flex;flex-wrap:wrap;gap:12px;font-family:Inter,SF Pro Display,-apple-system,system-ui,sans-serif;font-size:28px;line-height:1.5;height:100%;align-content:flex-start}.word-display[data-lang=tamil]{font-family:"Noto Serif Tamil",Latha,Arial Unicode MS,sans-serif;font-size:32px;line-height:1.6}.word{transition:all .15s ease-in-out;color:var(--text-secondary);opacity:.4}.word.active{color:var(--text-primary);font-weight:600;opacity:1;border-bottom:3px solid var(--accent-blue);padding-bottom:2px}.word.correct{animation:fadeOutCorrect .3s ease-out forwards}.word.wrong{animation:fadeOutWrong .3s ease-out forwards}@keyframes fadeOutCorrect{0%{opacity:1;color:var(--success);transform:scale(1)}to{opacity:0;transform:scale(.8) translateY(-10px)}}@keyframes fadeOutWrong{0%{opacity:1;color:var(--error);transform:scale(1)}to{opacity:0;transform:scale(.8) translateY(-10px)}}.input-container{position:relative}.input-box{width:100%;height:70px;font-size:24px;padding:20px;border:2px solid var(--border);border-radius:12px;background:var(--bg-secondary);color:var(--text-primary);font-family:Inter,SF Pro Display,-apple-system,system-ui,sans-serif;transition:all .2s ease;box-shadow:0 2px 8px var(--shadow)}.input-box[data-lang=tamil]{font-family:"Noto Serif Tamil",Latha,Arial Unicode MS,sans-serif;font-size:28px}.input-box:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 4px 16px var(--shadow-md),0 0 0 3px #3b82f61a}.input-box.correct{border-color:var(--success);color:var(--success)}.input-box.wrong{border-color:var(--error);color:var(--error)}:root[data-theme=dark] .input-box:focus{box-shadow:0 4px 16px var(--shadow-md),0 0 0 3px #60a5fa1a}.input-box::placeholder{color:var(--text-secondary);opacity:.5}.input-box:disabled{opacity:.6;cursor:not-allowed}.timer-stats-section{background-color:var(--bg-secondary);border:2px solid var(--border);border-radius:12px;padding:24px;box-shadow:0 2px 8px var(--shadow);display:flex;flex-direction:column;gap:20px;height:fit-content}.timer-display{text-align:center;padding:16px;background-color:var(--bg-primary);border-radius:8px}.timer-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.timer-inputs{display:flex;align-items:center;justify-content:center;gap:8px}.timer-input{width:50px;height:45px;font-size:24px;font-weight:700;text-align:center;border:2px solid var(--border);border-radius:8px;background-color:var(--bg-secondary);color:var(--text-primary);font-family:SF Mono,Consolas,monospace}.timer-input:focus{outline:none;border-color:var(--accent-blue)}.timer-input:disabled{opacity:.6;cursor:not-allowed}.timer-separator{font-size:24px;font-weight:700;color:var(--text-secondary)}.timer-time-display{font-size:48px;font-weight:700;color:var(--accent-blue);font-family:SF Mono,Consolas,monospace}.timer-buttons{display:flex;flex-direction:column;gap:8px}.btn{padding:12px 20px;font-size:14px;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;gap:6px}.btn-primary{background-color:var(--accent-blue);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #3b82f64d}.btn-secondary{background-color:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background-color:var(--border)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.stat-item{padding:12px;background-color:var(--bg-primary);border-radius:8px;text-align:center}.stat-label{font-size:10px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.stat-value{font-size:24px;font-weight:700;color:var(--text-primary)}.stat-value.accent{color:var(--accent-blue)}.inline-results{margin-top:16px;background-color:var(--bg-secondary);border:2px solid var(--border);border-radius:12px;padding:24px;box-shadow:0 4px 12px var(--shadow);animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.results-header{text-align:center}.results-title{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:24px}.results-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.result-metric{padding:12px;background-color:var(--bg-primary);border-radius:8px;display:flex;flex-direction:column;gap:4px;border:1px solid var(--border)}.metric-label{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.metric-value{font-size:20px;font-weight:700;color:var(--text-primary);display:flex;align-items:center;justify-content:center;gap:4px}.metric-value.highlight{color:var(--accent-blue);font-size:24px}.metric-sub{font-size:12px;font-weight:400;color:var(--text-secondary);opacity:.8}.retry-btn{width:100%;padding:16px;font-size:16px}.metric-value .correct{color:var(--success)}.metric-value .wrong{color:var(--error)}@media(max-width:600px){.results-summary{grid-template-columns:repeat(2,1fr)}}.char-correct{color:var(--success)}.char-wrong{color:var(--error);text-decoration:underline;text-decoration-color:var(--error)}.char-pending{color:inherit}@media(max-width:1023px){.typing-container{grid-template-columns:1fr;gap:24px}.timer-stats-section{order:-1}}@media(max-width:767px){.header{padding:8px 12px;height:auto;min-height:50px;flex-wrap:wrap;gap:8px}.logo{font-size:16px;order:1}.header-nav{order:3;width:100%;justify-content:center;gap:4px}.nav-btn{flex:1;padding:8px 12px;font-size:12px}.nav-btn svg{width:16px;height:16px}.header-controls{order:2;gap:6px}.language-toggle{border-radius:6px}.language-btn{padding:6px 8px;font-size:11px}.theme-toggle{width:32px;height:32px;font-size:16px;border-radius:6px}.theme-toggle svg{width:18px;height:18px}.main-content{padding:12px;align-items:flex-start}.typing-container{gap:12px;display:flex;flex-direction:column}.timer-stats-section{order:-1;padding:12px;flex-direction:row;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px}.timer-display{padding:0;background:transparent;display:flex;align-items:center;gap:8px}.timer-label{margin:0;display:none}.timer-time-display{font-size:24px}.timer-inputs{gap:4px}.timer-input{width:36px;height:32px;font-size:16px}.timer-separator{font-size:16px}.timer-buttons{flex-direction:row}.btn{padding:8px 12px;font-size:12px}.stats-grid{display:flex;gap:8px;flex:1;justify-content:flex-end}.stat-item{padding:4px 8px;min-width:60px}.stat-label{font-size:8px}.stat-value{font-size:14px}.words-input-section{gap:12px}.word-display-container{padding:12px;min-height:80px;max-height:80px}.word-display-container[data-lang=tamil]{min-height:100px;max-height:100px}.word-display{font-size:18px;gap:8px}.word-display[data-lang=tamil]{font-size:20px}.input-box{font-size:16px;height:50px;padding:12px}.input-box[data-lang=tamil]{font-size:18px}.modal{padding:20px;width:95%}.inline-results{padding:16px}.results-summary{grid-template-columns:1fr 1fr;gap:12px}}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}:focus-visible{outline:2px solid var(--accent-blue);outline-offset:2px}.header-nav{display:flex;gap:8px}.nav-btn{padding:8px 20px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;font-size:14px;font-weight:600;border-radius:6px;transition:all .15s ease}.nav-btn.active{background-color:var(--accent-blue);color:#fff}.nav-btn:hover:not(.active):not(:disabled){background-color:var(--border)}.nav-btn:disabled{opacity:.4;cursor:not-allowed}.learning-page{height:calc(100vh - 60px);max-height:calc(100vh - 60px);background-color:var(--bg-primary);display:flex;flex-direction:column;overflow:hidden}.learning-header{padding:12px 28px;border-bottom:1px solid var(--border);background-color:var(--bg-secondary);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.learning-title{font-size:18px;font-weight:700;color:var(--text-primary);margin:0}.learning-container{flex:1;display:grid;grid-template-columns:240px 1fr;gap:0;min-height:0;overflow:hidden}.exercise-menu{background-color:var(--bg-secondary);border-right:1px solid var(--border);padding:16px;overflow-y:auto}.menu-title{font-size:12px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.exercise-list{display:flex;flex-direction:column;gap:6px}.exercise-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background-color:var(--bg-primary);cursor:pointer;transition:all .15s ease;text-align:left;width:100%}.exercise-item:hover:not(.locked){background-color:var(--border);transform:translate(3px)}.exercise-item.current{border-color:var(--accent-blue);background-color:#3b82f61a}.exercise-item.completed{border-color:var(--success)}.exercise-item.locked{opacity:.5;cursor:not-allowed}.exercise-number{font-size:14px;font-weight:700;color:var(--accent-blue);min-width:20px}.exercise-name{flex:1;font-size:12px;color:var(--text-primary);line-height:1.3}.exercise-status-icon{font-size:14px}.exercise-area{padding:18px 28px;overflow-y:auto;display:flex;flex-direction:column;gap:12px;flex:1;background-color:var(--bg-primary);background-image:radial-gradient(var(--border) 1px,transparent 1px);background-size:20px 20px;min-height:0;align-items:center;justify-content:flex-start}.exercise-info{text-align:center;max-width:800px;margin:0 auto}.exercise-title{font-size:24px;font-weight:800;color:var(--text-primary);margin-bottom:4px;letter-spacing:-.4px}.exercise-description{font-size:13px;color:var(--text-secondary);line-height:1.5}.progress-section{background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:12px 18px;box-shadow:0 2px 6px var(--shadow);max-width:750px;width:100%}.progress-stats{display:flex;justify-content:space-between;margin-bottom:8px;font-size:12px;color:var(--text-primary);font-weight:600}.progress-bar{height:8px;background-color:var(--bg-primary);border-radius:4px;overflow:hidden;box-shadow:inset 0 1px 3px var(--shadow)}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-blue) 0%,#a78bfa 100%);transition:width .3s cubic-bezier(.4,0,.2,1);box-shadow:0 0 8px #6366f180}.target-text-container{background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:14px;padding:40px 32px;min-height:140px;max-height:350px;display:flex;align-items:flex-start;justify-content:center;box-shadow:0 4px 12px var(--shadow);max-width:750px;width:100%;position:relative;overflow-y:auto;scroll-behavior:smooth;scroll-padding:40px}.target-text-container[data-lang=tamil]{min-height:160px;max-height:400px;padding:44px 32px}.target-text{font-family:Inter,SF Pro Display,-apple-system,system-ui,sans-serif;font-size:28px;line-height:1.8;letter-spacing:.4px;display:flex;flex-direction:column;justify-content:flex-start;gap:0;position:relative;z-index:1;width:100%}.target-text[data-lang=tamil]{font-family:"Noto Serif Tamil",Latha,Arial Unicode MS,sans-serif;font-size:32px}.target-text .char{padding:2px 5px;border-radius:5px;transition:all .15s ease;min-width:14px;text-align:center}.target-text .char.pending{color:var(--text-secondary);opacity:.4}.target-text .char.current{color:var(--text-primary);background-color:var(--bg-primary);box-shadow:0 0 0 2px var(--accent-blue);font-weight:700;transform:scale(1.1);z-index:10}.target-text .char.correct{color:var(--success);text-shadow:0 0 10px rgba(16,185,129,.3)}.target-text .char.wrong{color:var(--error);background-color:#ef44441a;text-decoration:underline wavy var(--error)}.text-line{display:flex;flex-wrap:wrap;justify-content:center;gap:3px;width:100%}.text-line.current-line{margin-bottom:12px}.text-line.next-line{display:none}.learning-input-container{position:relative;max-width:750px;width:100%}.learning-input{width:100%;height:60px;font-size:24px;padding:16px 24px;border:2px solid var(--border);border-radius:12px;background:var(--bg-secondary);color:var(--text-primary);font-family:Inter,SF Pro Display,-apple-system,system-ui,sans-serif;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 6px var(--shadow);text-align:center}.learning-input[data-lang=tamil]{font-family:"Noto Serif Tamil",Latha,Arial Unicode MS,sans-serif;font-size:28px}.learning-input:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 6px 16px var(--shadow-md),0 0 0 3px #3b82f626;transform:translateY(-2px)}.visual-keyboard{background:linear-gradient(180deg,var(--bg-secondary) 0%,var(--bg-primary) 100%);border:1px solid var(--border);border-radius:12px;padding:12px 18px 10px;display:flex;flex-direction:column;gap:4px;align-items:center;box-shadow:0 3px 12px var(--shadow);max-width:750px;width:100%;will-change:auto}.visual-keyboard.premium{background:linear-gradient(145deg,var(--bg-secondary) 0%,var(--bg-primary) 100%)}.keyboard-row{display:flex;gap:4px;justify-content:center}.keyboard-key{min-width:46px;height:42px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;border:1.5px solid transparent;border-radius:8px;font-weight:600;position:relative;cursor:default}.keyboard-key.has-shift{justify-content:flex-end;padding-bottom:6px;padding-top:3px}.keyboard-key.wide{min-width:180px}.keyboard-key.home-key:after{content:"";position:absolute;bottom:4px;width:12px;height:2.5px;background-color:currentColor;border-radius:1.5px;opacity:.35}.keyboard-key.expected,.keyboard-key.correct,.keyboard-key.wrong{z-index:10}.key-shifted{font-size:9px;font-weight:700;line-height:1;position:absolute;top:3px;right:4px;text-shadow:0 1px 1px rgba(255,255,255,.3)}.key-label{font-size:14px;font-weight:700;line-height:1;text-shadow:0 1px 1px rgba(255,255,255,.3);letter-spacing:.4px}.finger-guide{display:none;gap:12px;margin-top:10px;flex-wrap:wrap;justify-content:center;padding-top:10px;border-top:1px solid var(--border)}.visual-keyboard:hover .finger-guide{display:flex}.finger-guide-item{display:flex;align-items:center;gap:6px;font-size:10px;color:var(--text-secondary)}.finger-color{width:14px;height:14px;border-radius:3px;border:1px solid rgba(0,0,0,.1);box-shadow:inset 0 1px #ffffff4d}.finger-label{font-weight:600;letter-spacing:.3px}.exercise-controls{display:flex;justify-content:center;gap:10px}.exercise-controls .btn{padding:10px 18px;font-size:13px}.exercise-complete{text-align:center;padding:40px;background-color:var(--bg-secondary);border:2px solid var(--border);border-radius:12px}.complete-title{font-size:32px;font-weight:700;color:var(--text-primary);margin-bottom:32px}.complete-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:32px;max-width:600px;margin-left:auto;margin-right:auto}.complete-stat{padding:20px;background-color:var(--bg-primary);border-radius:8px;border:1px solid var(--border)}.stat-label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.stat-value{display:block;font-size:28px;font-weight:700;color:var(--text-primary)}.stat-value.success{color:var(--success)}.stat-value.error{color:var(--error)}.complete-message{font-size:16px;color:var(--text-secondary);margin-bottom:24px;line-height:1.6}.complete-buttons{display:flex;gap:12px;justify-content:center}@media(max-width:1023px){.learning-container{grid-template-columns:1fr;max-height:none}.exercise-menu{border-right:none;border-bottom:1px solid var(--border);max-height:300px}.exercise-list{flex-direction:row;overflow-x:auto;padding-bottom:8px}.exercise-item{min-width:200px}}@media(max-width:767px){.learning-header{padding:12px 16px;flex-wrap:wrap;gap:12px}.learning-title{font-size:16px}.learning-container{grid-template-columns:1fr}.exercise-menu{padding:12px;max-height:200px}.menu-title{font-size:12px}.exercise-item{min-width:150px;padding:8px}.exercise-number{font-size:14px}.exercise-name{font-size:11px}.exercise-area{padding:16px;gap:16px}.exercise-title{font-size:18px}.exercise-description{font-size:12px}.target-text{font-size:24px}.target-text[data-lang=tamil]{font-size:28px}.learning-input{height:60px;font-size:20px;padding:16px}.learning-input[data-lang=tamil]{font-size:24px}.visual-keyboard{padding:12px;gap:4px}.keyboard-key{min-width:34px;height:38px}.keyboard-key.has-shift{padding-bottom:4px;padding-top:2px}.keyboard-key.wide{min-width:140px}.key-shifted{font-size:8px;top:3px;right:4px}.key-label{font-size:11px}.finger-guide{display:none}.complete-stats{grid-template-columns:1fr;gap:12px}.complete-title{font-size:24px}.stat-value{font-size:20px}.complete-buttons{flex-direction:column;width:100%}.complete-buttons .btn{width:100%}.progress-stats{flex-direction:column;gap:4px;font-size:12px}.exercise-controls,.exercise-controls .btn{width:100%}}@media(max-width:479px){.learning-header{padding:10px 12px}.learning-header .btn{padding:8px 12px;font-size:12px}.learning-header .btn span{display:none}.learning-title{font-size:14px;order:2;width:100%;text-align:center;margin-top:8px}.exercise-menu{max-height:120px;padding:8px}.menu-title{display:none}.exercise-item{min-width:100px;padding:6px 8px}.exercise-number{font-size:12px;min-width:22px;height:22px}.exercise-name{font-size:10px}.exercise-area{padding:12px;gap:12px}.exercise-title{font-size:16px}.exercise-description{display:none}.target-text{font-size:20px;padding:12px}.target-text[data-lang=tamil]{font-size:24px}.learning-input{height:50px;font-size:18px;padding:12px}.learning-input[data-lang=tamil]{font-size:20px}.visual-keyboard{padding:8px;gap:2px}.keyboard-row{gap:2px}.keyboard-key{min-width:26px;height:30px;border-radius:4px}.keyboard-key.wide{min-width:80px}.key-shifted{display:none}.key-label{font-size:9px}.complete-stat{padding:12px}.stat-label{font-size:11px}.stat-value{font-size:18px}.complete-message{font-size:12px}}
