:root{--max-width: 1200px;--bg-primary: #0f0f0f;--bg-card: #1a1a1a;--bg-hover: #242424;--bg-elevated: #2a2a2a;--surface-0: #0f0f0f;--surface-1: #1a1a1a;--surface-2: #242424;--surface-3: #2e2e2e;--surface-4: #383838;--glass-border: rgba(255, 255, 255, .08);--border-subtle: rgba(255, 255, 255, .06);--border-default: rgba(255, 255, 255, .1);--shadow-subtle: 0 2px 8px rgba(0, 0, 0, .3), 0 1px 2px rgba(0, 0, 0, .2);--shadow-elevated: 0 8px 32px rgba(0, 0, 0, .4), 0 2px 8px rgba(0, 0, 0, .3);--text-primary: #e8e8e8;--text-secondary: #b8b8b8;--text-tertiary: #9a9a9a;--accent-green: #10b981;--accent-orange: #f59e0b;--accent-blue: #3b82f6;--accent-red: #ef4444;--primary-color: var(--accent-orange);--success-color: var(--accent-green);--danger-color: var(--accent-red);--space-xs: .5rem;--space-sm: 1rem;--space-md: 1.5rem;--space-lg: 2rem;--space-xl: 3rem;--text-xs: clamp(.75rem, 1.5vw, .875rem);--text-sm: clamp(.875rem, 2vw, 1rem);--text-base: clamp(1rem, 2.5vw, 1.125rem);--text-lg: clamp(1.125rem, 3vw, 1.25rem);--text-xl: clamp(1.25rem, 3.5vw, 1.5rem);--text-2xl: clamp(1.5rem, 4vw, 1.75rem);--text-3xl: clamp(1.75rem, 5vw, 2rem);--text-4xl: clamp(2rem, 6vw, 2.5rem);--text-5xl: clamp(2.5rem, 8vw, 3.5rem);--radius-sm: .375rem;--radius-md: .625rem;--radius-lg: 1rem;--border-color: var(--border-default);--success: var(--accent-green);--error: var(--accent-red);--warning: #ff9800}*{margin:0;padding:0;box-sizing:border-box;scrollbar-width:none;-ms-overflow-style:none}*::-webkit-scrollbar{display:none}html{overflow-x:hidden;width:100vw}.container,.main-content,.performance-section,.practice-card{max-width:100%}body{font-family:JetBrains Mono,SF Mono,Fira Code,Monaco,Cascadia Code,Roboto Mono,Consolas,monospace;line-height:1.6;background-color:var(--bg-primary);color:var(--text-primary);margin:0;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;letter-spacing:.02em;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;background-image:radial-gradient(circle at 20% 50%,rgba(74,158,255,.03) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(255,112,67,.03) 0%,transparent 50%)}.container{max-width:var(--max-width);width:100%;margin:0 auto;padding:0;padding-top:calc(212px + env(safe-area-inset-top));min-height:100vh;background:transparent}h1,h2,h3{font-weight:600}.fixed-top-section{position:fixed;top:calc(60px + env(safe-area-inset-top));left:0;right:0;z-index:90;background:transparent}.fixed-top-section-inner{max-width:var(--max-width);width:100%;margin:0 auto;padding:0}.app-header{background:#0f0f0ff2;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--border-subtle);position:fixed;top:0;left:0;right:0;z-index:100;transition:all .3s ease;width:100%;box-shadow:0 2px 16px #0003;will-change:transform;transform:translateZ(0)}.header-content{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;padding-top:calc(1rem + env(safe-area-inset-top));padding-left:calc(1.5rem + env(safe-area-inset-left));padding-right:calc(1.5rem + env(safe-area-inset-right));max-width:var(--max-width);margin:0 auto;min-height:48px}.timer-info{display:flex;align-items:baseline;gap:.5rem}.timer-label{font-size:.875rem;color:var(--text-tertiary)}.timer-value{font-size:1.125rem;font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.settings-btn{display:flex;align-items:center;gap:.5rem;background:transparent;border:none;color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;padding:.75rem 1rem;margin:-.75rem -1rem;border-radius:8px;transition:all .15s ease;-webkit-tap-highlight-color:transparent;min-height:48px}.settings-btn:hover{background:#ffffff0d}.settings-btn:active{background:#ffffff14;transform:scale(.98)}.settings-btn:focus-visible{outline:2px solid var(--accent-blue);outline-offset:2px}.settings-recognition,.settings-speed{color:var(--text-secondary)}.settings-separator{color:var(--text-tertiary)}.settings-icon{color:var(--text-secondary);width:20px;height:20px;transition:color .15s}.settings-btn:hover .settings-icon{color:var(--text-primary)}h2{font-size:1.25rem;margin-bottom:1rem}h3{font-size:1rem;margin-bottom:.5rem}.main-content{display:flex;flex-direction:column;padding:0;gap:0;max-width:100%;position:relative;min-height:calc(100vh - 60px - env(safe-area-inset-top))}.performance-section{display:flex;flex-direction:column;gap:1.5rem;max-width:100%;padding:0 1.5rem calc(1.5rem + env(safe-area-inset-bottom) + 40px) 1.5rem}body.is-playing .main-content{position:relative}.practice-card{background:#ffffff08;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:20px;padding:0;text-align:center;border:1px solid var(--glass-border);user-select:none;-webkit-user-select:none;box-shadow:var(--shadow-elevated),0 8px 16px -4px #0000004d,0 12px 24px -8px #0003;position:relative;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);min-height:120px;margin:1rem 1.5rem;flex-shrink:0;z-index:10}.practice-card.waiting-start{border:2px solid var(--primary-color);cursor:pointer;box-shadow:0 0 20px #f9731633,var(--shadow-elevated);background:#f973160d}.practice-card.waiting-start:hover{background:#f973161a;box-shadow:0 0 30px #f973164d,var(--shadow-elevated);transform:translateY(-1px)}.practice-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.05) 0%,transparent 100%);pointer-events:none}.practice-content{min-height:120px;display:flex;flex-direction:row;position:relative;gap:0;align-items:stretch}.practice-display-zone *{transition:opacity .3s ease,visibility .3s ease}.practice-display-zone{flex:1;display:flex;align-items:center;justify-content:center;position:relative;padding:1rem}.form-label{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;font-weight:600;margin-bottom:.5rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;gap:1rem}.settings-group{display:flex;flex-direction:column;gap:2rem}.slider{width:100%;height:6px;border-radius:3px;background:var(--border-default);outline:none;-webkit-appearance:none;margin:1rem 0}.slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--primary-color);cursor:pointer;transition:all .2s}.slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 0 8px #3b82f61a}.slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--primary-color);cursor:pointer;border:none;transition:all .2s}.slider::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 0 0 8px #3b82f61a}.slider-labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-tertiary);margin-top:.25rem;letter-spacing:.02em}.label-value{color:var(--primary-color);font-weight:700;letter-spacing:.02em;white-space:nowrap}.slider:disabled{opacity:.5;cursor:not-allowed}.voice-selector{width:100%;padding:.5rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);font-size:1rem;cursor:pointer;transition:all .2s}.voice-selector:hover{background:var(--surface-2);border-color:var(--border-default)}.voice-selector:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f61a}.voice-selector:disabled{opacity:.4;cursor:not-allowed;background:#ffffff0d}.voice-helper-text{font-size:.8125rem;color:var(--text-tertiary);margin-top:.375rem;line-height:1.2;transition:opacity .2s ease-in-out;opacity:0}.voice-helper-text.show{opacity:1}.voice-helper-text:before{content:"ⓘ ";opacity:.7}.ripple-container{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;pointer-events:none;border-radius:inherit}.ripple{position:absolute;border-radius:50%;background:#ffffff80;transform:scale(0);animation:ripple-animation .6s ease-out}@keyframes ripple-animation{to{transform:scale(4);opacity:0}}.btn-start{background:transparent;border:none;color:var(--primary-color);padding:2rem;font-size:1.25rem;font-weight:700;cursor:pointer;letter-spacing:.1em;height:100%;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);text-transform:uppercase;position:absolute;top:0;left:0;bottom:0;width:100%;z-index:1}.button-text{position:relative;z-index:1}@keyframes gentlePulse{0%,to{transform:scale(1)}50%{transform:scale(1.01)}}.practice-card.waiting-start{animation:gentlePulse 3s ease-in-out infinite}@media (prefers-reduced-motion: reduce){.practice-card.waiting-start{animation:none}}.practice-card.waiting-start:hover{animation:none}.side-button{min-width:80px;min-height:120px;border:none;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden;position:relative;z-index:1;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:.25rem;-webkit-tap-highlight-color:transparent}.stop-btn{background:var(--surface-1);color:var(--text-secondary);border-radius:20px 0 0 20px;box-shadow:inset 0 2px 4px #0000004d,inset 0 1px #ffffff0d}.side-button .button-text{display:flex;align-items:center;justify-content:center;flex-direction:column}.side-button svg{width:24px;height:24px;display:block}.stop-btn:hover{background:var(--surface-2);color:var(--text-primary);box-shadow:inset 0 2px 4px #0003,inset 0 1px #ffffff14}.stop-btn:active{transform:scale(.98);background:var(--surface-0);box-shadow:inset 0 3px 6px #0006}.oops-btn{background:#dc2626;color:#fff;border-radius:0 20px 20px 0;font-weight:700}.oops-btn:active{transform:scale(.98)}.oops-btn:disabled{background:var(--surface-2);color:var(--text-tertiary);cursor:not-allowed}.oops-btn.oops-marked{background:var(--surface-3);color:var(--text-tertiary);border-color:transparent;box-shadow:inset 0 2px 4px #0000004d,inset 0 1px #ffffff0d;cursor:not-allowed}.oops-btn .ripple{position:absolute;border-radius:50%;background:#fff9;transform:scale(0);animation:ripple-effect .6s ease-out;pointer-events:none}@keyframes ripple-effect{to{transform:scale(4);opacity:0}}.oops-btn.pressed{animation:subtle-press .2s ease-out}@keyframes subtle-press{0%{transform:scale(1)}50%{transform:scale(.98)}to{transform:scale(1)}}.listening-state{display:flex;align-items:center;justify-content:center;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.listening-state.visible{opacity:1;visibility:visible}.morse-waveform{display:flex;align-items:center;justify-content:center;gap:4px;height:60px;padding:0 10px}.waveform-bar{width:4px;height:24px;background:var(--primary-color);border-radius:2px;transition:all .1s cubic-bezier(.4,0,.2,1);transform-origin:center;opacity:.3;box-shadow:0 0 10px #ff70434d;will-change:transform,opacity;-webkit-transform:translateZ(0);transform:translateZ(0)}.listening-state.visible .waveform-bar{animation:idleWave 2s ease-in-out infinite;opacity:.5}.listening-state.visible .waveform-bar:nth-child(1){animation-delay:0ms}.listening-state.visible .waveform-bar:nth-child(2){animation-delay:.1s}.listening-state.visible .waveform-bar:nth-child(3){animation-delay:.2s}.listening-state.visible .waveform-bar:nth-child(4){animation-delay:.3s}.listening-state.visible .waveform-bar:nth-child(5){animation-delay:.4s}.listening-state.visible .waveform-bar:nth-child(6){animation-delay:.5s}.listening-state.visible .waveform-bar:nth-child(7){animation-delay:.6s}.waveform-bar.active-dot{animation:dotPulse .15s ease-out!important;opacity:1!important}.waveform-bar.active-dash{animation:dashPulse .45s ease-out!important;opacity:1!important}@keyframes idleWave{0%,to{transform:scaleY(1);opacity:.5}50%{transform:scaleY(1.3);opacity:.7}}@keyframes dotPulse{0%{transform:scaleY(1);opacity:.5}20%{transform:scaleY(2.5);opacity:1;filter:brightness(1.3);box-shadow:0 0 20px #ff7043cc}to{transform:scaleY(1);opacity:.5;filter:brightness(1);box-shadow:0 0 10px #ff70434d}}@keyframes dashPulse{0%{transform:scaleY(1);opacity:.5}15%{transform:scaleY(3);opacity:1;filter:brightness(1.3);box-shadow:0 0 25px #ff7043e6}85%{transform:scaleY(2.8);opacity:1;filter:brightness(1.2)}to{transform:scaleY(1);opacity:.5;filter:brightness(1);box-shadow:0 0 10px #ff70434d}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.waveform-bar{transition:none;animation:none!important}.waveform-bar.active-dot,.waveform-bar.active-dash{opacity:1;transform:scaleY(2)}.heat-map-container,.pattern-group,.progress-overview,.live-stat,.gauge-accuracy.optimal{animation:none}}.char-display{font-size:clamp(4rem,15vw,6rem);font-weight:700;line-height:1;color:var(--text-primary);letter-spacing:.1em;opacity:0;visibility:hidden;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.8);transition:all .4s cubic-bezier(.4,0,.2,1);-webkit-backface-visibility:hidden;backface-visibility:hidden;transform-style:preserve-3d;will-change:opacity,transform;text-shadow:0 0 20px rgba(255,255,255,.1),0 0 40px rgba(255,255,255,.05)}.char-display.visible{opacity:1;visibility:visible;transform:translate(-50%,-50%) scale(1)}.performance-dashboard{display:none;gap:1.5rem}.is-playing .performance-dashboard,.has-practiced .performance-dashboard{display:grid}.heat-map-container{background:#ffffff08;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:16px;padding:1.25rem;border:1px solid var(--glass-border);box-shadow:var(--shadow-subtle);overflow:hidden;max-width:100%;transition:all .3s cubic-bezier(.4,0,.2,1)}.heat-map-title{font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.05em}.heat-map-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(44px,48px));gap:.5rem;justify-content:center}.heat-cell{min-width:44px;min-height:44px;width:100%;aspect-ratio:1;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;border:1px solid transparent;letter-spacing:.05em;will-change:transform;-webkit-tap-highlight-color:transparent}.heat-cell:hover{transform:scale(1.15) translateZ(0);z-index:2;box-shadow:0 8px 16px #0000004d,0 0 0 2px var(--glass-border)}.heat-cell.unpracticed{background:var(--surface-1);color:var(--text-tertiary);border-color:var(--border-default)}.heat-cell.struggling{background:var(--accent-red);color:#fff;font-weight:600}.heat-cell.learning{background:var(--accent-orange);color:#000;font-weight:600}.heat-cell.good{background:var(--accent-blue);color:#fff;font-weight:600}.heat-cell.mastered{background:var(--accent-green);color:#000;font-weight:600}.heat-cell-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:var(--surface-4);color:var(--text-primary);padding:.5rem .75rem;border-radius:6px;font-size:.75rem;white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .2s,transform .2s;z-index:10;pointer-events:none;margin-bottom:.5rem;box-shadow:0 4px 12px #0000004d;border:1px solid var(--border-subtle);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.heat-cell:hover .heat-cell-tooltip{opacity:1;visibility:visible;transform:translate(-50%) translateY(-4px)}.pattern-analysis{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.pattern-group{background:#ffffff08;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:16px;padding:1.25rem;border:1px solid var(--glass-border);box-shadow:var(--shadow-subtle);min-width:0;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;min-height:200px}.pattern-group:hover{border-color:var(--border-default);transform:translateY(-2px);box-shadow:var(--shadow-elevated)}.pattern-group-title{font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.pattern-chars{display:grid;grid-template-columns:repeat(4,1fr);gap:.375rem;width:100%;flex:1;align-content:start}.pattern-chars.has-pairs{grid-template-columns:repeat(2,1fr);gap:.375rem;width:100%;flex:1;align-content:start}.pattern-char{aspect-ratio:1;min-width:24px;max-width:36px;width:100%;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:clamp(.625rem,2.5vw,.875rem);font-weight:700;transition:all .2s;border:1px solid transparent;justify-self:center}.confusion-pair .pattern-char{min-width:16px;max-width:24px;font-size:clamp(.5rem,2vw,.75rem);border-radius:4px}.pattern-char.unpracticed,.pattern-char.ghost{background:var(--bg-card);color:var(--text-tertiary);border-color:var(--border-subtle)}.pattern-char.ghost,.confusion-pair.ghost{visibility:hidden;pointer-events:none}.confusion-pair{display:flex;align-items:center;justify-content:center;gap:.1rem;position:relative;height:36px;min-width:60px;max-width:80px;width:100%;justify-self:center;padding:.125rem;border-radius:6px;background:#ffffff01;border:1px solid rgba(255,255,255,.03)}.confusion-pair.confusion-low{background:#5a9fff26;border:1px solid rgba(90,159,255,.3)}.confusion-pair.confusion-medium{background:#ff704333;border:1px solid rgba(255,112,67,.4)}.confusion-pair.confusion-high{background:#ff5a6b40;border:1px solid rgba(255,90,107,.5)}.pair-separator{color:var(--text-tertiary);font-size:.75rem;opacity:.7}.confusion-count{position:absolute;top:-6px;right:-6px;background:var(--accent-orange);color:#000;font-size:.5rem;font-weight:700;width:14px;height:14px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0003;line-height:1}.pattern-char.struggling{background:var(--accent-red);color:#fff;font-weight:600}.pattern-char.learning{background:var(--accent-orange);color:#000;font-weight:600}.pattern-char.good{background:var(--accent-blue);color:#fff;font-weight:600}.pattern-char.mastered{background:var(--accent-green);color:#000;font-weight:600}.pattern-accuracy{font-size:1.5rem;font-weight:700;letter-spacing:.02em;margin-top:auto;padding-top:.25rem}.pattern-description{font-size:.75rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem;padding-top:.75rem}.live-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;max-width:100%}.live-stat{background:#ffffff08;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:16px;padding:1.25rem;border:1px solid var(--glass-border);text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.live-stat:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 60%,rgba(255,255,255,.02) 100%);pointer-events:none}.live-stat:hover{transform:translateY(-2px);border-color:var(--border-default);box-shadow:var(--shadow-subtle)}.live-stat-value{font-size:1.75rem;font-weight:700;display:block;margin-bottom:.25rem;letter-spacing:.02em}.live-stat-label{font-size:.75rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.progress-overview{background:#ffffff08;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:16px;padding:1.25rem;margin-bottom:0;border:1px solid var(--glass-border);box-shadow:var(--shadow-subtle);max-width:100%;overflow:visible;min-height:fit-content;transition:all .3s cubic-bezier(.4,0,.2,1)}.overall-accuracy{font-size:2rem;font-weight:700;margin-bottom:.5rem;letter-spacing:.02em}.progress-message{color:var(--text-secondary);font-size:.875rem;line-height:1.5}.welcome-box{text-align:center;padding:1.5rem}.welcome-box h3{color:var(--text-primary);font-size:1.5rem;margin-bottom:.25rem;text-align:center;letter-spacing:.02em;font-weight:700}.welcome-box .tagline{color:var(--text-secondary);text-align:center;margin-bottom:2rem;font-size:.875rem}.how-it-works{display:flex;gap:1rem;margin-bottom:2rem;justify-content:center}.step-card{flex:1;max-width:140px;text-align:center;padding:1rem .5rem;border-radius:var(--radius-md);background:var(--surface-1);border:1px solid var(--border-subtle);transition:all .2s ease}.step-card:hover{background:var(--surface-2);border-color:var(--border-default);transform:translateY(-2px)}.step-icon{margin-bottom:.5rem;display:block;color:var(--text-secondary)}.step-content h4{color:var(--text-primary);font-size:.875rem;margin-bottom:.25rem;font-weight:600}.step-content p{color:var(--text-secondary);font-size:.75rem;margin:0;line-height:1.3}.key-features{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem;max-width:400px;margin-left:auto;margin-right:auto}.feature{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--surface-1);border-radius:var(--radius-sm);border:1px solid var(--border-subtle);font-size:.813rem;color:var(--text-secondary);text-align:left}.feature-icon{flex-shrink:0;color:var(--text-secondary)}.quick-tips{text-align:center;padding-top:1rem;margin-top:.5rem;border-top:1px solid var(--border-subtle)}.quick-tips .tip{color:var(--text-tertiary);font-size:.75rem;margin:0}kbd{display:inline-block;padding:.125rem .375rem;font-size:.75rem;font-family:inherit;line-height:1.2;color:var(--text-primary);background-color:var(--surface-2);border:1px solid var(--border-default);border-radius:3px;box-shadow:inset 0 -1px 0 var(--border-subtle);white-space:nowrap}@media (max-width: 640px){.welcome-box{padding:1rem}.welcome-box h3{font-size:1.25rem}.how-it-works{gap:.5rem}.step-card{padding:.75rem .25rem}.step-content h4{font-size:.813rem}.feature{padding:.625rem .75rem;font-size:.75rem}}.progress-bar{background:var(--border-default);height:4px;border-radius:2px;overflow:hidden;margin-bottom:.25rem}.progress-fill{height:100%;background:var(--accent-green);transition:width .3s ease;position:relative;overflow:hidden}.progress-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:shimmer 2s infinite}.progress-fill.medium{background:var(--accent-orange)}.progress-fill.poor{background:var(--accent-red)}.overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:999;opacity:0;transition:opacity .3s ease}.overlay.show{display:block;opacity:1}.settings-panel{position:fixed;top:0;right:0;bottom:0;width:400px;background:#0f0f0ff2;backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:2000;border-left:1px solid var(--glass-border);box-shadow:-8px 0 32px #0006,-2px 0 8px #0003;overflow-y:auto;-webkit-overflow-scrolling:touch}.settings-panel.show{transform:translate(0)}.settings-panel-inner{padding:1.5rem;padding-top:calc(1.5rem + env(safe-area-inset-top));padding-bottom:calc(1.5rem + env(safe-area-inset-bottom));min-height:100%;display:flex;flex-direction:column}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.panel-body{flex:1}.panel-footer{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-subtle)}.contact-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--text-secondary);text-decoration:none;font-size:.875rem;font-weight:500;padding:.75rem 1rem;border-radius:12px;background:#ffffff08;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--glass-border);transition:all .2s cubic-bezier(.4,0,.2,1);width:100%;justify-content:center}.contact-link:hover{color:var(--text-primary);background:#ffffff0d;border-color:var(--border-default);transform:translateY(-1px);box-shadow:0 4px 12px #0003}.contact-link svg{width:20px;height:20px}.keyboard-shortcuts{margin-bottom:1.5rem;padding:1rem;background:#ffffff08;border-radius:8px;border:1px solid var(--glass-border)}.shortcuts-title{font-size:.75rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.shortcut-list{display:flex;flex-direction:column;gap:.5rem}.shortcut-item{display:flex;align-items:center;gap:.75rem;font-size:.8125rem}.shortcut-item kbd{min-width:2rem;padding:.25rem .5rem;background:var(--surface-2);border:1px solid var(--border-default);border-radius:4px;font-family:var(--font-mono);font-size:.75rem;color:var(--text-primary);box-shadow:inset 0 -1px 0 var(--border-subtle),0 1px 2px #0003;text-align:center;font-weight:600}.shortcut-desc{color:var(--text-secondary)}.panel-footer{padding-top:0}@media (max-width: 768px){.settings-panel{width:100%;transform:translateY(100%);border-left:none;border-top:1px solid var(--glass-border)}.settings-panel.show{transform:translateY(0)}.voice-selector{min-height:44px;font-size:1rem}.voice-helper-text{font-size:.875rem}}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-tertiary);padding:.25rem;line-height:1;transition:color .2s}.close-btn:hover{color:var(--text-secondary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}@media (max-width: 768px){:root{--space-xs: .375rem;--space-sm: .75rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem}.heat-map-grid{grid-template-columns:repeat(auto-fill,minmax(42px,1fr));gap:.375rem;max-width:100%;padding:0 .5rem}.pattern-chars{grid-template-columns:repeat(3,1fr)}.live-stats{grid-template-columns:repeat(2,1fr);gap:.75rem}.heat-map-title,.pattern-group-title{font-size:var(--text-base)}.welcome-box h3{font-size:var(--text-xl)}.btn-start{padding:2.5rem 2rem;font-size:var(--text-lg)}.pattern-analysis{grid-template-columns:repeat(2,1fr);gap:.75rem}.header-content{padding:.75rem 1rem;padding-top:calc(.75rem + env(safe-area-inset-top))}}@media (max-width: 480px){.heat-map-grid{grid-template-columns:repeat(auto-fill,minmax(40px,1fr));gap:.25rem}.side-button{min-width:60px}.practice-card{border-radius:16px}.pattern-analysis{grid-template-columns:repeat(2,1fr);gap:.5rem}.pattern-group{padding:1rem;min-height:160px}}@media (min-width: 769px) and (max-width: 1024px){.heat-map-grid{grid-template-columns:repeat(auto-fill,minmax(46px,52px))}.pattern-analysis{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1025px) and (max-width: 1439px){.pattern-analysis{grid-template-columns:repeat(4,1fr)}}@media (min-width: 1440px){.heat-map-grid{grid-template-columns:repeat(auto-fill,52px);gap:.625rem}.pattern-analysis{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}}.heat-map-container,.progress-overview,.live-stat{animation:fadeInUp .6s ease-out backwards}.pattern-group{opacity:1;transform:translateY(0);transition:opacity .3s ease,transform .3s ease}body:not(.is-playing) .pattern-group{animation:fadeInUp .6s ease-out backwards}.heat-map-container{animation-delay:.1s}body:not(.is-playing) .pattern-group:nth-child(1){animation-delay:.2s}body:not(.is-playing) .pattern-group:nth-child(2){animation-delay:.3s}body:not(.is-playing) .pattern-group:nth-child(3){animation-delay:.4s}.live-stat:nth-child(1){animation-delay:.15s}.live-stat:nth-child(2){animation-delay:.25s}.live-stat:nth-child(3){animation-delay:.35s}.live-stat:nth-child(4){animation-delay:.45s}.loading-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;height:-webkit-fill-available;background:var(--bg-primary);z-index:10000;display:none;align-items:center;justify-content:center;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}.loading-overlay.show{display:flex}.loading-content{text-align:center;max-width:400px;padding:var(--space-lg);margin:auto;position:relative}.loading-title{font-size:var(--text-4xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-xs);letter-spacing:-.02em}.loading-subtitle{font-size:var(--text-lg);color:var(--text-secondary);margin-bottom:var(--space-xl)}.progress-container{width:100%}.progress-bar{width:100%;height:6px;background:var(--bg-elevated);border-radius:3px;overflow:hidden;margin-bottom:var(--space-md)}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-blue),var(--accent-green));width:0%;transition:width .3s ease;border-radius:3px}.loading-text{font-size:var(--text-sm);color:var(--text-secondary)}.gauge-container{background:linear-gradient(135deg,#ffffff0d,#ffffff05);border:1.5px solid var(--border-default);border-radius:var(--radius-lg);padding:var(--space-lg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);will-change:transform;box-shadow:0 4px 20px #0000001a,0 0 0 1px #ffffff0d inset;position:relative}.gauge-container:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at center,rgba(255,255,255,.03) 0%,transparent 70%);animation:gauge-shimmer 8s ease-in-out infinite;pointer-events:none}@keyframes gauge-shimmer{0%,to{transform:translate(0) scale(1);opacity:.5}50%{transform:translate(-10%,-10%) scale(1.1);opacity:.8}}.gauge-wrapper{display:flex;flex-direction:column;gap:0}.gauge-section{display:flex;justify-content:center;align-items:center;margin-bottom:0;transition:box-shadow .5s ease-out;position:relative}.gauge-zone-arc{transition:all .5s ease-out;filter:brightness(.8) saturate(.7);transform-origin:center}.gauge-zone-arc.too-easy-arc{opacity:.45}.gauge-zone-arc.learning-arc{opacity:.5}.gauge-zone-arc.too-hard-arc{opacity:.45}.gauge-wrapper.zone-learning .gauge-zone-arc.learning-arc,.gauge-wrapper.zone-too-easy .gauge-zone-arc.too-easy-arc,.gauge-wrapper.zone-too-hard .gauge-zone-arc.too-hard-arc{opacity:1;filter:brightness(1.3) saturate(1.1);-webkit-filter:brightness(1.3) saturate(1.1)}.gauge-label{font-size:13px;font-weight:600;fill:#fffffff2;letter-spacing:.06em;text-transform:uppercase;opacity:.65;text-shadow:0 1px 3px rgba(0,0,0,.5),0 0 10px rgba(0,0,0,.3);paint-order:stroke fill;stroke:#0006;stroke-width:.7px;transition:opacity .5s ease-out,fill .5s ease-out}.gauge-label.training-zone{fill:#fff;font-weight:700;font-size:13px;stroke-width:.7px}.gauge-wrapper.zone-learning .gauge-label:nth-of-type(2){opacity:1;fill:#fff}.gauge-wrapper.zone-too-hard .gauge-label:nth-of-type(1){opacity:1;fill:#fff}.gauge-wrapper.zone-too-easy .gauge-label:nth-of-type(3){opacity:1;fill:#fff}.gauge-needle-line{stroke:var(--text-primary);stroke-width:4;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3)) drop-shadow(0 0 8px rgba(255,255,255,.2))}.gauge-needle-triangle{filter:drop-shadow(0 2px 6px rgba(0,0,0,.4)) drop-shadow(0 0 10px rgba(255,255,255,.15))}.gauge-needle circle{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.gauge-wrapper.zone-learning .gauge-needle-line{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3)) drop-shadow(0 0 12px rgba(102,187,106,.4))}.gauge-wrapper.zone-too-easy .gauge-needle-line{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3)) drop-shadow(0 0 12px rgba(100,181,246,.4))}.gauge-wrapper.zone-too-hard .gauge-needle-line{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3)) drop-shadow(0 0 12px rgba(239,83,80,.4))}.gauge-accuracy{font-family:inherit;fill:var(--text-primary);transition:fill .3s ease}.gauge-accuracy.optimal{fill:var(--accent-green)}.gauge-accuracy.too-easy{fill:var(--accent-blue)}.gauge-accuracy.too-hard{fill:var(--accent-red)}.gauge-zone-status{font-size:14px;font-weight:500;fill:var(--text-secondary);transition:all .3s ease}.gauge-zone-status.optimal{fill:var(--success);font-weight:600}.gauge-zone-status.too-easy{fill:var(--accent-blue)}.gauge-zone-status.too-hard{fill:var(--accent-orange)}.gauge-needle-animated{transition:transform .8s cubic-bezier(.4,0,.2,1)}.gauge-zone-arc{cursor:pointer}.gauge-zone-arc:hover{filter:brightness(1.15)}@media (max-width: 640px){.gauge-svg{width:100%;height:auto}.gauge-container{padding:var(--space-md)}.gauge-section{overflow:hidden}.recognition-recommendation-btn{min-width:120px;font-size:.875rem;padding:var(--space-sm) var(--space-md)}.zone-status-text{font-size:.8125rem}}@media (prefers-reduced-motion: reduce){.gauge-needle-line{animation:none!important}.gauge-needle-animated{transition:none}.gauge-container:before{animation:none}.recognition-adjust{animation:none}animateTransform,animate{display:none}}.zone-status-message{text-align:center;margin-top:0;min-height:1.25rem}.zone-status-text{font-size:.875rem;font-weight:500;letter-spacing:.05em;transition:all .4s cubic-bezier(.4,0,.2,1);text-transform:uppercase;opacity:.8;line-height:1.25rem}.zone-status-text.optimal{color:var(--accent-green);font-weight:600;opacity:1;text-shadow:0 0 10px rgba(102,187,106,.3)}.zone-status-text.too-easy{color:var(--accent-blue);opacity:.9;text-shadow:0 0 10px rgba(100,181,246,.3)}.zone-status-text.too-hard{color:var(--error);opacity:.9;text-shadow:0 0 10px rgba(239,83,80,.3)}.zone-status-text.too-hard{color:var(--accent-red)}.recognition-controls{display:flex;justify-content:center;align-items:center;margin-top:16px;min-height:44px}.recognition-recommendation-btn{min-width:140px;min-height:44px;padding:var(--space-sm) var(--space-lg);font-size:var(--text-base);font-weight:600;background:linear-gradient(135deg,#ffffff14,#ffffff0a);border:1.5px solid rgba(255,255,255,.12);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 4px 16px #00000026,0 0 20px #ffffff1a,0 0 0 1px #ffffff1a inset;animation:pulse-glow 2s ease-in-out infinite}.recognition-recommendation-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 24px #00000040,0 0 30px #ffffff26,0 0 0 1px #ffffff26 inset}.recognition-recommendation-btn:active:not(:disabled){transform:translateY(0);transition-duration:.1s}.recognition-recommendation-btn:focus{outline:none;box-shadow:0 0 0 3px #64b5f64d}.recognition-recommendation-btn:disabled,.recognition-recommendation-btn.training-well{cursor:default;opacity:.5;background:linear-gradient(135deg,#ffffff0a,#ffffff05);border-color:#ffffff14;color:var(--text-secondary);animation:none;box-shadow:0 1px 4px #00000014,0 0 0 1px #ffffff0d inset;font-weight:500}.recognition-recommendation-btn.increase{border-color:#ef535080;background:linear-gradient(135deg,#ef535026,#ef535014)}.recognition-recommendation-btn.increase:hover:not(:disabled){border-color:#ef5350b3;background:linear-gradient(135deg,#ef535040,#ef535026);box-shadow:0 6px 24px #ef53504d,0 0 30px #ef535033,0 0 0 1px #ef53504d inset}.recognition-recommendation-btn.decrease{border-color:#64b5f680;background:linear-gradient(135deg,#64b5f626,#64b5f614)}.recognition-recommendation-btn.decrease:hover:not(:disabled){border-color:#64b5f6b3;background:linear-gradient(135deg,#64b5f640,#64b5f626);box-shadow:0 6px 24px #64b5f64d,0 0 30px #64b5f633,0 0 0 1px #64b5f64d inset}.recommendation-content{display:inline-block;font-feature-settings:"tnum";letter-spacing:.025em}.recognition-adjust{min-width:100px;min-height:44px;padding:var(--space-sm) var(--space-md);font-size:var(--text-sm);font-weight:600;background:linear-gradient(135deg,#ffffff0d,#ffffff05);border:1.5px solid rgba(255,255,255,.08);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 2px 8px #0000001a,0 0 0 1px #ffffff0d inset;opacity:.7;display:flex;align-items:center;justify-content:center;gap:8px}.recognition-adjust:hover{background:linear-gradient(135deg,#ffffff14,#ffffff0a);transform:translateY(-2px);box-shadow:0 4px 16px #0003,0 0 0 1px #ffffff1a inset;opacity:.9;border-color:#ffffff1f}.recognition-adjust:focus{outline:none;box-shadow:0 0 0 3px #64b5f64d}.recognition-adjust:active{transform:translateY(0);background:#ffffff1a;box-shadow:0 1px 4px #0000004d inset,0 0 0 1px #ffffff26 inset;transition-duration:.1s}.recognition-adjust.recommended{background:linear-gradient(135deg,#ffffff1f,#ffffff0f);border-color:currentColor;color:var(--text-primary);animation:pulse-glow 2s ease-in-out infinite;opacity:1;box-shadow:0 4px 16px #00000026,0 0 20px #ffffff1a,0 0 0 1px #ffffff1a inset}.recognition-adjust.recommended:hover{background:linear-gradient(135deg,#ffffff29,#ffffff14);box-shadow:0 6px 24px #00000040,0 0 30px #ffffff26,0 0 0 1px #ffffff26 inset;opacity:1;transform:translateY(-3px)}.recognition-adjust.decrease{border-color:#64b5f666}.recognition-adjust.decrease.recommended{border-color:var(--accent-blue);color:var(--accent-blue);background:linear-gradient(135deg,#64b5f626,#64b5f614);box-shadow:0 4px 16px #64b5f640,0 0 20px #64b5f626,0 0 0 1px #64b5f633 inset}.recognition-adjust.increase{border-color:#ef535066}.recognition-adjust.increase.recommended{border-color:var(--error);color:var(--error);background:linear-gradient(135deg,#ef535026,#ef535014);box-shadow:0 4px 16px #ef535040,0 0 20px #ef535026,0 0 0 1px #ef535033 inset}@keyframes pulse-glow{0%,to{transform:scale(1);opacity:1;box-shadow:0 4px 16px #00000026,0 0 20px #ffffff1a,0 0 0 1px #ffffff1a inset}50%{transform:scale(1.03);opacity:.95;box-shadow:0 6px 24px #0003,0 0 30px #ffffff26,0 0 0 2px #ffffff26 inset}}.recognition-adjust svg{width:18px;height:18px;stroke:currentColor;stroke-width:3;flex-shrink:0;transition:transform .3s cubic-bezier(.4,0,.2,1)}.recognition-adjust:hover svg{transform:scale(1.1)}.recognition-adjust.decrease:hover svg{transform:translateY(2px)}.recognition-adjust.increase:hover svg{transform:translateY(-2px)}.recognition-adjust:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#fff6;transform:translate(-50%,-50%);transition:width .4s,height .4s}.recognition-adjust:active:after{width:200%;height:200%}.focus-queue{background:#ffffff05;border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg);backdrop-filter:blur(10px);will-change:transform}.gauge-title,.focus-queue-title,.practice-stream-title{font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-md)}.focus-queue-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--space-md)}.focus-char{background:#ffffff08;border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-md);text-align:center;transition:all .2s ease}.focus-char:hover{background:#ffffff0d;border-color:var(--border-default);transform:translateY(-2px);box-shadow:var(--shadow-subtle)}.focus-char-letter{font-size:var(--text-2xl);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-sm)}.focus-char-stats{font-size:var(--text-xs)}.focus-accuracy{position:relative;height:8px;background:#ffffff1a;border-radius:4px;margin-bottom:var(--space-xs);overflow:hidden}.focus-accuracy-bar{position:absolute;left:0;top:0;height:100%;background:var(--accent-blue);border-radius:2px;transition:width .3s ease}.focus-accuracy-text{color:var(--text-secondary);font-weight:500;margin-top:var(--space-xs);font-size:var(--text-sm)}.focus-confusion{color:var(--text-secondary);margin-top:var(--space-xs);font-size:var(--text-sm)}.focus-confusion strong{color:var(--text-secondary)}.confusion-matrix{background:#ffffff05;border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg);backdrop-filter:blur(10px);will-change:transform}.confusion-matrix-title{font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-md)}.confusion-pairs{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-md)}.confusion-pair-card{background:#ffffff08;border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-md);text-align:center;transition:all .2s ease;cursor:pointer}.confusion-pair-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-subtle)}.confusion-pair-card:focus{outline:2px solid currentColor;outline-offset:2px}.confusion-pair-card.low{border-color:#64b5f64d;background:#64b5f60d}.confusion-pair-card.medium{border-color:#ffa7264d;background:#ffa7260d}.confusion-pair-card.high{border-color:#ef53504d;background:#ef53500d}.confusion-chars{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);margin-bottom:var(--space-xs)}.confusion-char{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);text-shadow:0 1px 2px rgba(0,0,0,.2)}.confusion-separator{color:var(--text-tertiary);font-size:var(--text-sm)}.confusion-count{font-size:var(--text-xs);color:var(--text-secondary)}.practice-stream{background:#ffffff05;border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg);backdrop-filter:blur(10px);will-change:transform;max-width:100%;box-sizing:border-box;overflow:hidden}.practice-stream-scroll{overflow:hidden}.practice-stream-items{display:flex;flex-wrap:wrap;gap:var(--space-sm);padding-top:2px;max-width:100%}.stream-char{background:#ffffff08;border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-sm);text-align:center;min-width:70px;min-height:80px;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;justify-content:space-between;gap:4px}.stream-char:hover{background:#ffffff0d;transform:translateY(-1px)}.stream-char.good{border-color:#2ed57380;background:#2ed57314}.stream-char.struggling{border-color:#ef535080;background:#ef535014}.stream-char-letter{font-size:var(--text-lg);font-weight:600;color:var(--text-primary)}.sparkline{margin:2px 0;flex-shrink:0}.stream-char-accuracy{font-size:var(--text-sm);color:var(--text-primary);font-weight:500;opacity:.8;white-space:nowrap;flex-shrink:0}.focus-placeholder,.stream-placeholder{text-align:center;color:var(--text-secondary);font-size:var(--text-sm);padding:var(--space-sm);opacity:.7}.loading-dots{opacity:.5;animation:pulse 1.5s ease-in-out infinite}.focus-success{text-align:center;padding:var(--space-lg);opacity:.7}.success-icon{color:var(--accent-green);margin-bottom:var(--space-sm)}.success-message{color:var(--text-secondary);font-size:var(--text-sm);margin:0}@media (max-width: 768px){.gauge-container{padding:var(--space-md)}.gauge-svg{max-width:300px}.zone-status-text{font-size:.8125rem}.recognition-label{width:100%;text-align:center;margin-bottom:var(--space-xs);font-size:.875rem}.recognition-buttons{width:100%;justify-content:center;gap:16px}.recognition-adjust{min-width:110px;min-height:48px;padding:var(--space-sm) var(--space-md);font-size:.875rem}.focus-queue{padding:var(--space-md)}.focus-queue-grid{grid-template-columns:1fr;gap:var(--space-sm)}.focus-char{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm)}.focus-char-letter{font-size:var(--text-xl);min-width:3rem;margin-bottom:0;display:flex;align-items:center;justify-content:center}.focus-char-stats{flex:1;text-align:left}.confusion-matrix{padding:var(--space-md)}.confusion-pairs{grid-template-columns:1fr;gap:var(--space-sm)}.confusion-pair-card{padding:var(--space-sm);min-height:60px}.practice-stream{padding:var(--space-md)}.stream-char{min-width:56px;min-height:70px;padding:var(--space-xs)}.stream-char-letter{font-size:var(--text-base)}.sparkline{display:none}.stream-char-accuracy{font-size:var(--text-xs)}}@media (max-width: 480px){.gauge-container,.focus-queue,.practice-stream{padding:var(--space-sm)}.gauge-svg{max-width:100%;width:100%}.gauge-label{font-size:11px;letter-spacing:.04em}.gauge-label.training-zone{font-size:11px}.gauge-zone-status{font-size:12px}.gauge-accuracy tspan:first-child{font-size:36px}.gauge-accuracy tspan:last-child{font-size:18px}.gauge-title,.focus-queue-title,.practice-stream-title{font-size:var(--text-sm)}}@media (max-width: 768px) and (hover: none){.gauge-container,.focus-queue,.confusion-matrix,.practice-stream{backdrop-filter:blur(5px)}}
