@import"https://fonts.googleapis.com/css2?family=Geist:wght@300;400;500;600;700&family=Geist+Mono:wght@400;500;600&family=Newsreader:ital,opsz,wght@0,6..72,400;0,6..72,500;0,6..72,600;1,6..72,400&display=swap";:root{--font-sans: "Geist", "Geist Sans", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;--font-display: "Geist", ui-sans-serif, system-ui, sans-serif;--font-serif: "Newsreader", Georgia, "Source Serif Pro", serif;--font-mono: "Geist Mono", ui-monospace, "JetBrains Mono", "SF Mono", Menlo, monospace;--type-2xs: 11px;--type-xs: 12px;--type-sm: 13px;--type-base: 15px;--type-md: 16px;--type-lg: 18px;--type-xl: 22px;--type-2xl: 28px;--type-3xl: 36px;--type-4xl: 48px;--type-5xl: 64px;--w-light: 300;--w-regular: 400;--w-medium: 500;--w-semibold: 600;--w-bold: 700;--lh-tight: 1.05;--lh-snug: 1.2;--lh-base: 1.45;--lh-loose: 1.6;--lh-reading: 1.72;--tk-tight: -.022em;--tk-tighter: -.04em;--tk-normal: 0;--tk-wide: .06em;--tk-eyebrow: .12em;--paper: #FCFCFA;--paper-sunken: #F5F4F0;--surface: #FFFFFF;--surface-2: #F9F8F4;--overlay: rgba(20, 18, 14, .42);--ink-1: #18181A;--ink-2: #2F2F33;--ink-3: #5C5C61;--ink-4: #8A8A8F;--ink-5: #B4B4B8;--rule: #ECEAE2;--rule-strong: #D8D5CB;--rule-focus: #6E2BD9;--m-blue: #2D7BF5;--m-violet: #7B3FE4;--m-magenta: #E63892;--m-orange: #FF8533;--primary: #6E2BD9;--primary-hover: #5C1FC2;--primary-press: #4B17A4;--primary-soft: #F1ECFC;--primary-soft-2: #E5DAFA;--primary-ink: #4214A4;--primary-ring: rgba(110, 43, 217, .32);--success: #1F8A5B;--success-soft: #E2F2E9;--success-ink: #155A3C;--warning: #C57E12;--warning-soft: #FAEFD2;--warning-ink: #7A4D08;--danger: #C8312C;--danger-soft: #F8E2E0;--danger-ink: #861B17;--info: #1E6FB8;--info-soft: #E1EDF9;--info-ink: #134879;--srs-again: #C8312C;--srs-hard: #C57E12;--srs-good: #1F8A5B;--srs-easy: #6E2BD9;--sp-0: 0;--sp-px: 1px;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-7: 32px;--sp-8: 40px;--sp-9: 56px;--sp-10: 72px;--sp-11: 96px;--radius-xs: 3px;--radius-sm: 5px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 18px;--radius-2xl: 24px;--radius-pill: 999px;--shadow-0: 0 0 0 1px var(--rule);--shadow-1: 0 1px 2px rgba(20, 18, 14, .04), 0 0 0 1px var(--rule);--shadow-2: 0 2px 6px rgba(20, 18, 14, .06), 0 0 0 1px var(--rule);--shadow-3: 0 8px 24px rgba(20, 18, 14, .08), 0 0 0 1px var(--rule);--shadow-pop: 0 16px 40px rgba(20, 18, 14, .14), 0 0 0 1px var(--rule-strong);--shadow-focus: 0 0 0 3px var(--primary-ring);--shadow-inset: inset 0 1px 0 rgba(0,0,0,.04);--ease-out: cubic-bezier(.22, 1, .36, 1);--ease-in: cubic-bezier(.55, 0, .74, 0);--ease-snap: cubic-bezier(.32, .72, 0, 1);--dur-fast: .12s;--dur-base: .18s;--dur-slow: .28s;--grad-brand: linear-gradient(96deg, var(--m-blue) 0%, var(--m-violet) 38%, var(--m-magenta) 70%, var(--m-orange) 100%);--grad-brand-soft: linear-gradient(96deg, rgba(45,123,245,.08), rgba(123,63,228,.08) 38%, rgba(230,56,146,.08) 70%, rgba(255,133,51,.08));--grad-violet-pink: linear-gradient(120deg, var(--m-violet), var(--m-magenta));--grad-blue-violet: linear-gradient(120deg, var(--m-blue), var(--m-violet));--grad-page-glow: radial-gradient(60% 50% at 50% 0%, rgba(123,63,228,.06), transparent 70%)}:root[data-theme=dark]{--paper: #0E0D10;--paper-sunken: #0A090C;--surface: #16151A;--surface-2: #1C1B22;--overlay: rgba(0, 0, 0, .62);--ink-1: #F4F2EE;--ink-2: #D8D5CF;--ink-3: #9C9AA0;--ink-4: #6E6D74;--ink-5: #45444B;--rule: #23222A;--rule-strong: #34323D;--primary: #9764F0;--primary-hover: #A87DF4;--primary-press: #BA98F7;--primary-soft: #1F1730;--primary-soft-2: #2C2148;--primary-ink: #C7A8FA;--primary-ring: rgba(151, 100, 240, .42);--success: #4EBD89;--success-soft: #122319;--success-ink: #7BD3A5;--warning: #E2A23E;--warning-soft: #2A1F0E;--warning-ink: #EFC07A;--danger: #E55C57;--danger-soft: #2A1413;--danger-ink: #F09995;--info: #5AA1E0;--info-soft: #112030;--info-ink: #93C2EC;--shadow-0: 0 0 0 1px var(--rule);--shadow-1: 0 1px 2px rgba(0,0,0,.4), 0 0 0 1px var(--rule);--shadow-2: 0 4px 12px rgba(0,0,0,.5), 0 0 0 1px var(--rule);--shadow-3: 0 12px 32px rgba(0,0,0,.55), 0 0 0 1px var(--rule);--shadow-pop: 0 24px 48px rgba(0,0,0,.6), 0 0 0 1px var(--rule-strong);--shadow-focus: 0 0 0 3px var(--primary-ring)}.t-display{font-family:var(--font-display);font-size:var(--type-5xl);font-weight:var(--w-semibold);line-height:var(--lh-tight);letter-spacing:var(--tk-tighter);color:var(--ink-1)}.t-h1{font-family:var(--font-display);font-size:var(--type-3xl);font-weight:var(--w-semibold);line-height:var(--lh-snug);letter-spacing:var(--tk-tight);color:var(--ink-1)}.t-h2{font-family:var(--font-display);font-size:var(--type-2xl);font-weight:var(--w-semibold);line-height:var(--lh-snug);letter-spacing:var(--tk-tight);color:var(--ink-1)}.t-h3{font-family:var(--font-sans);font-size:var(--type-xl);font-weight:var(--w-semibold);line-height:var(--lh-snug);letter-spacing:var(--tk-tight);color:var(--ink-1)}.t-h4{font-family:var(--font-sans);font-size:var(--type-lg);font-weight:var(--w-semibold);line-height:var(--lh-snug);color:var(--ink-1)}.t-body{font-family:var(--font-sans);font-size:var(--type-base);font-weight:var(--w-regular);line-height:var(--lh-base);color:var(--ink-2)}.t-body-sm{font-family:var(--font-sans);font-size:var(--type-sm);font-weight:var(--w-regular);line-height:var(--lh-base);color:var(--ink-2)}.t-prose{font-family:var(--font-serif);font-size:var(--type-lg);font-weight:var(--w-regular);line-height:var(--lh-reading);color:var(--ink-2);font-feature-settings:"ss01","onum"}.t-caption{font-family:var(--font-sans);font-size:var(--type-xs);font-weight:var(--w-regular);line-height:var(--lh-base);color:var(--ink-4)}.t-eyebrow{font-family:var(--font-sans);font-size:var(--type-xs);font-weight:var(--w-semibold);text-transform:uppercase;letter-spacing:var(--tk-eyebrow);color:var(--ink-3)}.t-mono{font-family:var(--font-mono);font-size:var(--type-sm);font-weight:var(--w-regular);line-height:var(--lh-base);color:var(--ink-2);font-feature-settings:"tnum"}.t-label{font-family:var(--font-sans);font-size:var(--type-sm);font-weight:var(--w-medium);line-height:var(--lh-snug);color:var(--ink-2)}.t-kbd{font-family:var(--font-mono);font-size:var(--type-xs);padding:2px 6px;border-radius:var(--radius-xs);background:var(--surface-2);border:1px solid var(--rule);border-bottom-width:2px;color:var(--ink-2)}.t-vocab{font-family:var(--font-display);font-size:var(--type-4xl);font-weight:var(--w-medium);letter-spacing:var(--tk-tight);line-height:var(--lh-tight);color:var(--ink-1)}.t-transcription{font-family:var(--font-mono);font-size:var(--type-sm);color:var(--ink-4)}.t-stat{font-family:var(--font-mono);font-size:var(--type-3xl);font-weight:var(--w-medium);letter-spacing:var(--tk-tight);line-height:1;color:var(--ink-1);font-feature-settings:"tnum"}.t-wordmark{font-family:var(--font-display);font-size:var(--type-lg);font-weight:var(--w-semibold);letter-spacing:var(--tk-tight);color:var(--ink-1)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%;margin:0}body{font-family:var(--font-sans);background:var(--paper);color:var(--ink-1);font-size:16px;line-height:1.45}.app{max-width:560px;margin:0 auto;min-height:100%;display:flex;flex-direction:column;padding:12px 16px calc(28px + env(safe-area-inset-bottom))}.bar{display:flex;align-items:center;gap:8px;margin-bottom:14px}.brand{display:flex;align-items:center;gap:8px;margin-right:auto}.brand .mark{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,#6e2bd9,#c026a8);color:#fff;font-weight:700;font-size:13px;display:grid;place-items:center}.brand .wm{font-weight:600;font-size:17px;letter-spacing:-.01em}.chip{display:inline-flex;align-items:center;gap:5px;padding:6px 10px;border-radius:var(--radius-pill, 999px);background:var(--surface-2);border:1px solid var(--rule);font-family:var(--font-mono);font-size:13px;font-weight:600}.chip.low{color:var(--warning, #C57E12);border-color:var(--warning, #C57E12)}button.chip{cursor:pointer;color:var(--ink-1)}button.chip:active{background:var(--primary-soft, #F1E9FC);color:var(--primary)}.list-item{padding:12px 14px;border-radius:var(--radius-lg, 12px);background:var(--surface);border:1px solid var(--rule);margin-bottom:8px}.li-pair{font-family:var(--font-mono);font-size:11px;color:var(--ink-4, #8A8A8E);margin-bottom:4px}.li-main{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.li-src{font-weight:600;font-size:15px}.li-tr{color:var(--ink-2);font-size:15px;margin-top:2px}.li-act{display:flex;gap:4px;flex:0 0 auto}.li-act button{border:0;background:var(--surface-2);border-radius:8px;padding:6px 9px;font-size:15px;cursor:pointer}.li-act button:active{background:var(--primary-soft, #F1E9FC)}.langbar{display:flex;align-items:center;gap:8px;margin-bottom:12px}.langtile{flex:1;padding:11px 14px;border-radius:var(--radius-lg, 12px);background:var(--surface);border:1px solid var(--rule);font:inherit;font-size:14px;font-weight:600;color:var(--ink-1);text-align:left;cursor:pointer}.langtile:active{border-color:var(--primary)}.swap{width:38px;height:38px;border-radius:50%;background:var(--primary-soft, #F1E9FC);color:var(--primary);border:0;font-size:18px;cursor:pointer;flex:0 0 auto}.modes{display:flex;gap:4px;padding:4px;margin-bottom:12px;background:var(--surface-2);border-radius:var(--radius-lg, 12px);border:1px solid var(--rule)}.modes button{flex:1;padding:8px 4px;border:0;border-radius:9px;background:transparent;font:inherit;font-size:13px;font-weight:600;color:var(--ink-3, #6B6B70);cursor:pointer;position:relative}.modes button.active{background:var(--surface);color:var(--ink-1);box-shadow:var(--shadow-1, 0 1px 3px rgba(0,0,0,.08))}.modes .free{font-size:9px;color:var(--success, #1F8A5B);display:block;line-height:1;margin-top:2px}.input-wrap{position:relative;margin-bottom:12px}.input-wrap textarea{width:100%;min-height:96px;max-height:220px;resize:none;padding:14px;border-radius:var(--radius-lg, 12px);background:var(--surface);border:1px solid var(--rule);font:inherit;color:inherit;outline:none}.input-wrap textarea:focus{border-color:var(--primary)}.counter{position:absolute;right:12px;bottom:10px;font-family:var(--font-mono);font-size:11px;color:var(--ink-5, #B4B4B8)}.toolbar{display:flex;gap:6px;margin:-4px 0 12px}.tool{padding:8px 14px;border-radius:var(--radius-pill, 999px);background:var(--surface-2);border:1px solid var(--rule);font:inherit;font-size:13px;font-weight:600;color:var(--ink-2);cursor:pointer}.tool:active{background:var(--primary-soft, #F1E9FC);color:var(--primary)}.tool.rec{background:var(--danger-soft, #FBE9E8);color:var(--danger, #C8312C);border-color:var(--danger, #C8312C);animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.55}}.result{padding:14px;border-radius:var(--radius-lg, 12px);background:var(--surface);border:1px solid var(--rule);margin-bottom:12px}.result .ocr-cap{font-size:13px;color:var(--ink-3, #6B6B70);background:var(--surface-2);border-radius:8px;padding:8px 10px;margin-bottom:10px;max-height:80px;overflow:auto;white-space:pre-wrap}.result .pair{font-family:var(--font-mono);font-size:12px;color:var(--ink-4, #8A8A8E);margin-bottom:8px}.result .body{font-size:17px}.result .body i{font-family:var(--font-serif)}.actions{display:flex;gap:6px;margin-top:12px;padding-top:12px;border-top:1px solid var(--rule)}.actions button{flex:1;padding:9px 6px;border-radius:9px;background:var(--surface-2);border:1px solid var(--rule);font:inherit;font-size:13px;font-weight:600;color:var(--ink-2);cursor:pointer}.actions button:active{background:var(--primary-soft, #F1E9FC);color:var(--primary)}.toast{position:fixed;left:50%;bottom:calc(80px + env(safe-area-inset-bottom));transform:translate(-50%);background:var(--ink-1);color:var(--paper);padding:10px 16px;border-radius:var(--radius-pill, 999px);font-size:13px;font-weight:500;box-shadow:var(--shadow-pop, 0 8px 24px rgba(0,0,0,.18));z-index:50}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#1412186b;display:flex;align-items:flex-end;z-index:60;animation:fade .18s ease}@keyframes fade{0%{opacity:0}to{opacity:1}}.sheet{width:100%;max-width:560px;margin:0 auto;background:var(--paper);border-radius:20px 20px 0 0;padding:8px 16px calc(20px + env(safe-area-inset-bottom));max-height:78vh;display:flex;flex-direction:column;animation:slideup .26s cubic-bezier(.22,1,.36,1)}@keyframes slideup{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sheet-handle{width:36px;height:4px;border-radius:999px;background:var(--rule-strong);margin:6px auto 12px}.sheet-search{width:100%;padding:11px 14px;border-radius:var(--radius-lg, 12px);background:var(--surface-2);border:1px solid var(--rule);font:inherit;font-size:15px;outline:none;margin-bottom:8px}.sheet-search:focus{border-color:var(--primary)}.sheet-list{overflow-y:auto;-webkit-overflow-scrolling:touch}.lang-row{display:flex;align-items:center;gap:12px;width:100%;padding:12px 8px;border:0;background:transparent;cursor:pointer;font:inherit;font-size:16px;color:var(--ink-1);text-align:left;border-bottom:1px solid var(--rule)}.lang-row .fl{font-size:20px}.lang-row .nm{margin-right:auto}.lang-row .ck{color:var(--primary);font-weight:700}.lang-row.sel{color:var(--primary)}.train-btn{width:100%;padding:13px;margin-bottom:12px;border:0;border-radius:var(--radius-lg, 12px);background:var(--primary);color:#fff;font:inherit;font-size:15px;font-weight:600;cursor:pointer}.train-btn:active{background:var(--primary-press, #4B17A4)}.progress{height:4px;background:var(--rule);border-radius:999px;overflow:hidden;margin-bottom:18px}.progress-bar{height:100%;background:var(--primary);transition:width .25s ease}.quiz-card{background:var(--surface);border:1px solid var(--rule);border-radius:var(--radius-xl, 18px);padding:24px 18px;text-align:center}.quiz-word{font-size:30px;font-weight:600;letter-spacing:-.01em;margin:6px 0}.quiz-answer{font-size:22px;color:var(--primary);font-weight:600;margin:12px 0 18px}.li-act-inline{border:0;background:transparent;font-size:18px;cursor:pointer}.quiz-rate{display:flex;gap:8px}.rate{flex:1;padding:13px;border:0;border-radius:var(--radius-lg, 12px);font:inherit;font-size:15px;font-weight:600;cursor:pointer}.rate.again{background:var(--warning-soft, #FBF1E0);color:var(--warning, #C57E12)}.rate.good{background:var(--success-soft, #E4F3EC);color:var(--success, #1F8A5B)}.done{text-align:center;padding:48px 16px}.done-mark{width:64px;height:64px;margin:0 auto 16px;border-radius:50%;background:var(--success-soft, #E4F3EC);color:var(--success, #1F8A5B);font-size:34px;display:grid;place-items:center}.hint{text-align:center;color:var(--ink-4, #8A8A8E);font-size:14px;padding:24px 0}.err{color:var(--danger, #C8312C)}.loading{text-align:center;color:var(--ink-4, #8A8A8E);padding:20px}
