:root{--bg: #1a1a2e;--surface: #16213e;--surface-hover: #1c2a4f;--accent: #e94560;--accent-hover: #d13850;--text: #eeeeee;--text-muted: #8899aa;--jp-font: "Noto Sans JP", sans-serif;--en-font: "Inter", system-ui, -apple-system, sans-serif;--radius: 12px;--radius-sm: 8px}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}body{font-family:var(--en-font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}.app{min-height:100%;display:flex;flex-direction:column;align-items:center;padding:24px 16px;max-width:600px;margin:0 auto}.header{text-align:center;margin-bottom:32px;width:100%}.header h1{font-size:28px;font-weight:700;letter-spacing:2px}.header h1 span{color:var(--accent)}.header .subtitle{font-size:13px;color:var(--text-muted);margin-top:4px;font-weight:400}.output-card{width:100%;background:var(--surface);border-radius:var(--radius);padding:24px;margin-bottom:20px;min-height:180px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;transition:all .2s ease;border:1px solid rgba(255,255,255,.05)}.output-card.has-result{border-color:#e9456033}.output-card .placeholder{color:var(--text-muted);font-size:15px;line-height:1.6}.output-card .japanese{font-family:var(--jp-font);font-size:32px;font-weight:900;line-height:1.4;margin-bottom:12px;word-break:break-word}.output-card .romaji{font-size:16px;color:var(--text-muted);font-weight:400;margin-bottom:16px}.output-card .play-btn{background:var(--accent);border:none;color:#fff;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;transition:all .15s ease;margin-top:4px}.output-card .play-btn:hover{background:var(--accent-hover);transform:scale(1.05)}.output-card .play-btn:active{transform:scale(.95)}.output-card .play-btn.playing{animation:pulse 1s infinite}@keyframes pulse{0%,to{box-shadow:0 0 #e9456080}50%{box-shadow:0 0 0 12px #e9456000}}.spinner{width:32px;height:32px;border:3px solid rgba(233,69,96,.2);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.input-area{width:100%;display:flex;flex-direction:column;gap:12px}.text-input{width:100%;padding:16px;background:var(--surface);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);color:var(--text);font-family:var(--en-font);font-size:16px;resize:none;outline:none;transition:border-color .15s;min-height:60px}.text-input:focus{border-color:var(--accent)}.text-input::placeholder{color:var(--text-muted)}.button-row{display:flex;gap:10px;width:100%}.btn-primary{flex:1;padding:14px 24px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);font-size:16px;font-weight:600;cursor:pointer;transition:all .15s ease;font-family:var(--en-font)}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-icon{width:50px;height:50px;background:var(--surface);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);color:var(--text);font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;flex-shrink:0}.btn-icon:hover{background:var(--surface-hover);border-color:var(--accent)}.btn-icon:active{transform:scale(.95)}.btn-icon.listening{border-color:var(--accent);color:var(--accent);animation:pulse 1s infinite}.options-row{width:100%;display:flex;justify-content:flex-end;align-items:center;gap:8px;margin-top:4px;font-size:13px;color:var(--text-muted)}.toggle{position:relative;width:36px;height:20px;background:var(--surface);border:1px solid rgba(255,255,255,.1);border-radius:10px;cursor:pointer;transition:all .15s}.toggle.active{background:var(--accent);border-color:var(--accent)}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;background:#fff;border-radius:50%;transition:transform .15s}.toggle.active:after{transform:translate(16px)}.voice-selector{width:100%;display:flex;align-items:center;gap:8px;margin-top:4px}.voice-selector label{font-size:13px;color:var(--text-muted)}.voice-selector select{background:var(--surface);color:var(--text);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);padding:6px 10px;font-size:13px;font-family:var(--en-font);cursor:pointer;outline:none}.voice-selector select:focus{border-color:var(--accent)}.error-msg{width:100%;padding:12px 16px;background:#e945601a;border:1px solid rgba(233,69,96,.3);border-radius:var(--radius-sm);color:var(--accent);font-size:14px;margin-top:12px;font-family:var(--jp-font)}.footer{margin-top:auto;padding:24px 0 12px;font-size:12px;color:var(--text-muted);text-align:center}@media (max-width: 480px){.app{padding:16px 12px}.header h1{font-size:24px}.output-card .japanese{font-size:26px}.output-card{padding:18px;min-height:140px}}.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;background:var(--surface);border-top:1px solid rgba(255,255,255,.08);z-index:100;padding-bottom:env(safe-area-inset-bottom,0);text-decoration:none}.bottom-nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px 0 12px;color:var(--text-muted);cursor:pointer;border:none;background:none;gap:2px;transition:color .15s;text-decoration:none}.bottom-nav-tab .tab-kanji{font-size:20px;font-family:var(--jp-font)}.bottom-nav-tab .tab-label{font-size:10px;letter-spacing:.05em;text-transform:uppercase}.bottom-nav-tab.active{color:var(--accent)}.shell-content{padding-bottom:72px;min-height:100vh}.screen-stub{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:12px;color:var(--text-muted)}.stub-kanji{font-size:72px;font-family:var(--jp-font);color:var(--text);opacity:.15}.history-toggle{width:100%;text-align:left;background:none;border:none;color:var(--text-muted);font-size:13px;padding:12px 0 8px;cursor:pointer;display:flex;align-items:center;gap:6px}.history-list{display:flex;flex-direction:column;gap:8px;width:100%;margin-bottom:16px}.history-row{background:var(--surface);border-radius:var(--radius-sm);padding:10px 12px;display:flex;align-items:center;gap:8px}.history-row-text{flex:1;min-width:0}.history-row .ja{font-family:var(--jp-font);font-size:16px;font-weight:700}.history-row .rm{font-size:11px;color:var(--text-muted)}.replay-btn{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:14px;padding:4px 8px}.star-btn{background:none;border:none;cursor:pointer;font-size:18px;color:var(--text-muted);padding:4px}.star-btn.starred{color:#f5c518}.settings-screen{padding:24px 16px;max-width:480px;margin:0 auto;width:100%}.settings-section{margin-bottom:32px}.settings-section h2{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:12px}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.06)}.settings-row label{font-size:14px}.header{position:relative}.screen-stub{position:relative;width:100%}.settings-gear{position:absolute;top:0;right:0;color:var(--text-muted);text-decoration:none;font-size:20px;padding:4px 8px;transition:color .15s}.settings-gear:hover{color:var(--text)}.screen-stub .settings-gear{top:16px;right:16px}.learn-today{position:relative;width:100%;max-width:480px;margin:0 auto;padding:24px 16px;display:flex;flex-direction:column;gap:16px}.learn-today .settings-gear{top:24px;right:16px}.learn-title{font-size:24px;font-weight:700}.learn-loading{display:flex;justify-content:center;padding:80px 0}.today-card{background:var(--surface);border:1px solid rgba(255,255,255,.05);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;gap:12px}.today-card-big{font-size:20px;font-weight:700}.today-card-sub{font-size:14px;color:var(--text-muted)}.today-card-row{display:flex;justify-content:space-between;align-items:baseline}.unit-name{font-weight:600;font-size:15px}.unit-pct{font-size:13px;color:var(--text-muted)}.unit-progress-bar{height:8px;background:#ffffff14;border-radius:4px;overflow:hidden}.unit-progress-fill{height:100%;background:var(--accent);border-radius:4px;transition:width .3s ease}.learn-stats{display:flex;gap:12px}.learn-stats .stat{flex:1;background:var(--surface);border:1px solid rgba(255,255,255,.05);border-radius:var(--radius);padding:14px;text-align:center}.learn-stats .stat-num{font-size:22px;font-weight:700}.learn-stats .stat-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:2px}.session-screen{width:100%;max-width:480px;margin:0 auto;padding:16px;display:flex;flex-direction:column;min-height:calc(100vh - 72px)}.session-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.session-exit{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:4px 6px}.session-exit:hover{color:var(--text)}.session-progress{flex:1;height:6px;background:#ffffff14;border-radius:3px;overflow:hidden}.session-progress-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .3s ease}.session-count{font-size:12px;color:var(--text-muted);white-space:nowrap}.exercise-card{flex:1;background:var(--surface);border:1px solid rgba(255,255,255,.05);border-radius:var(--radius);padding:28px 20px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;text-align:center}.exercise-prompt{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.kana-display{font-family:var(--jp-font);font-size:112px;font-weight:900;line-height:1.1}.exercise-ja{font-family:var(--jp-font);font-size:34px;font-weight:900;line-height:1.4;word-break:keep-all}.exercise-reading{font-size:15px;color:var(--text-muted)}.exercise-en{font-size:18px;font-weight:600}.exercise-notes{font-size:13px;color:var(--text-muted);line-height:1.5;max-width:320px}.intro-countdown{font-size:12px;color:var(--text-muted)}.reveal-btn{width:100%;max-width:280px}.audio-btn{background:var(--accent);border:none;color:#fff;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;transition:all .15s ease}.audio-btn.big{width:72px;height:72px;font-size:30px}.audio-btn:hover{background:var(--accent-hover);transform:scale(1.05)}.audio-btn:active{transform:scale(.95)}.audio-btn.playing{animation:pulse 1s infinite}.exercise-choices{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;margin-top:8px}.choice-btn{padding:16px 12px;background:var(--bg);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);color:var(--text);font-size:16px;font-family:var(--en-font);cursor:pointer;transition:all .15s ease}.choice-btn:hover:not(:disabled){border-color:var(--accent)}.choice-btn:disabled{cursor:default}.choice-btn.correct{background:#50c8782e;border-color:#50c878;color:#a8e6c0}.choice-btn.wrong{background:#e9456026;border-color:var(--accent);animation:shake .3s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.grade-buttons{display:flex;gap:10px;width:100%;margin-top:8px}.grade-buttons button{flex:1}.btn-secondary{padding:14px 24px;background:var(--bg);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);color:var(--text);font-size:15px;font-weight:600;font-family:var(--en-font);cursor:pointer;transition:all .15s ease}.btn-secondary:hover{border-color:var(--accent)}.btn-secondary:active{transform:scale(.98)}.session-end{width:100%;max-width:420px;margin:0 auto;padding:48px 16px;display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center}.session-end-emoji{font-size:56px}.session-end h2{font-size:22px}.stageups{display:flex;flex-direction:column;gap:6px;width:100%}.stageup-row{display:flex;justify-content:space-between;align-items:center;background:var(--surface);border-radius:var(--radius-sm);padding:10px 14px;font-size:15px}.stageup-row .ja{font-family:var(--jp-font);font-weight:700}.arcade-screen{padding:16px;max-width:480px;margin:0 auto;min-height:100vh}.arcade-back{background:none;border:none;color:var(--text-muted);font-size:20px;cursor:pointer;padding:8px 0;margin-bottom:16px;display:flex;align-items:center;gap:8px}.arcade-lobby{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding-top:8px}.arcade-game-card{background:var(--surface);border-radius:var(--radius);padding:20px 16px;display:flex;flex-direction:column;gap:8px;border:1px solid rgba(255,255,255,.06)}.arcade-game-card h3{font-size:15px;font-weight:700}.arcade-game-card p{font-size:12px;color:var(--text-muted);line-height:1.4}.arcade-timer-bar{height:4px;background:#ffffff1a;border-radius:2px;margin-bottom:16px}.arcade-timer-fill{height:100%;background:var(--accent);border-radius:2px;transition:width 1s linear}.arcade-streak{text-align:center;font-size:13px;color:var(--text-muted);margin-bottom:8px}.kana-display-large{font-family:Noto Sans JP,sans-serif;font-size:112px;text-align:center;line-height:1.2;margin:24px 0;color:var(--text)}.kana-choices{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px}.kana-choice-btn{padding:18px 12px;background:var(--surface);border:2px solid rgba(255,255,255,.08);border-radius:var(--radius);color:var(--text);font-size:17px;font-family:Noto Sans JP,sans-serif;cursor:pointer;text-align:center;transition:all .15s}.kana-choice-btn:hover{background:var(--surface-hover);border-color:var(--accent)}.kana-choice-btn.correct{background:#22c55e26;border-color:#22c55e;color:#22c55e}.kana-choice-btn.wrong{background:#ef444426;border-color:#ef4444;color:#ef4444}@keyframes arcade-shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-6px)}40%,80%{transform:translate(6px)}}.kana-choice-btn.shake{animation:arcade-shake .3s ease}.kana-choice-btn.glyph{font-size:26px}.kana-choices.kid{gap:14px}.kana-choices.kid .kana-choice-btn{padding:26px 12px;font-size:22px}.kana-choices.kid .kana-choice-btn.glyph{font-size:34px}.arcade-celebrate{text-align:center;font-size:18px;font-weight:700;color:var(--accent);margin-bottom:8px;animation:arcade-shake .3s ease}.pairs-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:16px}.pair-card{aspect-ratio:1;background:var(--surface);border-radius:var(--radius-sm);border:2px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;font-family:Noto Sans JP,sans-serif;transition:all .2s;-webkit-user-select:none;user-select:none}.pair-card.face-down{background:var(--surface-hover);color:transparent}.pair-card.matched{background:#22c55e1f;border-color:#22c55e;color:#22c55e;cursor:default}.ladder-screen{padding:16px;max-width:480px;margin:0 auto}.ladder-rung{background:var(--surface);border-radius:var(--radius);padding:14px 16px;margin-bottom:10px;display:flex;align-items:center;gap:12px;border:1px solid rgba(255,255,255,.06)}.ladder-rung.locked{opacity:.5}.ladder-rung-preview{font-family:Noto Sans JP,sans-serif;font-size:18px;flex:1}.ladder-rung-status{font-size:20px}.arcade-end-card{text-align:center;padding:32px 16px}.arcade-end-card h2{font-size:28px;margin-bottom:8px}.arcade-stage-ups{display:flex;flex-direction:column;gap:6px;margin:16px 0}.arcade-stage-up-row{background:var(--surface);border-radius:var(--radius-sm);padding:10px 14px;font-size:13px}.tile-builder{display:flex;flex-direction:column;gap:16px}.tile-answer-row{min-height:52px;display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:10px 12px;background:#ffffff0a;border-radius:var(--radius-sm);border:2px dashed rgba(255,255,255,.1)}.tile-pool{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.segment-tile{padding:10px 16px;background:var(--surface);border:2px solid rgba(255,255,255,.12);border-radius:var(--radius-sm);font-family:Noto Sans JP,sans-serif;font-size:16px;cursor:pointer;transition:all .15s;color:var(--text)}.segment-tile:hover{background:var(--surface-hover);border-color:var(--accent)}.segment-tile.placed{background:#e945601a;border-color:var(--accent)}.segment-tile.correct{background:#22c55e26;border-color:#22c55e;color:#22c55e}.segment-tile.wrong{background:#ef444426;border-color:#ef4444;color:#ef4444;animation:shake .3s ease}.cloze-phrase{font-family:Noto Sans JP,sans-serif;font-size:24px;line-height:1.6;text-align:center;margin:16px 0}.cloze-blank{color:var(--accent);font-weight:700;border-bottom:2px solid var(--accent);padding:0 4px}.cloze-choices{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px}.cloze-choice{padding:14px 12px;background:var(--surface);border:2px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);font-family:Noto Sans JP,sans-serif;font-size:15px;cursor:pointer;transition:all .15s;color:var(--text);text-align:center}.cloze-choice:hover{background:var(--surface-hover);border-color:var(--accent)}.cloze-choice.correct{background:#22c55e26;border-color:#22c55e;color:#22c55e}.cloze-choice.wrong{background:#ef444426;border-color:#ef4444;color:#ef4444}.match-five{display:flex;gap:12px}.match-col{flex:1;display:flex;flex-direction:column;gap:8px}.match-tile{padding:14px 10px;background:var(--surface);border:2px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);font-family:Noto Sans JP,sans-serif;font-size:14px;cursor:pointer;transition:all .15s;color:var(--text);text-align:center;min-height:52px;display:flex;align-items:center;justify-content:center}.match-tile:hover{border-color:var(--accent)}.match-tile.selected{background:#e9456026;border-color:var(--accent)}.match-tile.matched{background:#22c55e1f;border-color:#22c55e;color:#22c55e;cursor:default;opacity:.7}.match-tile.wrong-flash{background:#ef444426;border-color:#ef4444;animation:shake .3s ease}.show-card-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:var(--bg);display:flex;align-items:center;justify-content:center;flex-direction:column}.show-card-content{display:flex;flex-direction:column;align-items:center;gap:20px;padding:32px 24px;text-align:center;max-width:480px;width:100%}.show-card-ja{font-family:Noto Sans JP,sans-serif;font-size:clamp(48px,12vw,96px);font-weight:900;line-height:1.3;color:var(--text)}.show-card-romaji{font-size:22px;color:var(--text-muted)}.show-card-play{width:72px;height:72px;border-radius:50%;background:var(--accent);border:none;color:#fff;font-size:28px;cursor:pointer;display:flex;align-items:center;justify-content:center}.show-card-play.playing{animation:pulse 1s infinite}.show-card-close{background:none;border:none;color:var(--text-muted);font-size:14px;cursor:pointer;padding:8px 16px}.phrasebook-chip{background:var(--surface);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:8px 18px;color:var(--text);font-size:14px;cursor:pointer;transition:all .15s;width:100%;margin-bottom:8px}.phrasebook-chip:hover{border-color:var(--accent)}.phrasebook-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:150;background:#000000b3;display:flex;align-items:flex-end}.phrasebook-modal{background:var(--bg);border-radius:var(--radius) var(--radius) 0 0;width:100%;max-height:75vh;overflow-y:auto;padding:0 0 env(safe-area-inset-bottom,0)}.phrasebook-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;position:sticky;top:0;background:var(--bg);border-bottom:1px solid rgba(255,255,255,.06)}.phrasebook-header h2{font-size:16px}.phrasebook-close{background:none;border:none;color:var(--text-muted);font-size:20px;cursor:pointer}.phrasebook-row{padding:14px 20px;border-bottom:1px solid rgba(255,255,255,.04);cursor:pointer;transition:background .15s}.phrasebook-row:hover{background:var(--surface)}.phrasebook-ja{font-family:Noto Sans JP,sans-serif;font-size:20px;font-weight:700}.phrasebook-en{font-size:14px;color:var(--text-muted);margin-top:2px}.phrasebook-rm{font-size:12px;color:var(--text-muted);opacity:.7}
