@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-md: 1.0625rem;--text-lg: 1.25rem;--text-xl: 1.5rem;--text-2xl: 1.875rem;--text-3xl: 2.25rem;--text-4xl: 3rem;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 32px;--space-8: 48px;--space-9: 64px;--primary: #10B981;--primary-dark: #059669;--primary-light: #34D399;--primary-soft: rgba(16, 185, 129, .1);--primary-glow: rgba(16, 185, 129, .35);--primary-ghost: rgba(16, 185, 129, .1);--primary-glass: rgba(16, 185, 129, .06);--secondary: #3B82F6;--secondary-soft: rgba(59, 130, 246, .1);--secondary-ghost: rgba(59, 130, 246, .1);--secondary-glow: rgba(59, 130, 246, .35);--accent: #8B5CF6;--accent-soft: rgba(139, 92, 246, .1);--accent-ghost: rgba(139, 92, 246, .1);--accent-glow: rgba(139, 92, 246, .35);--warning: #F59E0B;--warning-soft: rgba(245, 158, 11, .12);--warning-ghost: rgba(245, 158, 11, .12);--warning-glow: rgba(245, 158, 11, .35);--danger: #EF4444;--danger-soft: rgba(239, 68, 68, .1);--danger-ghost: rgba(239, 68, 68, .1);--danger-glow: rgba(239, 68, 68, .35);--success: #10B981;--success-glow: rgba(16, 185, 129, .35);--golden: #F59E0B;--golden-glow: rgba(245, 158, 11, .4);--bg: #FAFAFA;--bg-app: #F4F4F5;--bg-surface: #FFFFFF;--bg-elevated: #FFFFFF;--bg-secondary: #F4F4F5;--bg-tertiary: #EFEFF1;--bg-quaternary: #E4E4E7;--text: #0A0A0A;--text-primary: #0A0A0A;--text-secondary: #52525B;--text-tertiary: #71717A;--text-muted: #A1A1AA;--text-inverse: #FFFFFF;--text-link: #2563EB;--border: rgba(0, 0, 0, .08);--border-light: rgba(0, 0, 0, .05);--border-strong: rgba(0, 0, 0, .14);--border-focus: rgba(16, 185, 129, .55);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 12px 28px rgba(0, 0, 0, .12);--shadow-float: 0 8px 32px rgba(0, 0, 0, .1);--shadow-glow-primary: 0 6px 24px var(--primary-glow);--shadow-glow-secondary: 0 6px 24px var(--secondary-glow);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-2xl: 28px;--radius-full: 9999px;--header-height: 56px;--tab-bar-height: 64px;--max-width: 480px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--content-padding-x: 20px;--touch-target: 44px;--touch-target-lg: 52px;--touch-target-xl: 56px;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--ease-smooth: cubic-bezier(.4, 0, .2, 1);--t-instant: .1s var(--ease-smooth);--t-fast: .18s var(--ease-smooth);--t-base: .25s var(--ease-out);--t-slow: .4s var(--ease-out);--t-slower: .6s var(--ease-out);--blur-sm: blur(8px) saturate(160%);--blur-md: blur(12px) saturate(160%);--blur-lg: blur(20px) saturate(160%);--blur-xl: blur(28px) saturate(160%)}[data-theme=dark]{--bg: #0A0A0A;--bg-app: #050505;--bg-surface: #141416;--bg-elevated: #18181B;--bg-secondary: #1F1F22;--bg-tertiary: #27272A;--bg-quaternary: #303034;--text: #FAFAFA;--text-primary: #FAFAFA;--text-secondary: #A1A1AA;--text-tertiary: #71717A;--text-muted: #52525B;--text-inverse: #0A0A0A;--text-link: #60A5FA;--border: rgba(255, 255, 255, .08);--border-light: rgba(255, 255, 255, .05);--border-strong: rgba(255, 255, 255, .14);--border-focus: rgba(52, 211, 153, .55);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .3);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .35);--shadow-md: 0 4px 12px rgba(0, 0, 0, .45);--shadow-lg: 0 12px 28px rgba(0, 0, 0, .55);--shadow-float: 0 12px 36px rgba(0, 0, 0, .6)}@media (prefers-color-scheme: dark){[data-theme=system]{--bg: #0A0A0A;--bg-app: #050505;--bg-surface: #141416;--bg-elevated: #18181B;--bg-secondary: #1F1F22;--bg-tertiary: #27272A;--bg-quaternary: #303034;--text: #FAFAFA;--text-primary: #FAFAFA;--text-secondary: #A1A1AA;--text-tertiary: #71717A;--text-muted: #52525B;--text-inverse: #0A0A0A;--border: rgba(255, 255, 255, .08);--border-light: rgba(255, 255, 255, .05);--border-strong: rgba(255, 255, 255, .14);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .35);--shadow-md: 0 4px 12px rgba(0, 0, 0, .45);--shadow-lg: 0 12px 28px rgba(0, 0, 0, .55);--shadow-float: 0 12px 36px rgba(0, 0, 0, .6)}}*,*:before,*:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;-webkit-text-size-adjust:100%;text-size-adjust:100%}body{margin:0;padding:0;min-height:100vh;min-height:100dvh;background:var(--bg-app);color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;font-weight:400;font-size:var(--text-base);letter-spacing:-.005em;line-height:1.5;overscroll-behavior-y:contain;transition:background var(--t-base),color var(--t-base)}button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}button{border:none;background:none;cursor:pointer;padding:0;margin:0}h1,h2,h3,h4,h5,h6,.brand-font{font-family:Inter,sans-serif;font-weight:700;letter-spacing:-.02em;line-height:1.2;margin:0;color:var(--text-primary)}#root{min-height:100vh;min-height:100dvh;display:flex;justify-content:center;background:var(--bg-app)}:focus{outline:none}:focus-visible{outline:none;box-shadow:0 0 0 3px var(--border-focus);border-radius:inherit}::selection{background:var(--primary);color:#fff}.skip-link{position:absolute;top:-100px;left:12px;z-index:10000;background:var(--text-primary);color:var(--text-inverse);padding:12px 18px;border-radius:var(--radius-md);font-weight:600;font-size:var(--text-sm);text-decoration:none;transition:top var(--t-fast)}.skip-link:focus{top:12px}@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{width:100%;max-width:var(--max-width);min-height:100vh;min-height:100dvh;background:var(--bg);display:flex;flex-direction:column;position:relative;overflow:hidden;padding-top:var(--safe-top)}@media (min-width: 520px){.app-container{min-height:100vh;margin:0 auto;border-left:1px solid var(--border);border-right:1px solid var(--border)}}.main-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--space-5) var(--content-padding-x);padding-bottom:calc(var(--tab-bar-height) + var(--safe-bottom) + var(--space-7));-webkit-overflow-scrolling:touch;scroll-behavior:smooth}.header{height:var(--header-height);padding:0 var(--content-padding-x);display:flex;align-items:center;justify-content:space-between;background:var(--bg);border-bottom:1px solid var(--border-light);position:sticky;top:0;z-index:100}.header-logo{font-weight:800;font-size:var(--text-lg);color:var(--primary);letter-spacing:-.03em;display:flex;align-items:center;gap:8px}.theme-toggle{width:44px;height:44px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--bg-surface);display:flex;align-items:center;justify-content:center;color:var(--text-primary);transition:background var(--t-fast),border-color var(--t-fast)}.theme-toggle:active{background:var(--bg-tertiary)}.tab-bar{position:fixed;bottom:0;left:0;right:0;max-width:var(--max-width);margin:0 auto;height:calc(var(--tab-bar-height) + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:var(--bg);border-top:1px solid var(--border);display:flex;justify-content:space-around;align-items:stretch;z-index:100;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px)}@media (min-width: 520px){.tab-bar{border-left:1px solid var(--border);border-right:1px solid var(--border)}}.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;min-height:var(--touch-target);color:var(--text-tertiary);font-size:11px;font-weight:600;letter-spacing:.01em;transition:color var(--t-fast);position:relative;touch-action:manipulation}.tab-item svg{width:24px;height:24px;stroke-width:2;transition:transform var(--t-fast)}.tab-item.is-active{color:var(--primary)}.tab-item.is-active svg{transform:translateY(-1px);stroke-width:2.4}.tab-item.is-active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:28px;height:3px;background:var(--primary);border-radius:0 0 3px 3px}.tab-item:active{opacity:.6}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;min-height:var(--touch-target-lg);border-radius:var(--radius-md);font-size:var(--text-md);font-weight:600;font-family:inherit;border:1px solid transparent;cursor:pointer;transition:background var(--t-fast),border-color var(--t-fast),transform var(--t-instant),box-shadow var(--t-fast);text-decoration:none;user-select:none;-webkit-user-select:none;touch-action:manipulation;letter-spacing:-.01em}.btn:active{transform:scale(.98)}.btn--primary{background:var(--primary);color:#fff;font-weight:700;box-shadow:var(--shadow-sm)}.btn--primary:hover,.btn--primary:active{background:var(--primary-dark)}.btn--secondary{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border)}.btn--secondary:hover{background:var(--bg-quaternary)}.btn--danger{background:var(--danger-soft);color:var(--danger);border-color:#ef444433}.btn--danger.btn--3d{background:var(--bg-surface);border:1px solid rgba(239,68,68,.25);color:var(--danger)}.btn--ghost{background:transparent;color:var(--text-secondary);padding:10px;min-height:var(--touch-target);border-radius:var(--radius-full)}.btn--ghost:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn--ghost:active{background:var(--bg-quaternary)}.btn--block{width:100%}.btn--sm{min-height:var(--touch-target);padding:10px 18px;font-size:var(--text-sm)}.btn--lg{min-height:var(--touch-target-xl);padding:18px 28px;font-size:var(--text-md);border-radius:var(--radius-lg)}.glass-card{background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.home-topbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-3)}.home-topbar__greet{display:flex;flex-direction:column;gap:2px;min-width:0}.home-topbar__hello{font-weight:700;font-size:var(--text-lg);letter-spacing:-.02em;color:var(--text-primary)}.home-topbar__subline{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.home-topbar__chips{display:flex;gap:6px;flex-shrink:0}.status-chip{display:inline-flex;align-items:center;gap:4px;height:28px;padding:0 10px;border-radius:var(--radius-full);background:var(--warning-soft);color:var(--warning);font-size:var(--text-sm);font-weight:700;letter-spacing:-.01em}.status-chip--xp{background:var(--secondary-soft);color:var(--secondary)}.home-daily{height:4px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--space-5)}.home-daily__fill{height:100%;background:var(--primary);border-radius:var(--radius-full)}.home-hero{display:flex;flex-direction:column;gap:4px;width:100%;text-align:left;padding:var(--space-5);background:var(--text-primary);color:var(--bg);border-radius:var(--radius-xl);border:none;cursor:pointer;margin-bottom:var(--space-6);transition:transform var(--t-instant),box-shadow var(--t-fast);box-shadow:var(--shadow-md);position:relative;overflow:hidden}.home-hero:active{transform:scale(.99)}.home-hero:after{content:"";position:absolute;top:-40%;right:-20%;width:70%;height:200%;background:radial-gradient(ellipse at center,var(--primary-glow) 0%,transparent 60%);opacity:.4;pointer-events:none}.home-hero__eyebrow{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--primary-light);position:relative;z-index:1}.home-hero__title{font-weight:800;font-size:var(--text-xl);letter-spacing:-.025em;line-height:1.15;margin-top:4px;position:relative;z-index:1}.home-hero__meta{display:flex;gap:6px;color:#fff9;font-size:var(--text-sm);font-weight:500;margin-top:4px;position:relative;z-index:1}[data-theme=dark] .home-hero__meta,[data-theme=system] .home-hero__meta{color:#0000008c}.home-hero__cta{display:inline-flex;align-items:center;gap:8px;margin-top:var(--space-4);height:44px;padding:0 18px;background:var(--primary);color:#fff;border-radius:var(--radius-full);font-weight:700;font-size:var(--text-md);width:fit-content;position:relative;z-index:1}.quick-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.quick-action{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:var(--space-4);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);text-align:left;cursor:pointer;transition:background var(--t-fast),border-color var(--t-fast);min-height:var(--touch-target-xl)}.quick-action:active{background:var(--bg-tertiary)}.quick-action__icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:4px}.quick-action__label{font-weight:700;font-size:var(--text-md);color:var(--text-primary);letter-spacing:-.01em}.quick-action__count{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.daily-progress-banner{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);margin-bottom:var(--space-5);background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border)}.daily-progress-banner__content{flex:1;min-width:0}.daily-progress-banner__title{font-weight:700;font-size:var(--text-md);color:var(--text-primary);letter-spacing:-.01em;margin-bottom:2px}.daily-progress-banner__subtitle{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500;margin-bottom:var(--space-2)}.daily-progress-banner__bar{height:6px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.daily-progress-banner__bar-fill{height:100%;background:var(--primary);border-radius:var(--radius-full)}.progress-ring{position:relative;width:64px;height:64px;flex-shrink:0}.progress-ring__circle{transform:rotate(-90deg);transform-origin:50% 50%}.progress-ring__bg{fill:none;stroke:var(--bg-tertiary);stroke-width:5}.progress-ring__fill{fill:none;stroke:var(--primary);stroke-width:5;stroke-linecap:round}.progress-ring__text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--text-md);color:var(--text-primary)}.streak-banner{background:linear-gradient(135deg,var(--warning) 0%,#F97316 100%);border-radius:var(--radius-lg);padding:var(--space-4);display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);box-shadow:var(--shadow-md);color:#fff}.streak-banner__icon{font-size:28px}.streak-banner__content{flex:1}.streak-banner__title{font-weight:800;font-size:var(--text-md);color:#fff}.streak-banner__subtitle{font-size:var(--text-sm);color:#ffffffe6;margin-top:2px}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2);margin-bottom:var(--space-5)}.stat-item{padding:var(--space-3) var(--space-2);text-align:center;border-radius:var(--radius-md);background:var(--bg-surface);border:1px solid var(--border);transition:background var(--t-fast)}.stat-item:active{background:var(--bg-tertiary)}.stat-item__value{font-weight:800;font-size:var(--text-lg);color:var(--text-primary);display:flex;align-items:center;justify-content:center;gap:4px;line-height:1}.stat-item__label{font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;margin-top:6px}.section{margin-bottom:var(--space-6)}.section__header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:var(--space-3);gap:var(--space-3)}.section__title{font-weight:700;font-size:var(--text-lg);color:var(--text-primary);letter-spacing:-.02em}.section__hint{font-size:var(--text-sm);color:var(--text-tertiary);font-weight:500}.lesson-card{padding:var(--space-4);margin-bottom:var(--space-2);display:flex;align-items:center;gap:var(--space-3);border-radius:var(--radius-lg);background:var(--bg-surface);border:1px solid var(--border);transition:background var(--t-fast),border-color var(--t-fast),transform var(--t-instant);position:relative;touch-action:manipulation;min-height:var(--touch-target-xl)}.lesson-card:hover{border-color:var(--border-strong)}.lesson-card:active{background:var(--bg-tertiary);transform:scale(.99)}.lesson-card__icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;background:var(--bg-tertiary)}.lesson-card__content{flex:1;min-width:0}.lesson-card__title{font-weight:600;font-size:var(--text-md);color:var(--text-primary);letter-spacing:-.01em;margin-bottom:2px}.lesson-card__meta{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.lesson-card__arrow{width:32px;height:32px;border-radius:var(--radius-full);background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);flex-shrink:0}.quiz-screen{height:100%;height:100dvh;display:flex;flex-direction:column;background:var(--bg);padding-top:var(--safe-top);padding-bottom:var(--safe-bottom)}.quiz-header{padding:var(--space-3) var(--content-padding-x);display:flex;align-items:center;gap:var(--space-3);height:var(--header-height)}.quiz-progress{flex:1;height:6px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.quiz-progress__fill{height:100%;background:var(--primary);border-radius:var(--radius-full)}.quiz-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:var(--space-5) var(--content-padding-x) var(--space-5);text-align:center}.quiz-word{font-weight:800;font-size:var(--text-4xl);margin-bottom:var(--space-3);letter-spacing:-.03em;color:var(--text-primary);line-height:1.1;word-break:break-word;-webkit-hyphens:auto;hyphens:auto}.quiz-answer{font-size:var(--text-xl);color:var(--primary);font-weight:700;letter-spacing:-.02em}.quiz-sound-btn{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-full);width:64px;height:64px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;gap:0;color:var(--text-primary);transition:background var(--t-fast),border-color var(--t-fast);touch-action:manipulation}.quiz-sound-btn:active{background:var(--bg-tertiary)}.quiz-sound-btn.is-playing{background:var(--primary-soft);border-color:var(--primary);color:var(--primary)}.quiz-answer-buttons{display:flex;gap:var(--space-3);width:100%}.quiz-answer-btn{flex:1;min-height:var(--touch-target-xl);padding:18px var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-md);font-weight:700;display:flex;align-items:center;justify-content:center;gap:8px;transition:background var(--t-fast),border-color var(--t-fast),transform var(--t-instant);border:1px solid transparent;cursor:pointer;touch-action:manipulation}.quiz-answer-btn:active{transform:scale(.97)}.quiz-answer-btn--wrong{background:var(--danger-soft);color:var(--danger);border-color:#ef44442e}.quiz-answer-btn--wrong:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.quiz-answer-btn--correct{background:var(--primary);color:#fff;border-color:var(--primary)}.quiz-answer-btn--correct:hover{background:var(--primary-dark)}.session-complete{height:100%;height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-6) var(--content-padding-x);background:var(--bg);padding-top:calc(var(--safe-top) + var(--space-7));padding-bottom:calc(var(--safe-bottom) + var(--space-6))}.session-complete__emoji{font-size:88px;margin-bottom:var(--space-5)}.session-complete__title{font-weight:800;font-size:var(--text-3xl);margin-bottom:var(--space-4);text-align:center;color:var(--text-primary);letter-spacing:-.03em;line-height:1.1}.session-complete__stats{display:flex;gap:var(--space-3);margin:var(--space-5) 0;width:100%;max-width:340px}.session-complete__stat{flex:1;padding:var(--space-4) var(--space-3);text-align:center;background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border)}.session-complete__stat-value{font-size:var(--text-2xl);font-weight:800;line-height:1;letter-spacing:-.02em}.session-complete__stat-label{font-size:11px;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;margin-top:8px}.session-complete__progress-bar{width:100%;max-width:340px;height:8px;background:var(--bg-tertiary);border-radius:var(--radius-full);margin-bottom:var(--space-6);overflow:hidden}.onboarding{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;padding:var(--space-7) var(--content-padding-x) calc(var(--safe-bottom) + var(--space-6));padding-top:calc(var(--safe-top) + var(--space-7));background:var(--bg)}.onboarding__step{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:var(--space-3)}.onboarding__illustration{font-size:88px;margin-bottom:var(--space-3)}.onboarding__title{font-weight:800;font-size:var(--text-2xl);color:var(--text-primary);letter-spacing:-.03em;line-height:1.15;margin-bottom:4px}.onboarding__subtitle{color:var(--text-secondary);font-size:var(--text-md);max-width:320px;line-height:1.5}.onboarding__actions{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-6)}.onboarding__dots{display:flex;justify-content:center;gap:6px;margin-top:var(--space-4)}.onboarding__dot{width:8px;height:8px;border-radius:var(--radius-full);background:var(--bg-tertiary);transition:width var(--t-base),background var(--t-base)}.onboarding__dot--active{width:24px;background:var(--primary)}.option-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3);width:100%;max-width:320px;margin-top:var(--space-5)}.option-card{padding:var(--space-5) var(--space-3);background:var(--bg-surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer;transition:border-color var(--t-fast),background var(--t-fast);min-height:var(--touch-target-xl)}.option-card.is-selected{border-color:var(--primary);background:var(--primary-soft)}.option-card__label{font-weight:800;font-size:var(--text-2xl);color:var(--text-primary);letter-spacing:-.02em;line-height:1}.vocabulary-hero{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;padding:var(--space-5) var(--space-5);border-radius:var(--radius-xl);margin-bottom:var(--space-4);box-shadow:var(--shadow-md)}.vocabulary-hero__value{font-size:var(--text-3xl);font-weight:800;letter-spacing:-.03em;line-height:1}.vocabulary-hero__label{font-size:var(--text-sm);color:#ffffffe6;font-weight:500;margin-top:4px}.vocabulary-search{display:flex;align-items:center;gap:var(--space-2);padding:12px var(--space-4);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:var(--space-3);min-height:var(--touch-target)}.vocabulary-search__icon{color:var(--text-tertiary);flex-shrink:0}.vocabulary-search__input{flex:1;border:none;outline:none;background:transparent;font-size:var(--text-base);color:var(--text-primary);font-weight:500;min-width:0}.vocabulary-search__input::placeholder{color:var(--text-tertiary)}.vocabulary-controls{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3)}.vocabulary-select{flex:1;display:flex;align-items:center;gap:8px;padding:10px var(--space-3);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-sm);min-height:var(--touch-target)}.vocabulary-select span{color:var(--text-tertiary);font-weight:600}.vocabulary-select select{flex:1;border:none;outline:none;background:transparent;color:var(--text-primary);font-size:var(--text-sm);font-weight:600}.vocabulary-counter{font-size:var(--text-sm);color:var(--text-tertiary);font-weight:600;white-space:nowrap}.vocabulary-card{position:relative;display:flex;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);min-height:var(--touch-target-lg)}.vocabulary-card__badge{position:absolute;top:10px;right:10px;width:22px;height:22px;background:var(--primary);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:#fff}.vocabulary-card__content{flex:1;min-width:0}.vocabulary-card__en{font-weight:700;font-size:var(--text-md);color:var(--text-primary);letter-spacing:-.01em}.vocabulary-card__cz{font-size:var(--text-sm);color:var(--text-secondary);margin-top:2px}.vocabulary-card__status{display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:3px 8px;border-radius:var(--radius-full);margin-top:8px}.vocabulary-card__status--review{background:var(--warning-soft);color:var(--warning)}.vocabulary-card__status--mastered{background:var(--primary-soft);color:var(--primary-dark)}.vocabulary-card__status--new{background:var(--secondary-soft);color:var(--secondary)}.vocabulary-strength{margin-top:8px;height:3px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.vocabulary-strength span{display:block;height:100%;background:var(--primary);border-radius:var(--radius-full)}.vocabulary-card__actions{display:flex;align-items:flex-start}.vocabulary-card__sound{width:44px;height:44px;border-radius:var(--radius-full);background:var(--bg-tertiary);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0;color:var(--primary);transition:background var(--t-fast)}.vocabulary-card__sound:active{background:var(--primary-soft)}.vocabulary-card__sound-label{font-size:9px;font-weight:700;letter-spacing:.06em;margin-top:-2px}.vocabulary-load-more{margin-top:var(--space-3);padding:14px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-weight:600;width:100%;cursor:pointer;font-size:var(--text-sm)}.vocabulary-load-more:active{background:var(--bg-tertiary)}.empty-state{text-align:center;padding:var(--space-7) var(--space-4)}.empty-state__icon{font-size:56px;margin-bottom:var(--space-3)}.empty-state__title{font-weight:700;font-size:var(--text-lg);color:var(--text-primary);margin-bottom:4px}.empty-state__text{font-size:var(--text-sm);color:var(--text-secondary)}.path{display:flex;flex-direction:column;gap:var(--space-5)}.path-unit{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-4)}.path-unit__header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3)}.path-unit__badge{width:40px;height:40px;border-radius:var(--radius-md);background:var(--primary-soft);color:var(--primary);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:var(--text-md);flex-shrink:0}.path-unit__copy{flex:1;min-width:0}.path-unit__name{font-weight:700;font-size:var(--text-md);color:var(--text-primary);letter-spacing:-.01em}.path-unit__sub{font-size:var(--text-sm);color:var(--text-secondary);margin-top:2px}.path-unit__progress{font-size:var(--text-sm);font-weight:700;color:var(--primary);background:var(--primary-soft);padding:4px 10px;border-radius:var(--radius-full);flex-shrink:0}.path-unit__nodes{display:flex;flex-direction:column;gap:var(--space-2)}.path-node{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--bg);border:1px solid var(--border-light);border-radius:var(--radius-md);transition:background var(--t-fast),border-color var(--t-fast);min-height:var(--touch-target-lg);cursor:pointer;touch-action:manipulation;text-align:left;width:100%}.path-node:active{background:var(--bg-tertiary);transform:scale(.99)}.path-node--locked{opacity:.45;cursor:not-allowed}.path-node--current{border-color:var(--primary);background:var(--primary-soft)}.path-node--completed .path-node__bubble{background:var(--primary);color:#fff}.path-node__bubble{width:40px;height:40px;border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:17px;flex-shrink:0;position:relative}.path-node__pulse{position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:var(--radius-full);border:2px solid var(--primary);pointer-events:none}.path-node__copy{flex:1;min-width:0}.path-node__title{font-weight:600;font-size:var(--text-base);color:var(--text-primary);letter-spacing:-.005em;display:flex;align-items:center;gap:8px}.path-node__chip{font-size:10px;font-weight:700;background:var(--secondary-soft);color:var(--secondary);padding:2px 8px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em}.path-node__sub{font-size:var(--text-sm);color:var(--text-tertiary);margin-top:2px;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.path-node__meta{display:none;gap:8px;margin-top:6px;font-size:11px;color:var(--text-tertiary);font-weight:600}.path-node--current .path-node__meta,.path-node--available .path-node__meta{display:flex}.path-node__level{background:var(--bg-tertiary);padding:2px 8px;border-radius:var(--radius-full)}.path-node__count{color:var(--text-tertiary)}.runner{position:relative;display:flex;flex-direction:column;height:100%;height:100dvh;background:var(--bg);padding-top:var(--safe-top);padding-bottom:var(--safe-bottom)}.runner--success,.runner--right{animation:flashSuccess .5s var(--ease-out)}.runner--error,.runner--wrong{animation:flashError .5s var(--ease-out)}@keyframes flashSuccess{0%{background:var(--bg)}30%{background:var(--primary-soft)}to{background:var(--bg)}}@keyframes flashError{0%{background:var(--bg)}30%{background:var(--danger-soft)}to{background:var(--bg)}}.runner__top{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--content-padding-x);min-height:var(--header-height)}.runner__close{width:40px;height:40px;border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.runner__close:active{background:var(--bg-quaternary)}.runner__progress{flex:1;height:8px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.runner__progress-fill{height:100%;background:var(--primary);border-radius:var(--radius-full);transition:width var(--t-base)}.runner__body{flex:1;display:flex;flex-direction:column;padding:var(--space-4) var(--content-padding-x) var(--space-5);overflow-y:auto;-webkit-overflow-scrolling:touch}.hearts{display:flex;align-items:center;gap:4px;font-size:var(--text-md);color:var(--danger)}.hearts__pip{display:inline-flex}.ex{display:flex;flex-direction:column;flex:1;min-height:0;width:100%;max-width:540px;margin:0 auto;gap:var(--space-4)}.ex__prompt{font-size:var(--text-sm);font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary)}.ex__stage{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-4) 0;gap:var(--space-3);min-height:120px}.ex__question{display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.ex__question-text{font-weight:800;font-size:var(--text-3xl);letter-spacing:-.03em;color:var(--text-primary);line-height:1.1;word-break:break-word}.ex__phonetic{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:var(--text-base);font-weight:600;color:var(--primary);background:var(--primary-ghost);padding:4px 12px;border-radius:var(--radius-full)}.ex__audio{width:56px;height:56px;border-radius:var(--radius-full);background:var(--primary-ghost);color:var(--primary);display:flex;align-items:center;justify-content:center;transition:transform var(--t-fast),background var(--t-fast)}.ex__audio:active{transform:scale(.92)}.ex__audio.is-playing{background:var(--primary);color:#fff;animation:audioPulse 1.2s ease-in-out infinite}@keyframes audioPulse{0%,to{box-shadow:0 0 0 0 var(--primary-glow)}50%{box-shadow:0 0 0 14px #10b98100}}.ex__big-audio{width:120px;height:120px;border-radius:var(--radius-full);background:var(--primary);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;box-shadow:var(--shadow-glow-primary);transition:transform var(--t-fast)}.ex__big-audio:active{transform:scale(.95)}.ex__big-audio.is-playing{animation:audioPulse 1.2s ease-in-out infinite}.ex__big-audio-label{font-size:11px;font-weight:700;letter-spacing:.04em;opacity:.9}.ex__options{display:flex;flex-direction:column;gap:var(--space-3);width:100%;margin-top:auto}.ex__option{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);width:100%;min-height:60px;padding:var(--space-4) var(--space-5);background:var(--bg-surface);border:2px solid var(--border);border-bottom-width:4px;border-radius:var(--radius-lg);font-size:var(--text-md);font-weight:600;color:var(--text-primary);text-align:left;transition:border-color var(--t-fast),background var(--t-fast),transform var(--t-fast)}.ex__option:active{transform:translateY(1px)}.ex__option:disabled{cursor:default}.ex__option.is-correct{border-color:var(--primary);background:var(--primary-soft);color:var(--primary-dark)}.ex__option.is-wrong{border-color:var(--danger);background:var(--danger-soft);color:var(--danger)}.ex__option-text{flex:1}.ex__cz-prompt{display:flex;flex-direction:column;align-items:center}.ex__cz-prompt-text{font-weight:800;font-size:var(--text-2xl);letter-spacing:-.02em;color:var(--text-primary)}.ex__form{display:flex;flex-direction:column;gap:var(--space-3);width:100%;margin-top:auto}.ex__input{width:100%;min-height:58px;padding:var(--space-4) var(--space-5);background:var(--bg-surface);border:2px solid var(--border-strong);border-radius:var(--radius-lg);font-size:var(--text-lg);font-weight:600;color:var(--text-primary);text-align:center;outline:none;transition:border-color var(--t-fast)}.ex__input::placeholder{color:var(--text-muted);font-weight:500}.ex__input:focus{border-color:var(--border-focus);box-shadow:0 0 0 4px var(--primary-soft)}.ex__input.is-correct{border-color:var(--primary);background:var(--primary-soft);color:var(--primary-dark)}.ex__input.is-wrong{border-color:var(--danger);background:var(--danger-soft);color:var(--danger)}.ex__correct-answer{display:flex;align-items:center;gap:var(--space-2);justify-content:center;padding:var(--space-2) var(--space-4);background:var(--primary-soft);border-radius:var(--radius-md);font-size:var(--text-md);color:var(--text-primary)}.ex__correct-answer strong{color:var(--primary-dark)}.ex__correct-answer-label{color:var(--text-secondary);font-weight:600;font-size:var(--text-sm)}.ex__submit.is-correct{background:var(--primary)}.ex__submit.is-wrong{background:var(--danger)}.match{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3);width:100%;margin-top:var(--space-2)}.match__col{display:flex;flex-direction:column;gap:var(--space-3)}.match__tile{position:relative;display:flex;align-items:center;justify-content:center;min-height:56px;padding:var(--space-3);background:var(--bg-surface);border:2px solid var(--border);border-bottom-width:4px;border-radius:var(--radius-md);font-size:var(--text-base);font-weight:600;color:var(--text-primary);text-align:center;transition:border-color var(--t-fast),background var(--t-fast)}.match__tile.is-selected{border-color:var(--secondary);background:var(--secondary-soft)}.match__tile.is-matched{border-color:var(--primary);background:var(--primary-soft);color:var(--primary-dark)}.match__tile.is-wrong{border-color:var(--danger);background:var(--danger-soft);animation:shakeX .36s}.match__tile-check{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:var(--radius-full);background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center}.match__hint{text-align:center;font-size:var(--text-sm);color:var(--danger);font-weight:600}@keyframes shakeX{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.builder__cz-prompt{font-weight:700;font-size:var(--text-lg);color:var(--text-primary);text-align:center}.builder__slots{display:flex;flex-wrap:wrap;gap:var(--space-2);align-content:flex-start;width:100%;min-height:64px;padding:var(--space-3);border:2px dashed var(--border-strong);border-radius:var(--radius-lg);background:var(--bg-secondary)}.builder__slots.is-empty{align-items:center;justify-content:center}.builder__placeholder{color:var(--text-muted);font-weight:500;font-size:var(--text-base)}.builder__pool{display:flex;flex-wrap:wrap;gap:var(--space-2);width:100%;margin-top:var(--space-3);min-height:48px}.builder__token{padding:var(--space-2) var(--space-4);min-height:44px;background:var(--bg-surface);border:2px solid var(--border);border-bottom-width:3px;border-radius:var(--radius-md);font-size:var(--text-base);font-weight:600;color:var(--text-primary);transition:transform var(--t-fast)}.builder__token:active{transform:translateY(1px)}.builder__token--in-slot{background:var(--primary-ghost);border-color:var(--primary);color:var(--primary-dark)}.builder__token.is-correct{border-color:var(--primary);background:var(--primary-soft)}.builder__token.is-wrong{border-color:var(--danger);background:var(--danger-soft);color:var(--danger)}.builder__actions{display:flex;gap:var(--space-2);align-items:center;margin-top:auto;padding-top:var(--space-3)}.builder__reset{flex-shrink:0}.builder__submit{flex:1;justify-content:center}.builder__submit.is-correct{background:var(--primary)}.builder__submit.is-wrong{background:var(--danger)}.speak__cz{color:var(--text-secondary);font-size:var(--text-md);font-weight:500}.speak__transcript{display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center;min-height:48px;padding:var(--space-3)}.speak__transcript-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:600}.speak__transcript strong{font-size:var(--text-lg);color:var(--text-primary)}.speak__transcript-hint{color:var(--text-muted);font-size:var(--text-base)}.speak__mic-wrap{display:flex;justify-content:center;padding:var(--space-3) 0}.speak__mic{width:96px;height:96px;border-radius:var(--radius-full);background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-glow-primary);transition:transform var(--t-fast)}.speak__mic.is-listening{background:var(--danger)}.speak__mic.is-disabled{background:var(--bg-quaternary);color:var(--text-muted);box-shadow:none}.speak__fallback{display:flex;gap:var(--space-2);justify-content:center;margin-top:var(--space-2)}.speak__verdict{display:flex;align-items:center;justify-content:center;gap:var(--space-2);margin-top:auto;padding:var(--space-3);font-weight:700;font-size:var(--text-md);border-radius:var(--radius-md)}.speak__verdict.is-correct{color:var(--primary-dark);background:var(--primary-soft)}.speak__verdict.is-wrong{color:var(--danger);background:var(--danger-soft)}.reading__story{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4)}.reading__story-controls{display:flex;gap:var(--space-2);margin-bottom:var(--space-3)}.reading__chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);transition:background var(--t-fast),color var(--t-fast)}.reading__chip.is-active,.reading__chip.is-playing{background:var(--primary);color:#fff;border-color:var(--primary)}.reading__paragraph{font-size:var(--text-md);line-height:1.6;color:var(--text-primary)}.reading__translation{margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px dashed var(--border);font-size:var(--text-base);line-height:1.6;color:var(--text-secondary);overflow:hidden}.reading__question{font-weight:700;font-size:var(--text-md);color:var(--text-primary);margin-top:var(--space-2)}.lesson-complete{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-6) var(--content-padding-x);text-align:center;flex:1;gap:var(--space-3)}.lesson-complete__badge{width:96px;height:96px;border-radius:var(--radius-full);background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-3);box-shadow:var(--shadow-glow-primary)}.lesson-complete--error .lesson-complete__badge{background:var(--danger);box-shadow:0 6px 24px var(--danger-glow)}.lesson-complete--warning .lesson-complete__badge{background:var(--warning)}.lesson-complete__title{font-weight:800;font-size:var(--text-2xl);color:var(--text-primary);letter-spacing:-.03em}.lesson-complete__sub{color:var(--text-secondary);font-size:var(--text-md);margin-bottom:var(--space-3)}.lesson-complete__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2);width:100%;max-width:360px;margin:var(--space-4) 0}.lesson-complete__stat{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-2);display:flex;flex-direction:column;align-items:center;gap:4px}.lesson-complete__stat-icon{width:32px;height:32px;border-radius:var(--radius-full);background:var(--primary-soft);color:var(--primary);display:flex;align-items:center;justify-content:center}.lesson-complete__stat-value{font-weight:800;font-size:var(--text-xl);color:var(--text-primary);letter-spacing:-.02em;line-height:1}.lesson-complete__stat-label{font-size:10px;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em}.lesson-complete__mistakes{width:100%;max-width:360px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);text-align:left;margin-top:var(--space-2)}.lesson-complete__mistakes-title{font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);margin-bottom:8px}.lesson-complete__mistakes-list{display:flex;flex-wrap:wrap;gap:6px}.lesson-complete__mistakes-chip{background:var(--warning-soft);color:var(--warning);padding:4px 10px;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:600}.lesson-complete__actions{display:flex;flex-direction:column;gap:var(--space-2);width:100%;max-width:360px;margin-top:var(--space-4)}.card-surface__chrome{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.card-surface__eyebrow{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary)}.card-surface__body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-5) var(--space-3);text-align:center;gap:var(--space-3)}.card-surface__word{font-weight:800;font-size:var(--text-3xl);color:var(--text-primary);letter-spacing:-.03em;line-height:1.1;word-break:break-word}.card-surface__phonetic{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:var(--text-md);color:var(--primary);background:var(--primary-soft);padding:4px 12px;border-radius:var(--radius-full);font-weight:600}.card-surface__hint{font-size:var(--text-sm);color:var(--text-tertiary)}.card-reveal{width:100%;max-width:360px;margin:0 auto;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4)}.card-reveal__header{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);margin-bottom:6px}.card-reveal__answer{font-weight:700;font-size:var(--text-xl);color:var(--primary);letter-spacing:-.02em}.card-reveal__actions{display:flex;gap:var(--space-2);margin-top:var(--space-4)}.card-meanings{font-size:var(--text-sm);color:var(--text-secondary);margin-top:8px}.card-context__translation{font-size:var(--text-sm);color:var(--text-secondary);margin-top:4px}.detail-row{display:flex;justify-content:space-between;align-items:baseline;padding:var(--space-2) 0;border-bottom:1px solid var(--border-light)}.detail-row__label{font-size:var(--text-sm);color:var(--text-tertiary);font-weight:600}.detail-example{font-size:var(--text-sm);color:var(--text-secondary);margin-top:4px}.card-detail-sheet{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4)}.reveal-prompt{font-size:var(--text-sm);color:var(--text-tertiary);text-align:center;font-weight:500}.gesture-row{display:flex;justify-content:center;gap:var(--space-4);margin-top:var(--space-3);font-size:var(--text-sm);color:var(--text-tertiary)}.eyebrow{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary)}.achievement-card{position:relative;padding:var(--space-3) var(--space-4);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);display:flex;gap:var(--space-3);align-items:center;margin-bottom:var(--space-2);min-height:72px}.achievement-card.locked{opacity:.55}.achievement-card__icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:24px;background:var(--bg-tertiary);flex-shrink:0}.achievement-card__content{flex:1;min-width:0}.achievement-card__title{font-weight:700;font-size:var(--text-md);color:var(--text-primary);letter-spacing:-.01em}.achievement-card__description{font-size:var(--text-sm);color:var(--text-secondary);margin-top:2px}.achievement-card__xp{display:inline-block;font-size:11px;font-weight:700;color:var(--primary);background:var(--primary-soft);padding:2px 8px;border-radius:var(--radius-full);margin-top:6px}.achievement-card__badge{width:28px;height:28px;border-radius:var(--radius-full);background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.achievement-toast{position:fixed;bottom:calc(var(--tab-bar-height) + var(--safe-bottom) + var(--space-3));left:var(--space-3);right:var(--space-3);max-width:calc(var(--max-width) - var(--space-6));margin:0 auto;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-3);display:flex;align-items:center;gap:var(--space-3);box-shadow:var(--shadow-lg);z-index:1000}.achievement-toast__icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.achievement-toast__content{flex:1;min-width:0}.achievement-toast__title{font-weight:700;font-size:var(--text-sm);color:var(--text-primary)}.achievement-toast__description{font-size:var(--text-sm);color:var(--text-secondary);margin-top:2px}.achievement-toast__xp{font-size:11px;font-weight:700;color:var(--primary);background:var(--primary-soft);padding:2px 8px;border-radius:var(--radius-full);display:inline-block;margin-top:4px}.profile-section{display:flex;flex-direction:column;align-items:center;margin-bottom:var(--space-5);gap:var(--space-3)}.profile-avatar{width:88px;height:88px;border-radius:var(--radius-full);background:var(--primary-soft);display:flex;align-items:center;justify-content:center;font-size:44px}.profile-name{font-weight:800;font-size:var(--text-xl);color:var(--text-primary);letter-spacing:-.02em}.profile-danger-btn{margin-top:var(--space-4)}.loading-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-6)}.loading-screen__icon{font-size:60px}.loading-screen__text{color:var(--text-secondary);font-weight:500}.loading-screen__progress{width:200px;height:4px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden;margin-top:var(--space-2)}.loading-screen__progress-bar{width:40%;height:100%;background:var(--primary);border-radius:var(--radius-full);animation:loadingSlide 1.4s ease-in-out infinite}@keyframes loadingSlide{0%{transform:translate(-100%)}to{transform:translate(350%)}}.text-secondary{color:var(--text-secondary)}.text-white{color:#fff}.text-gray-400{color:var(--text-tertiary)}.session-progress{height:6px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.session-progress__fill{height:100%;background:var(--primary);border-radius:var(--radius-full)}.icon-button,.icon-ghost{width:44px;height:44px;border-radius:var(--radius-full);background:transparent;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:background var(--t-fast)}.icon-button:active,.icon-ghost:active{background:var(--bg-tertiary)}.danger-box{background:var(--danger-soft);border:1px solid rgba(239,68,68,.18);border-radius:var(--radius-md);padding:var(--space-3)}.danger-button{background:var(--danger);color:#fff;border-radius:var(--radius-md);padding:12px 18px;font-weight:700}.settings-screen{padding:var(--space-5) var(--content-padding-x)}.settings-grid{display:flex;flex-direction:column;gap:var(--space-3)}.settings-card__header,.settings-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);min-height:var(--touch-target-lg)}.settings-card__icon{width:36px;height:36px;border-radius:var(--radius-md);background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center}.settings-stat{display:flex;flex-direction:column}.theme-filter,.status-filter,.theme-switch{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;background:var(--bg-tertiary);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:600;color:var(--text-secondary)}.vocab-screen{padding:var(--space-4) var(--content-padding-x)}.vocab-header{margin-bottom:var(--space-4)}.vocab-filter-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;margin-bottom:var(--space-3)}.vocab-filter-row::-webkit-scrollbar{display:none}.vocab-sections{display:flex;flex-direction:column;gap:var(--space-5)}.vocab-section{display:flex;flex-direction:column;gap:var(--space-2)}.vocab-section__header{font-size:var(--text-sm);color:var(--text-secondary);font-weight:700}.vocab-list{display:flex;flex-direction:column;gap:var(--space-2)}.vocab-list__footer{margin-top:var(--space-3)}.vocab-item{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3);display:flex;align-items:center;gap:var(--space-3);min-height:var(--touch-target-lg)}.vocab-item__copy{flex:1;min-width:0}.vocab-item__head{font-weight:700;color:var(--text-primary);font-size:var(--text-md);letter-spacing:-.01em}.vocab-item__actions{display:flex;gap:8px}.vocab-item__speak{width:40px;height:40px;border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--primary);display:flex;align-items:center;justify-content:center}.vocab-empty{text-align:center;padding:var(--space-7) var(--space-3);color:var(--text-secondary)}.vocab-search{display:flex;align-items:center;gap:8px;padding:12px var(--space-3);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:var(--space-3)}.vocab-select{padding:10px 12px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:600}.vocab-strength{margin-top:6px;height:3px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.vocab-strength span{display:block;height:100%;background:var(--primary)}.vocab-theme-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:600}.vocab-load-more{padding:12px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);font-weight:600;color:var(--text-secondary)}.completion-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);text-align:center}.completion-card__icon{font-size:56px;margin-bottom:var(--space-2)}.completion-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-2);margin-top:var(--space-3)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
