:root{--bg-primary: #0f0a1a;--bg-secondary: #1a1225;--bg-tertiary: #241830;--bg-elevated: #2d2040;--bg-overlay: rgba(15, 10, 26, .85);--bg-glass: rgba(26, 18, 37, .7);--bg-glass-hover: rgba(36, 24, 48, .8);--text-primary: #f5f3f8;--text-secondary: #a8a0b5;--text-muted: #6d6580;--text-inverse: #0f0a1a;--text-accent: #c084fc;--border-primary: #3d2d55;--border-secondary: #2d2040;--border-focus: #a855f7;--border-glass: rgba(168, 85, 247, .2);--accent-primary: #a855f7;--accent-primary-hover: #c084fc;--accent-primary-active: #9333ea;--accent-primary-glow: rgba(168, 85, 247, .4);--accent-primary-subtle: rgba(168, 85, 247, .1);--accent-secondary: #818cf8;--accent-secondary-hover: #a5b4fc;--accent-secondary-subtle: rgba(129, 140, 248, .1);--accent-tertiary: #c084fc;--accent-tertiary-hover: #d8b4fe;--accent-success: #4ade80;--accent-success-hover: #86efac;--accent-success-subtle: rgba(74, 222, 128, .15);--accent-warning: #fbbf24;--accent-warning-hover: #fcd34d;--accent-warning-subtle: rgba(251, 191, 36, .15);--accent-error: #f87171;--accent-error-hover: #fca5a5;--accent-error-subtle: rgba(248, 113, 113, .15);--accent-info: #60a5fa;--accent-info-hover: #93c5fd;--accent-info-subtle: rgba(96, 165, 250, .15);--gradient-primary: linear-gradient(135deg, #a855f7 0%, #6366f1 100%);--gradient-primary-hover: linear-gradient(135deg, #c084fc 0%, #818cf8 100%);--gradient-accent: linear-gradient(135deg, #c084fc 0%, #f472b6 100%);--gradient-success: linear-gradient(135deg, #4ade80 0%, #22d3ee 100%);--gradient-dark: linear-gradient(180deg, #1a1225 0%, #0f0a1a 100%);--gradient-glow: radial-gradient(ellipse at center, rgba(168, 85, 247, .15) 0%, transparent 70%);--finger-pinky-left: #f472b6;--finger-ring-left: #fb923c;--finger-middle-left: #4ade80;--finger-index-left: #60a5fa;--finger-thumb: #a78bfa;--finger-index-right: #f472b6;--finger-middle-right: #2dd4bf;--finger-ring-right: #fbbf24;--finger-pinky-right: #a3e635;--key-default: #241830;--key-hover: #3d2d55;--key-active: #a855f7;--key-correct: #22c55e;--key-incorrect: #ef4444;--key-highlight: #a855f7;--key-gradient: linear-gradient(180deg, #2d2040 0%, #1a1225 100%);--key-border: #3d2d55;--key-shadow: 0 4px 0 #0f0a1a;--font-mono: "JetBrains Mono", "Fira Code", "Consolas", "Monaco", monospace;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-size-5xl: 3rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--letter-spacing-tight: -.025em;--letter-spacing-normal: 0;--letter-spacing-wide: .05em;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.25rem;--radius-3xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -2px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4), 0 4px 6px -4px rgba(0, 0, 0, .3);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .5), 0 8px 10px -6px rgba(0, 0, 0, .4);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .6);--shadow-glow: 0 0 20px rgba(168, 85, 247, .3);--shadow-glow-lg: 0 0 40px rgba(168, 85, 247, .4);--shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, .3);--shadow-colored: 0 10px 30px -5px rgba(168, 85, 247, .3);--shadow-card: 0 4px 20px rgba(0, 0, 0, .3), 0 0 0 1px rgba(168, 85, 247, .1);--glass-blur: blur(16px);--glass-blur-lg: blur(24px);--glass-bg: rgba(26, 18, 37, .6);--glass-border: rgba(168, 85, 247, .15);--transition-fast: .1s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--transition-slower: .5s ease;--transition-bounce: .5s cubic-bezier(.68, -.55, .265, 1.55);--transition-spring: .4s cubic-bezier(.175, .885, .32, 1.275);--z-dropdown: 100;--z-sticky: 200;--z-modal-backdrop: 300;--z-modal: 400;--z-tooltip: 500;--z-toast: 600;--sidebar-width: 260px;--header-height: 64px;--keyboard-max-width: 1000px;--content-max-width: 1400px;--key-size: 48px;--key-gap: 4px;--key-border-width: 1px}[data-theme=light],.theme-light{--bg-primary: #faf8fc;--bg-secondary: #f3f0f7;--bg-tertiary: #ebe6f2;--bg-elevated: #ffffff;--bg-overlay: rgba(250, 248, 252, .9);--bg-glass: rgba(255, 255, 255, .7);--bg-glass-hover: rgba(255, 255, 255, .85);--text-primary: #1a1225;--text-secondary: #5c5470;--text-muted: #8b8299;--text-inverse: #faf8fc;--text-accent: #9333ea;--border-primary: #e0dae8;--border-secondary: #ebe6f2;--border-focus: #9333ea;--border-glass: rgba(147, 51, 234, .2);--accent-primary: #9333ea;--accent-primary-hover: #a855f7;--accent-primary-active: #7c3aed;--accent-primary-glow: rgba(147, 51, 234, .3);--accent-primary-subtle: rgba(147, 51, 234, .08);--accent-secondary: #6366f1;--accent-secondary-hover: #818cf8;--accent-secondary-subtle: rgba(99, 102, 241, .08);--accent-tertiary: #a855f7;--accent-tertiary-hover: #c084fc;--accent-success: #22c55e;--accent-success-hover: #4ade80;--accent-success-subtle: rgba(34, 197, 94, .1);--accent-warning: #f59e0b;--accent-warning-hover: #fbbf24;--accent-warning-subtle: rgba(245, 158, 11, .1);--accent-error: #ef4444;--accent-error-hover: #f87171;--accent-error-subtle: rgba(239, 68, 68, .1);--accent-info: #3b82f6;--accent-info-hover: #60a5fa;--accent-info-subtle: rgba(59, 130, 246, .1);--gradient-primary: linear-gradient(135deg, #9333ea 0%, #6366f1 100%);--gradient-primary-hover: linear-gradient(135deg, #a855f7 0%, #818cf8 100%);--gradient-accent: linear-gradient(135deg, #a855f7 0%, #ec4899 100%);--gradient-success: linear-gradient(135deg, #22c55e 0%, #06b6d4 100%);--gradient-dark: linear-gradient(180deg, #f3f0f7 0%, #faf8fc 100%);--gradient-glow: radial-gradient(ellipse at center, rgba(147, 51, 234, .08) 0%, transparent 70%);--key-default: #ffffff;--key-hover: #f3f0f7;--key-active: #9333ea;--key-correct: #22c55e;--key-incorrect: #ef4444;--key-highlight: #9333ea;--key-gradient: linear-gradient(180deg, #ffffff 0%, #f3f0f7 100%);--key-border: #e0dae8;--key-shadow: 0 3px 0 #d4cce0;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .08), 0 2px 4px -2px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -4px rgba(0, 0, 0, .06);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .08);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .15);--shadow-glow: 0 0 20px rgba(147, 51, 234, .2);--shadow-glow-lg: 0 0 40px rgba(147, 51, 234, .25);--shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, .05);--shadow-colored: 0 10px 30px -5px rgba(147, 51, 234, .15);--shadow-card: 0 4px 20px rgba(0, 0, 0, .06), 0 0 0 1px rgba(147, 51, 234, .08);--glass-bg: rgba(255, 255, 255, .7);--glass-border: rgba(147, 51, 234, .12);--finger-pinky-left: #ec4899;--finger-ring-left: #f97316;--finger-middle-left: #22c55e;--finger-index-left: #3b82f6;--finger-thumb: #8b5cf6;--finger-index-right: #ec4899;--finger-middle-right: #14b8a6;--finger-ring-right: #f59e0b;--finger-pinky-right: #84cc16}@media (prefers-contrast: high){:root{--bg-primary: #000000;--bg-secondary: #0a0a0a;--text-primary: #ffffff;--border-primary: #ffffff;--accent-primary: #d946ef}}@media (prefers-reduced-motion: reduce){:root{--transition-fast: 0ms;--transition-normal: 0ms;--transition-slow: 0ms;--transition-slower: 0ms;--transition-bounce: 0ms;--transition-spring: 0ms}}.reduced-motion{--transition-fast: 0ms !important;--transition-normal: 0ms !important;--transition-slow: 0ms !important;--transition-slower: 0ms !important;--transition-bounce: 0ms !important;--transition-spring: 0ms !important}*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}html,body{height:100%}body{line-height:var(--line-height-normal);font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary)}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit;color:inherit}button{cursor:pointer;border:none;background:none}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight)}a{color:inherit;text-decoration:none}ul,ol{list-style:none}#app{isolation:isolate;min-height:100%;display:flex;flex-direction:column}:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}:focus:not(:focus-visible){outline:none}::selection{background-color:var(--accent-primary);color:var(--text-inverse)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-primary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}*{scrollbar-width:thin;scrollbar-color:var(--border-primary) var(--bg-secondary)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.app-container{display:grid;grid-template-rows:var(--header-height) 1fr;grid-template-columns:var(--sidebar-width) 1fr;grid-template-areas:"header header" "sidebar main";min-height:100vh;background:var(--bg-primary);position:relative}.app-container:before{content:"";position:fixed;inset:0;background:var(--gradient-glow);pointer-events:none;z-index:0}.app-header{grid-area:header;background:var(--bg-glass);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--glass-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-6);position:sticky;top:0;z-index:var(--z-sticky)}.header-logo{display:flex;align-items:center;gap:var(--space-3)}.header-logo-icon{width:36px;height:36px;background:var(--gradient-primary);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-glow)}.header-logo-icon svg{width:20px;height:20px;color:#fff}.header-logo-text{font-family:var(--font-mono);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--text-primary);letter-spacing:var(--letter-spacing-tight);background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-stats{display:flex;align-items:center;gap:var(--space-6)}.header-stat{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-4);background:var(--accent-primary-subtle);border-radius:var(--radius-lg);min-width:80px}.header-stat-value{font-family:var(--font-mono);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--accent-primary);line-height:1}.header-stat-label{font-size:var(--font-size-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);font-weight:var(--font-weight-medium)}.header-actions{display:flex;align-items:center;gap:var(--space-3)}.header-action-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-normal)}.header-action-btn:hover{background:var(--accent-primary-subtle);color:var(--accent-primary)}.header-action-btn svg{width:20px;height:20px}.app-sidebar{grid-area:sidebar;background:var(--bg-glass);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-right:1px solid var(--glass-border);padding:var(--space-4);overflow-y:auto;position:relative;z-index:1}.sidebar-section{margin-bottom:var(--space-6)}.sidebar-section-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);margin-bottom:var(--space-3);padding:0 var(--space-3)}.sidebar-nav{display:flex;flex-direction:column;gap:var(--space-1)}.sidebar-group{margin-bottom:var(--space-1)}.sidebar-group-header{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;border-radius:var(--radius-lg);transition:all var(--transition-normal);-webkit-user-select:none;user-select:none}.sidebar-group-header:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sidebar-group-header.has-active{color:var(--accent-primary)}.sidebar-group-icon{width:18px;height:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--accent-secondary)}.sidebar-group-icon svg{width:18px;height:18px}.sidebar-group-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-group-chevron{width:16px;height:16px;display:flex;align-items:center;justify-content:center;transition:transform var(--transition-normal);opacity:.5}.sidebar-group-chevron svg{width:100%;height:100%}.sidebar-group-chevron.rotated{transform:rotate(180deg)}.sidebar-group-items{max-height:0;overflow:hidden;transition:max-height var(--transition-slow);padding-left:var(--space-2)}.sidebar-group-items.visible{max-height:500px}.sidebar-nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:all var(--transition-normal);cursor:pointer;text-decoration:none;position:relative}.sidebar-nav-item:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:0;background:var(--accent-primary);border-radius:var(--radius-full);transition:height var(--transition-normal)}.sidebar-nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sidebar-nav-item.active{background:var(--accent-primary-subtle);color:var(--accent-primary)}.sidebar-nav-item.active:before{height:60%}.sidebar-nav-item-icon{width:18px;height:18px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.sidebar-nav-item-icon svg{width:18px;height:18px}.sidebar-nav-item-badge{margin-left:auto;padding:var(--space-1) var(--space-2);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);background:var(--accent-primary);color:#fff;border-radius:var(--radius-full);min-width:20px;text-align:center}.app-main{grid-area:main;padding:var(--space-8);overflow-y:auto;display:flex;flex-direction:column;align-items:center;position:relative;z-index:1}.app-main-content{width:100%;max-width:var(--content-max-width)}.page-header{margin-bottom:var(--space-8)}.page-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--text-primary);letter-spacing:var(--letter-spacing-tight);margin-bottom:var(--space-2)}.page-subtitle{font-size:var(--font-size-base);color:var(--text-secondary)}.stats-panel{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);width:100%;max-width:var(--keyboard-max-width);margin-bottom:var(--space-8)}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-6);width:100%;max-width:var(--content-max-width)}.section{margin-bottom:var(--space-8)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.section-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--text-primary)}.section-actions{display:flex;gap:var(--space-2)}.divider{height:1px;background:var(--border-primary);margin:var(--space-6) 0}.divider-vertical{width:1px;height:100%;background:var(--border-primary);margin:0 var(--space-4)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12);text-align:center}.empty-state-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:var(--accent-primary-subtle);border-radius:var(--radius-xl);color:var(--accent-primary);margin-bottom:var(--space-4)}.empty-state-icon svg{width:32px;height:32px}.empty-state-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin-bottom:var(--space-2)}.empty-state-description{font-size:var(--font-size-sm);color:var(--text-secondary);max-width:300px}@media (max-width: 1200px){.stats-panel{grid-template-columns:repeat(2,1fr)}}@media (max-width: 1024px){.app-container{grid-template-columns:200px 1fr}.app-sidebar{width:200px}.charts-grid{grid-template-columns:1fr}}@media (max-width: 768px){.app-container{grid-template-columns:1fr;grid-template-areas:"header" "main"}.app-sidebar{display:none}.app-main{padding:var(--space-4)}.stats-panel{grid-template-columns:repeat(2,1fr)}.header-stats{display:none}.page-title{font-size:var(--font-size-2xl)}}@media (max-width: 480px){.stats-panel{grid-template-columns:1fr}.header-logo-text{display:none}}.app-sidebar::-webkit-scrollbar,.app-main::-webkit-scrollbar{width:6px}.app-sidebar::-webkit-scrollbar-track,.app-main::-webkit-scrollbar-track{background:transparent}.app-sidebar::-webkit-scrollbar-thumb,.app-main::-webkit-scrollbar-thumb{background:var(--border-primary);border-radius:var(--radius-full)}.app-sidebar::-webkit-scrollbar-thumb:hover,.app-main::-webkit-scrollbar-thumb:hover{background:var(--border-focus)}*:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}::selection{background:var(--accent-primary-glow);color:var(--text-primary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);font-family:var(--font-sans);letter-spacing:var(--letter-spacing-normal);cursor:pointer;border:none;outline:none;position:relative;overflow:hidden;transition:all var(--transition-normal);white-space:nowrap}.btn:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-md),0 0 0 0 var(--accent-primary-glow)}.btn-primary:before{content:"";position:absolute;inset:0;background:var(--gradient-primary-hover);opacity:0;transition:opacity var(--transition-normal)}.btn-primary:hover:not(:disabled){box-shadow:var(--shadow-lg),var(--shadow-glow);transform:translateY(-1px)}.btn-primary:hover:not(:disabled):before{opacity:1}.btn-primary span,.btn-primary svg{position:relative;z-index:1}.btn-secondary{background:var(--bg-glass);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);color:var(--text-primary);border:1px solid var(--border-primary)}.btn-secondary:hover:not(:disabled){background:var(--bg-glass-hover);border-color:var(--border-focus);box-shadow:var(--shadow-md)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--accent-primary-subtle);color:var(--text-primary)}.btn-outline{background:transparent;color:var(--accent-primary);border:1px solid var(--accent-primary)}.btn-outline:hover:not(:disabled){background:var(--accent-primary-subtle);border-color:var(--accent-primary-hover)}.btn-danger{background:linear-gradient(135deg,var(--accent-error) 0%,#dc2626 100%);color:#fff;box-shadow:var(--shadow-md)}.btn-danger:hover:not(:disabled){box-shadow:var(--shadow-lg),0 0 20px #ef44444d;transform:translateY(-1px)}.btn-success{background:linear-gradient(135deg,var(--accent-success) 0%,#16a34a 100%);color:#fff;box-shadow:var(--shadow-md)}.btn-success:hover:not(:disabled){box-shadow:var(--shadow-lg),0 0 20px #4ade804d;transform:translateY(-1px)}.btn-warning{background:linear-gradient(135deg,var(--accent-warning) 0%,#d97706 100%);color:var(--text-inverse);box-shadow:var(--shadow-md)}.btn-warning:hover:not(:disabled){box-shadow:var(--shadow-lg),0 0 20px #fbbf244d;transform:translateY(-1px)}.btn-xs{padding:var(--space-1) var(--space-2);font-size:var(--font-size-xs);border-radius:var(--radius-sm)}.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm)}.btn-lg{padding:var(--space-4) var(--space-6);font-size:var(--font-size-base);border-radius:var(--radius-xl)}.btn-xl{padding:var(--space-5) var(--space-8);font-size:var(--font-size-lg);border-radius:var(--radius-xl)}.btn-icon{width:40px;height:40px;padding:0;border-radius:var(--radius-lg)}.btn-icon.btn-sm{width:32px;height:32px}.btn-icon.btn-lg{width:48px;height:48px}.btn-icon svg{width:20px;height:20px}.btn-icon.btn-sm svg{width:16px;height:16px}.btn-icon.btn-lg svg{width:24px;height:24px}.btn-icon-ghost{width:40px;height:40px;padding:0;background:transparent;color:var(--text-secondary);border-radius:var(--radius-lg)}.btn-icon-ghost:hover:not(:disabled){background:var(--accent-primary-subtle);color:var(--accent-primary)}.btn svg{width:18px;height:18px;flex-shrink:0}.btn-sm svg{width:16px;height:16px}.btn-lg svg{width:20px;height:20px}.btn-full{width:100%}.btn-group{display:inline-flex;border-radius:var(--radius-lg);overflow:hidden}.btn-group .btn{border-radius:0;border-right:1px solid rgba(255,255,255,.1)}.btn-group .btn:first-child{border-radius:var(--radius-lg) 0 0 var(--radius-lg)}.btn-group .btn:last-child{border-radius:0 var(--radius-lg) var(--radius-lg) 0;border-right:none}.btn-loading{position:relative;color:transparent!important;pointer-events:none}.btn-loading:after{content:"";position:absolute;width:18px;height:18px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:btn-spin .6s linear infinite}.btn-loading.btn-primary:after,.btn-loading.btn-danger:after,.btn-loading.btn-success:after{border-top-color:#fff}@keyframes btn-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.btn-pill{border-radius:var(--radius-full)}.btn-glow{animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:var(--shadow-md),0 0 0 0 var(--accent-primary-glow)}50%{box-shadow:var(--shadow-lg),var(--shadow-glow)}}.btn-tab{background:transparent;color:var(--text-secondary);border-radius:var(--radius-md);padding:var(--space-2) var(--space-4);font-weight:var(--font-weight-medium)}.btn-tab:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.btn-tab.active{background:var(--accent-primary-subtle);color:var(--accent-primary)}.btn-chip{padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-secondary)}.btn-chip:hover:not(:disabled){background:var(--accent-primary-subtle);color:var(--accent-primary)}.btn-chip.active{background:var(--accent-primary);color:#fff}.btn-link{background:none;color:var(--accent-primary);padding:0;text-decoration:none}.btn-link:hover:not(:disabled){color:var(--accent-primary-hover);text-decoration:underline}.btn-fab{width:56px;height:56px;border-radius:var(--radius-full);background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-xl),var(--shadow-glow);position:fixed;bottom:var(--space-6);right:var(--space-6);z-index:var(--z-sticky)}.btn-fab:hover:not(:disabled){transform:scale(1.05);box-shadow:var(--shadow-2xl),var(--shadow-glow-lg)}.btn-fab svg{width:24px;height:24px}.btn-split{display:inline-flex;border-radius:var(--radius-lg);overflow:hidden}.btn-split .btn-main{border-radius:var(--radius-lg) 0 0 var(--radius-lg);border-right:1px solid rgba(255,255,255,.2)}.btn-split .btn-dropdown{border-radius:0 var(--radius-lg) var(--radius-lg) 0;padding:var(--space-2)}.btn-text{background:transparent;color:var(--accent-primary);padding:var(--space-2)}.btn-text:hover:not(:disabled){background:var(--accent-primary-subtle)}.card{background:var(--bg-glass);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:var(--space-6);transition:all var(--transition-normal);position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent-primary-subtle),transparent);opacity:0;transition:opacity var(--transition-normal)}.card:hover{background:var(--bg-glass-hover);border-color:var(--border-focus);box-shadow:var(--shadow-card);transform:translateY(-2px)}.card:hover:before{opacity:1}.card-solid{background:var(--bg-secondary);backdrop-filter:none;-webkit-backdrop-filter:none;border:1px solid var(--border-primary)}.card-elevated{background:var(--bg-elevated);box-shadow:var(--shadow-lg)}.card-gradient{background:var(--gradient-dark);border:1px solid var(--border-glass)}.card-glow{box-shadow:var(--shadow-glow)}.card-glow:hover{box-shadow:var(--shadow-glow-lg)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4);padding-bottom:var(--space-4);border-bottom:1px solid var(--border-secondary)}.card-header-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--accent-primary-subtle);border-radius:var(--radius-lg);color:var(--accent-primary)}.card-header-icon svg{width:20px;height:20px}.card-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--text-primary);letter-spacing:var(--letter-spacing-tight)}.card-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary);margin-top:var(--space-1)}.card-description{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:var(--line-height-relaxed)}.card-body{flex:1}.card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border-secondary)}.stat-card{background:var(--bg-glass);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:var(--space-5);display:flex;flex-direction:column;align-items:center;gap:var(--space-2);text-align:center;transition:all var(--transition-normal);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:60%;height:2px;background:var(--gradient-primary);border-radius:var(--radius-full);opacity:0;transition:opacity var(--transition-normal)}.stat-card:hover{transform:translateY(-4px);border-color:var(--border-focus);box-shadow:var(--shadow-colored)}.stat-card:hover:before{opacity:1}.stat-card-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--accent-primary-subtle);border-radius:var(--radius-lg);color:var(--accent-primary);margin-bottom:var(--space-2)}.stat-card-icon svg{width:24px;height:24px}.stat-card-value{font-family:var(--font-mono);font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--text-primary);line-height:1;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-card-label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:var(--font-weight-medium)}.stat-card-trend{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.stat-card-trend.up{color:var(--accent-success)}.stat-card-trend.down{color:var(--accent-error)}.lesson-card{background:var(--bg-glass);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-3);transition:all var(--transition-normal);cursor:pointer;position:relative;overflow:hidden}.lesson-card:after{content:"";position:absolute;inset:0;background:var(--gradient-glow);opacity:0;transition:opacity var(--transition-normal);pointer-events:none}.lesson-card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-colored);transform:translateY(-2px)}.lesson-card:hover:after{opacity:1}.lesson-card.completed{border-color:var(--accent-success)}.lesson-card.completed:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-success)}.lesson-card.active{border-color:var(--accent-primary);box-shadow:var(--shadow-glow)}.lesson-card-header{display:flex;align-items:center;justify-content:space-between;position:relative;z-index:1}.lesson-card-level{font-family:var(--font-mono);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--accent-primary);background:var(--accent-primary-subtle);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}.lesson-card-badge{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-xs);color:var(--accent-success)}.lesson-card-badge svg{width:14px;height:14px}.lesson-card-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--text-primary);position:relative;z-index:1}.lesson-card-description{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:var(--line-height-normal);position:relative;z-index:1}.lesson-card-stats{display:flex;gap:var(--space-4);font-size:var(--font-size-xs);color:var(--text-muted);position:relative;z-index:1}.lesson-card-stat{display:flex;align-items:center;gap:var(--space-1)}.lesson-card-stat svg{width:14px;height:14px;color:var(--accent-secondary)}.lesson-card-progress{height:4px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden;position:relative;z-index:1}.lesson-card-progress-bar{height:100%;background:var(--gradient-primary);border-radius:var(--radius-full);transition:width var(--transition-slow)}.feature-card{background:var(--bg-glass);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4);transition:all var(--transition-normal);position:relative}.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl);border-color:var(--border-focus)}.feature-card-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);border-radius:var(--radius-lg);color:#fff;box-shadow:var(--shadow-glow)}.feature-card-icon svg{width:28px;height:28px}.feature-card-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--text-primary)}.feature-card-description{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:var(--line-height-relaxed)}.achievement-card{background:var(--bg-glass);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:var(--space-4);display:flex;align-items:center;gap:var(--space-4);transition:all var(--transition-normal)}.achievement-card:hover{border-color:var(--border-focus);box-shadow:var(--shadow-card)}.achievement-card.locked{opacity:.6}.achievement-card.legendary{border-color:var(--accent-warning);background:linear-gradient(135deg,var(--bg-glass) 0%,rgba(251,191,36,.1) 100%)}.achievement-card.epic{border-color:var(--accent-primary);background:linear-gradient(135deg,var(--bg-glass) 0%,var(--accent-primary-subtle) 100%)}.achievement-card-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--accent-primary-subtle);border-radius:var(--radius-lg);font-size:var(--font-size-2xl);flex-shrink:0}.achievement-card-content{flex:1;min-width:0}.achievement-card-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--text-primary)}.achievement-card-description{font-size:var(--font-size-sm);color:var(--text-secondary);margin-top:var(--space-1)}.achievement-card-xp{font-family:var(--font-mono);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--accent-warning)}.card-grid{display:grid;gap:var(--space-4)}.card-grid-2{grid-template-columns:repeat(2,1fr)}.card-grid-3{grid-template-columns:repeat(3,1fr)}.card-grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 1024px){.card-grid-4,.card-grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.card-grid-2,.card-grid-3,.card-grid-4{grid-template-columns:1fr}}.card-interactive{cursor:pointer}.card-interactive:active{transform:scale(.98)}.card-accent{border-left:3px solid var(--accent-primary)}.card-accent-success{border-left:3px solid var(--accent-success)}.card-accent-warning{border-left:3px solid var(--accent-warning)}.card-accent-error{border-left:3px solid var(--accent-error)}.keyboard-container{width:100%;max-width:var(--keyboard-max-width);background:var(--bg-glass);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-2xl);padding:var(--space-6);box-shadow:var(--shadow-xl);position:relative;overflow:hidden}.keyboard-container:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent-primary-subtle),transparent)}.keyboard{display:flex;flex-direction:column;gap:var(--key-gap)}.keyboard-row{display:flex;gap:var(--key-gap);justify-content:center}.key{display:flex;align-items:center;justify-content:center;min-width:var(--key-size);height:var(--key-size);background:var(--key-gradient);border:1px solid var(--key-border);border-radius:var(--radius-lg);font-family:var(--font-mono);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-primary);box-shadow:var(--key-shadow);transition:all var(--transition-fast);-webkit-user-select:none;user-select:none;position:relative;cursor:default}.key:before{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.08) 0%,transparent 100%);border-radius:var(--radius-lg) var(--radius-lg) 0 0;pointer-events:none}.key:hover{background:var(--key-hover);border-color:var(--border-focus);transform:translateY(-1px)}.key.active,.key.pressed{background:var(--key-active);color:#fff;transform:translateY(2px);box-shadow:none}.key.highlight{background:var(--gradient-primary);color:#fff;border-color:var(--accent-primary);box-shadow:var(--shadow-glow),var(--key-shadow);animation:key-pulse 1.5s ease-in-out infinite}@keyframes key-pulse{0%,to{box-shadow:var(--shadow-glow),var(--key-shadow)}50%{box-shadow:var(--shadow-glow-lg),var(--key-shadow)}}.key.correct{background:linear-gradient(135deg,var(--accent-success) 0%,#16a34a 100%);color:#fff;border-color:var(--accent-success);box-shadow:0 0 15px #4ade804d,var(--key-shadow)}.key.incorrect{background:linear-gradient(135deg,var(--accent-error) 0%,#dc2626 100%);color:#fff;border-color:var(--accent-error);animation:shake .3s ease;box-shadow:0 0 15px #f871714d,var(--key-shadow)}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.key-backspace{min-width:calc(var(--key-size) * 2)}.key-tab{min-width:calc(var(--key-size) * 1.5)}.key-caps{min-width:calc(var(--key-size) * 1.75)}.key-enter,.key-shift-left{min-width:calc(var(--key-size) * 2.25)}.key-shift-right{min-width:calc(var(--key-size) * 2.75)}.key-space{min-width:calc(var(--key-size) * 6)}.key-ctrl,.key-alt,.key-cmd{min-width:calc(var(--key-size) * 1.25)}.key-modifier{font-size:var(--font-size-xs);color:var(--text-secondary)}.key-label{display:flex;flex-direction:column;align-items:center;gap:2px}.key-label-main{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.key-label-sub{font-size:var(--font-size-xs);color:var(--text-muted)}.key[data-finger=pinky-left]{border-bottom:3px solid var(--finger-pinky-left)}.key[data-finger=ring-left]{border-bottom:3px solid var(--finger-ring-left)}.key[data-finger=middle-left]{border-bottom:3px solid var(--finger-middle-left)}.key[data-finger=index-left]{border-bottom:3px solid var(--finger-index-left)}.key[data-finger=thumb]{border-bottom:3px solid var(--finger-thumb)}.key[data-finger=index-right]{border-bottom:3px solid var(--finger-index-right)}.key[data-finger=middle-right]{border-bottom:3px solid var(--finger-middle-right)}.key[data-finger=ring-right]{border-bottom:3px solid var(--finger-ring-right)}.key[data-finger=pinky-right]{border-bottom:3px solid var(--finger-pinky-right)}.key.finger-highlight[data-finger=pinky-left]{background:#f472b64d}.key.finger-highlight[data-finger=ring-left]{background:#fb923c4d}.key.finger-highlight[data-finger=middle-left]{background:#4ade804d}.key.finger-highlight[data-finger=index-left]{background:#60a5fa4d}.key.finger-highlight[data-finger=thumb]{background:#a78bfa4d}.key.finger-highlight[data-finger=index-right]{background:#f472b64d}.key.finger-highlight[data-finger=middle-right]{background:#2dd4bf4d}.key.finger-highlight[data-finger=ring-right]{background:#fbbf244d}.key.finger-highlight[data-finger=pinky-right]{background:#a3e6354d}.key.home-key{position:relative}.key.home-key:after{content:"";position:absolute;bottom:8px;left:50%;transform:translate(-50%);width:6px;height:2px;background:var(--text-muted);border-radius:var(--radius-full)}.key.error-low{background:#4ade8033}.key.error-medium{background:#fbbf244d}.key.error-high{background:#f8717166}.keyboard-legend{display:flex;justify-content:center;gap:var(--space-6);margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border-secondary)}.keyboard-legend-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-xs);color:var(--text-muted)}.keyboard-legend-color{width:12px;height:12px;border-radius:var(--radius-sm)}.keyboard-container.minimal{background:transparent;border:none;box-shadow:none;padding:0}.keyboard-container.minimal .key{background:var(--bg-secondary);box-shadow:none;border:1px solid var(--border-primary)}.keyboard-container.minimal .key:before{display:none}@media (max-width: 900px){.keyboard-container{padding:var(--space-4)}:root{--key-size: 40px}}@media (max-width: 640px){:root{--key-size: 32px;--key-gap: 2px}.key{font-size:var(--font-size-xs);border-radius:var(--radius-md)}.keyboard-legend{flex-wrap:wrap;gap:var(--space-3)}}.modal-backdrop{position:fixed;inset:0;background:var(--bg-overlay);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);opacity:0;visibility:hidden;transition:opacity var(--transition-normal),visibility var(--transition-normal);padding:var(--space-4)}.modal-backdrop.open{opacity:1;visibility:visible}.modal{background:var(--bg-glass);backdrop-filter:var(--glass-blur-lg);-webkit-backdrop-filter:var(--glass-blur-lg);border:1px solid var(--glass-border);border-radius:var(--radius-2xl);box-shadow:var(--shadow-2xl),var(--shadow-glow);width:100%;max-width:500px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;transform:scale(.95) translateY(10px);transition:transform var(--transition-normal);position:relative}.modal-backdrop.open .modal{transform:scale(1) translateY(0)}.modal:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent-primary),transparent)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-secondary)}.modal-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--text-primary);letter-spacing:var(--letter-spacing-tight)}.modal-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary);margin-top:var(--space-1)}.modal-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-normal)}.modal-close:hover{background:var(--accent-primary-subtle);color:var(--accent-primary)}.modal-close svg{width:20px;height:20px}.modal-body{padding:var(--space-6);overflow-y:auto;flex:1}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-secondary)}.settings-modal{max-width:600px}.settings-content{padding:var(--space-4) var(--space-6)}.settings-section{margin-bottom:var(--space-6)}.settings-section:last-child{margin-bottom:0}.settings-section-title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin-bottom:var(--space-4);padding-bottom:var(--space-2);border-bottom:1px solid var(--border-secondary)}.settings-section-title svg{color:var(--accent-primary)}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) 0;gap:var(--space-4)}.settings-row+.settings-row{border-top:1px solid var(--border-secondary)}.settings-label{display:flex;flex-direction:column;gap:var(--space-1);flex:1}.settings-label>span:first-child{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-primary)}.settings-description{font-size:var(--font-size-xs);color:var(--text-muted)}.settings-select{min-width:140px;padding:var(--space-2) var(--space-3);background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-normal);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236d6580' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:32px}.settings-select:hover{border-color:var(--border-focus)}.settings-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-primary-subtle)}.settings-toggle{position:relative;width:48px;height:26px;cursor:pointer;flex-shrink:0}.toggle-slider{position:absolute;inset:0;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-full);transition:all var(--transition-normal)}.toggle-slider:before{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:var(--text-muted);border-radius:50%;transition:all var(--transition-normal)}.settings-toggle input:checked+.toggle-slider{background:var(--gradient-primary);border-color:var(--accent-primary)}.settings-toggle input:checked+.toggle-slider:before{transform:translate(22px);background:#fff}.settings-toggle input:focus-visible+.toggle-slider{box-shadow:0 0 0 2px var(--accent-primary-subtle)}.settings-range{width:120px;height:6px;-webkit-appearance:none;appearance:none;background:var(--bg-tertiary);border-radius:var(--radius-full);outline:none;cursor:pointer}.settings-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;background:var(--gradient-primary);border-radius:50%;cursor:pointer;box-shadow:var(--shadow-md);transition:transform var(--transition-fast)}.settings-range::-moz-range-thumb{width:18px;height:18px;background:var(--gradient-primary);border-radius:50%;cursor:pointer;border:none;box-shadow:var(--shadow-md)}.modal-confirm{text-align:center;max-width:400px}.modal-confirm .modal-body{padding:var(--space-8) var(--space-6)}.modal-confirm-icon{width:64px;height:64px;margin:0 auto var(--space-4);display:flex;align-items:center;justify-content:center;background:var(--accent-warning-subtle);border-radius:var(--radius-full);color:var(--accent-warning)}.modal-confirm-icon svg{width:32px;height:32px}.modal-confirm-icon.danger{background:var(--accent-error-subtle);color:var(--accent-error)}.modal-confirm-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin-bottom:var(--space-2)}.modal-confirm-message{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:var(--line-height-relaxed)}.modal-sm{max-width:360px}.modal-lg{max-width:700px}.modal-xl{max-width:900px}.modal-full{max-width:calc(100vw - 48px);max-height:calc(100vh - 48px)}@media (max-width: 640px){.modal-backdrop{padding:var(--space-2)}.modal{max-width:100%;border-radius:var(--radius-xl)}.modal-header,.modal-body,.modal-footer{padding-left:var(--space-4);padding-right:var(--space-4)}.settings-row{flex-direction:column;align-items:flex-start}.settings-select,.settings-range{width:100%}}.settings-select{min-width:160px;padding:var(--space-2) var(--space-3);background-color:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-sm);cursor:pointer;transition:border-color var(--transition-fast)}.settings-select:hover{border-color:var(--accent-primary)}.settings-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #58a6ff33}.settings-toggle{position:relative;display:inline-block;width:48px;height:26px;flex-shrink:0}.settings-toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-full);transition:all var(--transition-fast)}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:var(--text-secondary);border-radius:50%;transition:all var(--transition-fast)}.settings-toggle input:checked+.toggle-slider{background-color:var(--accent-primary);border-color:var(--accent-primary)}.settings-toggle input:checked+.toggle-slider:before{transform:translate(22px);background-color:#fff}.settings-toggle input:disabled+.toggle-slider{opacity:.5;cursor:not-allowed}.settings-range{width:120px;height:6px;background:var(--bg-tertiary);border-radius:var(--radius-full);outline:none;cursor:pointer;-webkit-appearance:none}.settings-range::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:var(--accent-primary);border-radius:50%;cursor:pointer;transition:transform var(--transition-fast)}.settings-range::-webkit-slider-thumb:hover{transform:scale(1.1)}.settings-range::-moz-range-thumb{width:18px;height:18px;background:var(--accent-primary);border-radius:50%;cursor:pointer;border:none}.settings-range:disabled{opacity:.5;cursor:not-allowed}.settings-range:disabled::-webkit-slider-thumb{cursor:not-allowed}.answer-input{display:flex;gap:var(--space-3)}.answer-input input{flex:1;padding:var(--space-3) var(--space-4);background-color:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:var(--font-size-base);color:var(--text-primary)}.answer-input input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #58a6ff33}.answer-input input:disabled{opacity:.6;cursor:not-allowed}.submit-btn{padding:var(--space-3) var(--space-5);background-color:var(--accent-primary);color:var(--text-inverse);border-radius:var(--radius-md);font-weight:var(--font-weight-medium);cursor:pointer;transition:background-color var(--transition-fast)}.submit-btn:hover:not(.disabled){background-color:var(--accent-primary-hover)}.submit-btn.disabled{opacity:.6;cursor:not-allowed}.toast-container{position:fixed;bottom:var(--space-6);right:var(--space-6);display:flex;flex-direction:column;gap:var(--space-3);z-index:var(--z-toast)}.toast{background-color:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-4);display:flex;align-items:center;gap:var(--space-3);min-width:300px;box-shadow:var(--shadow-lg);animation:slideIn .3s ease}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-icon{width:20px;height:20px;flex-shrink:0}.toast.success .toast-icon{color:var(--accent-success)}.toast.warning .toast-icon{color:var(--accent-warning)}.toast.error .toast-icon{color:var(--accent-error)}.toast.info .toast-icon{color:var(--accent-primary)}.toast-message{font-size:var(--font-size-sm);color:var(--text-primary);flex:1}.typing-container{width:100%;max-width:var(--content-max-width);display:flex;flex-direction:column;gap:var(--space-8)}.typing-text-display{background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-8);font-family:var(--font-mono);font-size:var(--font-size-2xl);line-height:var(--line-height-relaxed);min-height:200px;word-wrap:break-word;overflow-wrap:break-word;white-space:pre-wrap;max-width:100%;overflow-x:hidden}.typing-char{transition:color var(--transition-fast),background-color var(--transition-fast)}.typing-char.current{background-color:var(--accent-primary);color:var(--text-inverse);border-radius:2px}.typing-char.correct{color:var(--accent-success)}.typing-char.incorrect{color:var(--accent-error);background-color:#f8514933;border-radius:2px}.typing-char.upcoming{color:var(--text-muted)}@media (max-width: 768px){.typing-text-display{font-size:var(--font-size-xl);padding:var(--space-4)}}.progress-bar{width:100%;height:8px;background-color:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;background-color:var(--accent-primary);border-radius:var(--radius-full);transition:width var(--transition-normal)}.progress-bar-fill.success{background-color:var(--accent-success)}.progress-bar-fill.warning{background-color:var(--accent-warning)}.progress-bar-fill.error{background-color:var(--accent-error)}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-elevated) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;border-radius:var(--radius-md)}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.bounce{animation:bounce 1s ease infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.fade-enter{opacity:0;transform:translateY(10px)}.fade-enter-active{opacity:1;transform:translateY(0);transition:opacity .3s ease,transform .3s ease}.fade-exit{opacity:1}.fade-exit-active{opacity:0;transition:opacity .2s ease}.slide-up{animation:slideUp .3s ease-out}.slide-down{animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.slide-left{animation:slideLeft .3s ease-out}@keyframes slideLeft{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.slide-right{animation:slideRight .3s ease-out}@keyframes slideRight{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.scale-in{animation:scaleIn .2s ease-out}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.pop-in{animation:popIn .3s cubic-bezier(.68,-.55,.265,1.55)}@keyframes popIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.glow{box-shadow:0 0 20px #58a6ff4d}.glow-success{box-shadow:0 0 20px #3fb9504d}.glow-error{box-shadow:0 0 20px #f851494d}.glow-warning{box-shadow:0 0 20px #f0883e4d}.cursor-blink{animation:cursorBlink 1s step-end infinite}@keyframes cursorBlink{0%,to{opacity:1}50%{opacity:0}}.celebrate{animation:celebrate .6s ease}@keyframes celebrate{0%{transform:scale(1)}25%{transform:scale(1.1)}50%{transform:scale(.95)}75%{transform:scale(1.05)}to{transform:scale(1)}}.wpm-up{animation:wpmUp .3s ease}@keyframes wpmUp{0%{color:var(--accent-success);transform:translateY(0)}50%{transform:translateY(-5px)}to{color:var(--text-primary);transform:translateY(0)}}.wpm-down{animation:wpmDown .3s ease}@keyframes wpmDown{0%{color:var(--accent-error);transform:translateY(0)}50%{transform:translateY(5px)}to{color:var(--text-primary);transform:translateY(0)}}.achievement-unlock{animation:achievementUnlock .8s cubic-bezier(.68,-.55,.265,1.55)}@keyframes achievementUnlock{0%{opacity:0;transform:scale(.3) rotate(-10deg)}50%{opacity:1;transform:scale(1.1) rotate(5deg)}to{transform:scale(1) rotate(0)}}.ripple{position:relative;overflow:hidden}.ripple:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:#fff3;border-radius:50%;transform:translate(-50%,-50%);transition:width .3s ease,height .3s ease}.ripple:active:after{width:200%;height:200%}.focus-ring:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.hover-lift{transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.hover-lift:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.onboarding-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .3s ease}.onboarding-modal{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:16px;padding:48px;max-width:480px;width:90%;position:relative;animation:slideUp .4s ease;box-shadow:0 20px 60px #0006}.onboarding-skip{position:absolute;top:16px;right:16px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:8px;border-radius:8px;transition:all .2s ease}.onboarding-skip:hover{background:var(--bg-tertiary);color:var(--text-primary)}.onboarding-content{text-align:center;min-height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center}.onboarding-icon{font-size:64px;margin-bottom:24px;animation:bounceIn .5s ease}.onboarding-title{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:16px;line-height:1.3}.onboarding-description{font-size:16px;color:var(--text-secondary);line-height:1.6;margin-bottom:24px;max-width:380px}.onboarding-action{margin-top:8px}.onboarding-progress{display:flex;justify-content:center;gap:8px;margin:32px 0 24px}.onboarding-dot{width:10px;height:10px;border-radius:50%;background:var(--bg-tertiary);border:none;cursor:pointer;transition:all .3s ease;padding:0}.onboarding-dot:hover{background:var(--accent-secondary);transform:scale(1.2)}.onboarding-dot.active{background:var(--accent-primary);width:24px;border-radius:5px}.onboarding-actions{display:flex;justify-content:space-between;gap:16px}.onboarding-actions .btn{flex:1}.onboarding-prev:disabled{opacity:.3;cursor:not-allowed}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.1)}70%{transform:scale(.9)}to{opacity:1;transform:scale(1)}}@media (max-width: 480px){.onboarding-modal{padding:32px 24px;margin:16px}.onboarding-icon{font-size:48px}.onboarding-title{font-size:20px}.onboarding-description{font-size:14px}.onboarding-actions{flex-direction:column}}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-success{color:var(--accent-success)}.text-warning{color:var(--accent-warning)}.text-error{color:var(--accent-error)}.bg-primary{background-color:var(--bg-primary)}.bg-secondary{background-color:var(--bg-secondary)}.bg-tertiary{background-color:var(--bg-tertiary)}.font-mono{font-family:var(--font-mono)}.font-sans{font-family:var(--font-sans)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.w-full{width:100%}.h-full{height:100%}.hidden{display:none}.visible{visibility:visible}.invisible{visibility:hidden}.quiz-page-wrapper{width:100%;max-width:var(--content-max-width)}.quiz-page{width:100%}.quiz-header{text-align:center;margin-bottom:var(--space-8)}.quiz-header h1{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-2)}.quiz-header p{color:var(--text-secondary);font-size:var(--font-size-base)}.quiz-content{width:100%}.quiz-stats-overview{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);margin-bottom:var(--space-8)}.quiz-stats-overview .stat-card{text-align:center}.quiz-stats-overview .stat-value{font-family:var(--font-mono);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--accent-primary);display:block}.quiz-stats-overview .stat-label{font-size:var(--font-size-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.quiz-modes{margin-bottom:var(--space-8)}.quiz-modes h2{font-size:var(--font-size-xl);margin-bottom:var(--space-4)}.quiz-mode-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4)}.quiz-mode-card{background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-5);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.quiz-mode-card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-md)}.quiz-mode-card.featured{border-color:var(--accent-warning);background:linear-gradient(135deg,var(--bg-secondary) 0%,rgba(240,136,62,.1) 100%)}.quiz-mode-card .mode-icon{font-size:2.5rem;margin-bottom:var(--space-3)}.quiz-mode-card h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-2)}.quiz-mode-card p{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-4)}.mode-difficulty,.mode-categories{display:flex;flex-wrap:wrap;gap:var(--space-2)}.diff-btn,.cat-btn{padding:var(--space-2) var(--space-3);background-color:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);font-size:var(--font-size-xs);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.diff-btn:hover,.cat-btn:hover{background-color:var(--accent-primary);border-color:var(--accent-primary);color:var(--text-inverse)}.quiz-history{margin-bottom:var(--space-8)}.quiz-history h2{font-size:var(--font-size-xl);margin-bottom:var(--space-4)}.no-history{color:var(--text-muted);text-align:center;padding:var(--space-6)}.history-list{display:flex;flex-direction:column;gap:var(--space-3)}.history-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);border-left:4px solid var(--border-primary)}.history-item.success{border-left-color:var(--accent-success)}.history-item.warning{border-left-color:var(--accent-warning)}.history-item.error{border-left-color:var(--accent-error)}.history-type{font-weight:var(--font-weight-medium)}.history-stats{display:flex;gap:var(--space-4);font-size:var(--font-size-sm);color:var(--text-secondary)}.history-date{font-size:var(--font-size-sm);color:var(--text-muted)}.quiz-question-container{width:100%;max-width:700px;margin:0 auto}.quiz-progress{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6)}.quiz-progress .progress-bar{flex:1;height:8px;background-color:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.quiz-progress .progress-fill{height:100%;background-color:var(--accent-primary);transition:width var(--transition-normal)}.progress-text{font-family:var(--font-mono);font-size:var(--font-size-sm);color:var(--text-secondary);white-space:nowrap}.timer{font-family:var(--font-mono);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--text-primary);padding:var(--space-2) var(--space-3);background-color:var(--bg-tertiary);border-radius:var(--radius-md)}.timer.warning{color:var(--accent-error);background-color:#f851491a;animation:pulse 1s infinite}.question-card{background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-4)}.question-card.beginner{border-left:4px solid var(--accent-success)}.question-card.intermediate{border-left:4px solid var(--accent-warning)}.question-card.advanced{border-left:4px solid var(--accent-error)}.question-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);flex-wrap:wrap}.question-category{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--accent-primary);background-color:#58a6ff1a;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm)}.question-points{font-size:var(--font-size-xs);color:var(--text-muted)}.question-difficulty{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm)}.difficulty-beginner{background-color:#3fb9501a;color:var(--accent-success)}.difficulty-intermediate{background-color:#f0883e1a;color:var(--accent-warning)}.difficulty-advanced{background-color:#f851491a;color:var(--accent-error)}.question-text{margin-bottom:var(--space-6)}.question-text pre{font-family:var(--font-mono);font-size:var(--font-size-lg);line-height:var(--line-height-relaxed);white-space:pre-wrap;word-wrap:break-word}.question-hint{font-size:var(--font-size-sm);color:var(--text-muted);margin-top:var(--space-4);padding:var(--space-3);background-color:var(--bg-tertiary);border-radius:var(--radius-md)}.answer-options{display:flex;flex-direction:column;gap:var(--space-3)}.answer-option{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background-color:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left}.answer-option:hover:not(.disabled){border-color:var(--accent-primary);background-color:#58a6ff1a}.answer-option.disabled{cursor:not-allowed;opacity:.7}.answer-option.correct-answer{border-color:var(--accent-success);background-color:#3fb9501a}.answer-option.wrong-answer{border-color:var(--accent-error);background-color:#f851491a}.option-letter{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background-color:var(--bg-secondary);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);flex-shrink:0}.option-text{font-size:var(--font-size-sm)}.result-feedback{margin-top:var(--space-4)}.result-feedback.hidden{display:none}.feedback-content{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-md);margin-bottom:var(--space-4)}.feedback-content.correct{background-color:#3fb9501a;border:1px solid var(--accent-success)}.feedback-content.incorrect{background-color:#f851491a;border:1px solid var(--accent-error)}.feedback-icon{font-size:1.5rem}.feedback-text{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.next-btn{width:100%;padding:var(--space-3) var(--space-4);background-color:var(--accent-primary);color:var(--text-inverse);border-radius:var(--radius-md);font-weight:var(--font-weight-medium);cursor:pointer;transition:background-color var(--transition-fast)}.next-btn:hover{background-color:var(--accent-primary-hover)}.quiz-results{text-align:center;max-width:600px;margin:0 auto}.results-header{margin-bottom:var(--space-6)}.grade-display{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-2)}.grade-a{color:var(--accent-success)}.grade-b{color:#4ade80}.grade-c{color:var(--accent-warning)}.grade-d{color:#fb923c}.grade-f{color:var(--accent-error)}.results-stats{display:flex;justify-content:center;gap:var(--space-6);margin-bottom:var(--space-8)}.result-stat{display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.result-stat .stat-value{font-family:var(--font-mono);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--text-primary)}.result-stat .stat-label{font-size:var(--font-size-sm);color:var(--text-secondary)}.results-details{background-color:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-5);margin-bottom:var(--space-6);text-align:left}.results-details h3{font-size:var(--font-size-base);margin-bottom:var(--space-4)}.question-results{display:flex;flex-direction:column;gap:var(--space-2);max-height:300px;overflow-y:auto}.question-result{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);background-color:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:var(--font-size-sm)}.question-result.correct{border-left:3px solid var(--accent-success)}.question-result.incorrect{border-left:3px solid var(--accent-error)}.result-icon{flex-shrink:0}.result-question{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-secondary)}.result-answer{font-family:var(--font-mono);font-size:var(--font-size-xs);color:var(--text-muted)}.results-actions{display:flex;gap:var(--space-4);justify-content:center}.action-btn{padding:var(--space-3) var(--space-6);border-radius:var(--radius-md);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast)}.action-btn.primary{background-color:var(--accent-primary);color:var(--text-inverse)}.action-btn.primary:hover{background-color:var(--accent-primary-hover)}.action-btn.secondary{background-color:var(--bg-tertiary);border:1px solid var(--border-primary);color:var(--text-primary)}.action-btn.secondary:hover{background-color:var(--bg-elevated)}.quiz-error{text-align:center;padding:var(--space-8);color:var(--text-secondary)}.quiz-error p{margin-bottom:var(--space-4)}@media (max-width: 768px){.quiz-stats-overview{grid-template-columns:repeat(2,1fr)}.quiz-mode-grid{grid-template-columns:1fr}.history-item{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.results-stats{flex-direction:column;gap:var(--space-4)}.results-actions{flex-direction:column}.action-btn{width:100%}}@media (max-width: 768px){:root{--key-size: 40px;--space-8: 1.5rem}.keyboard-container{padding:var(--space-4)}}@media (max-width: 480px){:root{--key-size: 32px;--key-gap: 2px}.key{font-size:var(--font-size-xs)}}
