@import"https://fonts.googleapis.com/css2?family=Fredoka:wght@400;500;600&family=Nunito:wght@400;600&display=swap";:root{--color-background: #f5ddd0;--color-surface: #fff7f2;--color-border: #e8c9ba;--color-text-primary: #3d2c23;--color-text-muted: #9b7a70;--color-primary: #3db54a;--color-primary-hover: #35a241;--color-accent: #29b5e8;--color-accent-hover: #1fa3d4;--color-success: #3db54a;--color-warning: #e8a85c;--color-error: #e85c5c;--color-wordmark-start: #3db54a;--color-wordmark-end: #29b5e8;--font-display: "Fredoka", sans-serif;--font-body: "Nunito", sans-serif;--type-display-size: 32px;--type-display-weight: 600;--type-display-line-height: 1.2;--type-display-letter-spacing: -.02em;--type-h1-size: 26px;--type-h1-weight: 600;--type-h1-line-height: 1.3;--type-h1-letter-spacing: -.01em;--type-h2-size: 20px;--type-h2-weight: 500;--type-h2-line-height: 1.4;--type-h2-letter-spacing: 0;--type-h3-size: 16px;--type-h3-weight: 500;--type-h3-line-height: 1.4;--type-h3-letter-spacing: 0;--type-body-size: 15px;--type-body-weight: 400;--type-body-line-height: 1.6;--type-body-letter-spacing: 0;--type-caption-size: 12px;--type-caption-weight: 400;--type-caption-line-height: 1.4;--type-caption-letter-spacing: .01em;--type-label-size: 11px;--type-label-weight: 600;--type-label-line-height: 1.2;--type-label-letter-spacing: .06em;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-base: 16px;--spacing-lg: 20px;--spacing-xl: 24px;--spacing-2xl: 30px;--spacing-3xl: 36px;--radius-sm: 8px;--radius-md: 16px;--radius-lg: 24px;--radius-pill: 9999px;--shadow-sm: 0 1px 3px rgba(61, 44, 35, .08);--shadow-md: 0 4px 12px rgba(61, 44, 35, .1);--shadow-lg: 0 8px 24px rgba(61, 44, 35, .12);--animation-fast: .12s;--animation-normal: .2s;--animation-slow: .35s;--animation-spring: .45s;--animation-easing: cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--color-background: #151e18;--color-surface: #243028;--color-border: #3a4a3f;--color-text-primary: #f0ebe4;--color-text-muted: #a89e94;--color-primary: #5ec269;--color-primary-hover: #4db85a;--color-accent: #e8a85c;--color-accent-hover: #d4964e;--color-success: #5ec269;--color-warning: #e8a85c;--color-error: #e85c5c;--color-wordmark-start: #5ec269;--color-wordmark-end: #e8a85c;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .25);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .3)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){--color-background: #151e18;--color-surface: #243028;--color-border: #3a4a3f;--color-text-primary: #f0ebe4;--color-text-muted: #a89e94;--color-primary: #5ec269;--color-primary-hover: #4db85a;--color-accent: #e8a85c;--color-accent-hover: #d4964e;--color-success: #5ec269;--color-warning: #e8a85c;--color-error: #e85c5c;--color-wordmark-start: #5ec269;--color-wordmark-end: #e8a85c;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .25);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .3)}}.btn{border:0;border-radius:var(--radius-pill);padding:11px 22px;background:var(--color-primary);color:#fff;font-family:var(--font-body);font-weight:700;font-size:15px;cursor:pointer;transition:background .2s,transform .15s;white-space:nowrap}.btn:hover:not(:disabled){background:var(--color-primary-hover);transform:scale(1.03)}.btn:disabled{opacity:.5;cursor:default}.btn.secondary{background:#b482642e;color:#5a3020}.btn.secondary:hover:not(:disabled){background:#b4826447;transform:scale(1.03)}.knowledge-detail{display:flex;flex-direction:column;gap:8px}.knowledge-prompt-section{display:flex;flex-direction:column;gap:4px}.knowledge-prompt-value{font-family:var(--font-body);font-size:18px;font-weight:800;color:var(--color-text-primary);line-height:1.3}.knowledge-answer-section{display:flex;flex-direction:column;gap:4px;padding-top:6px;border-top:2px solid var(--color-border)}.knowledge-answer-value{font-family:var(--font-body);font-size:15px;font-weight:600;color:#5a3020;line-height:1.4}.knowledge-generic{margin:0;display:flex;flex-direction:column;gap:6px}.knowledge-generic-row{display:flex;gap:8px;align-items:baseline}.knowledge-generic-key{font-family:var(--font-body);font-size:11px;font-weight:800;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;min-width:80px;flex-shrink:0}.knowledge-generic-value{font-family:var(--font-body);font-size:14px;font-weight:600;color:var(--color-text-primary);margin:0}.review-card{display:flex;flex-direction:column;gap:20px}.review-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.review-prompt{display:flex;flex-direction:column;gap:6px;padding:24px;background:var(--color-surface);border:2px solid var(--color-border);border-radius:14px;min-height:100px;justify-content:center;align-items:center;text-align:center}.review-prompt-value{font-family:var(--font-body);font-size:28px;font-weight:800;color:var(--color-text-primary);line-height:1.25}.review-answer{display:flex;flex-direction:column;gap:6px;padding:20px 24px;background:#3db54a0f;border:2px solid rgba(61,181,74,.22);border-radius:14px;text-align:center;align-items:center}.review-answer-value{font-family:var(--font-body);font-size:20px;font-weight:700;color:#2a8a35;line-height:1.4}.review-score-buttons{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.review-page-heading{font-family:var(--font-display);font-size:32px;font-weight:600;margin:0;color:var(--color-text-primary)}.review-summary{display:flex;flex-direction:column;align-items:center;gap:24px;padding:32px 28px;background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-md)}.review-summary-header{display:flex;flex-direction:column;align-items:center;gap:4px}.review-summary-title{font-family:var(--font-display);font-size:28px;font-weight:600;margin:0;color:var(--color-text-primary)}.review-summary-count{font-family:var(--font-body);font-size:15px;font-weight:600;color:var(--color-text-muted)}.review-summary-stats{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;width:100%}.review-stat{flex:1;min-width:90px;display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 12px;border-radius:14px}.review-stat-number{font-family:var(--font-display);font-size:36px;font-weight:600;line-height:1}.review-stat-label{font-family:var(--font-body);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.review-stat-mastered{background:#3db54a14;border:2px solid rgba(61,181,74,.18)}.review-stat-mastered .review-stat-number,.review-stat-mastered .review-stat-label{color:#2a8a35}.review-stat-strengthened{background:#29b5e814;border:2px solid rgba(41,181,232,.18)}.review-stat-strengthened .review-stat-number,.review-stat-strengthened .review-stat-label{color:#1a7da0}.review-stat-improve{background:#c9a0801f;border:2px solid rgba(201,160,128,.25)}.review-stat-improve .review-stat-number,.review-stat-improve .review-stat-label{color:#8a6040}.review-summary-next{display:flex;flex-direction:column;align-items:center;gap:2px;padding:14px 24px;background:var(--color-surface);border-radius:12px;width:100%}.review-summary-next-label{font-family:var(--font-body);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.review-summary-next-time{font-family:var(--font-display);font-size:22px;font-weight:500;color:#5a3020}.morpheme-review{display:flex;flex-direction:column;align-items:center;gap:18px}.morpheme-review-prompt{font-family:var(--font-body);font-size:22px;font-weight:600;color:#5a3020;margin:0;text-align:center}.morpheme-review-prompt strong{font-size:28px;font-weight:800;color:var(--color-text-primary)}.kanji-writer-canvas{background:var(--color-surface);border:2px solid var(--color-border);border-radius:14px;display:flex;align-items:center;justify-content:center;cursor:crosshair;touch-action:none;transition:border-color .2s,box-shadow .2s}.kanji-writer-canvas:hover{border-color:#d4b0a0}.kanji-writer-canvas:active{border-color:var(--color-primary);box-shadow:0 0 0 3px #3db54a1f}.kanji-writer-fallback{background:var(--color-surface);border:2px solid var(--color-border);border-radius:14px;display:flex;align-items:center;justify-content:center}.kanji-writer-static{font-size:64px;color:var(--color-text-muted)}.morpheme-kanji{font-size:68px;font-weight:600;line-height:1;color:var(--color-text-primary);text-align:center}.morpheme-meaning{font-family:var(--font-body);font-size:20px;font-weight:700;color:#5a3020;text-align:center}.morpheme-radicals{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.morpheme-radical-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;background:#3db54a14;border:1px solid rgba(61,181,74,.2);border-radius:var(--radius-pill);font-size:14px;font-weight:600;color:#2a8a35}.morpheme-radical-char{font-size:18px}.morpheme-radical-meaning{color:#5a3020;font-weight:500}.morpheme-readings,.cloze-readings{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}.morpheme-reading,.cloze-reading{font-family:var(--font-body);font-size:17px;font-weight:600;color:var(--color-text-muted);letter-spacing:.03em}.cloze-reading-line{display:flex;align-items:center;gap:10px;justify-content:center;margin:0}.cloze-correct-kanji-inline{font-size:28px;font-weight:700;color:#2a8a35}.morpheme-result-feedback{font-family:var(--font-body);font-size:15px;font-weight:600;color:var(--color-text-muted);margin:0;text-align:center}.cloze-review{display:flex;flex-direction:column;align-items:center;gap:22px}.cloze-sentence{font-family:var(--font-body);font-size:26px;font-weight:700;color:var(--color-text-primary);text-align:center;line-height:1.5;margin:0;padding:20px 24px;background:var(--color-surface);border:2px solid var(--color-border);border-radius:14px;width:100%}.cloze-choices{display:grid;grid-template-columns:1fr 1fr;gap:12px;width:100%;max-width:340px}.cloze-choice{font-family:var(--font-body);font-size:36px;font-weight:700;color:var(--color-text-primary);padding:16px 12px;background:var(--color-surface);border:2px solid var(--color-border);border-radius:14px;cursor:pointer;transition:border-color .15s,background .15s,transform .1s,box-shadow .15s;text-align:center;line-height:1}.cloze-choice:hover:not(:disabled){border-color:#d4b0a0;background:var(--color-surface);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.cloze-choice:active:not(:disabled){transform:translateY(0)}.cloze-choice:disabled{cursor:default}.cloze-choice.cloze-correct{background:#3db54a1a;border-color:var(--color-primary);color:#2a8a35}.cloze-choice.cloze-wrong{background:#c3392b14;border-color:var(--color-error);color:var(--color-error)}.cloze-choice.cloze-dimmed{opacity:.4}.cloze-explanation{display:flex;flex-direction:column;align-items:center;gap:10px;padding:18px 24px;background:#3db54a0f;border:2px solid rgba(61,181,74,.18);border-radius:14px;width:100%}.cloze-correct-kanji{font-size:44px;font-weight:700;color:#2a8a35;line-height:1}.cloze-full-sentence{font-family:var(--font-body);font-size:18px;font-weight:600;color:var(--color-text-primary);text-align:center;line-height:1.5;margin:0}.cloze-story{font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--color-text-muted);text-align:center;line-height:1.5;margin:0;font-style:italic}.usage-detail{display:flex;flex-direction:column;align-items:center;gap:12px}.usage-kanji{font-size:56px;font-weight:600;line-height:1;color:var(--color-text-primary);text-align:center}.usage-sentence{font-family:var(--font-body);font-size:18px;font-weight:600;color:#5a3020;text-align:center;line-height:1.5}.usage-story{font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--color-text-muted);font-style:italic;text-align:center;padding:12px 16px;background:var(--color-surface);border-radius:10px;margin:0;line-height:1.5}.direction-grid-review{display:flex;flex-direction:column;align-items:center;gap:18px}.direction-grid-header{display:flex;justify-content:space-between;width:100%;max-width:320px;font-family:var(--font-body);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted)}.direction-grid-hints{width:100%;max-width:320px;padding:12px 16px;background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:10px}.direction-grid-hints ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.direction-grid-hints li{font-family:var(--font-body);font-size:14px;color:var(--color-text-primary);line-height:1.4}.direction-grid-hints li strong{font-weight:800;color:var(--color-primary)}.direction-grid-container{display:flex;justify-content:center}.direction-grid{display:inline-grid;gap:0;image-rendering:pixelated;position:relative;border:2px solid var(--color-border);border-radius:8px;overflow:hidden}.direction-grid-tile{width:var(--tile-size, 32px);height:var(--tile-size, 32px);position:relative}.direction-grid-tree{image-rendering:pixelated;pointer-events:none}.direction-grid-chest-glow{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:2px;animation:chest-glow 1.5s ease-in-out infinite;pointer-events:none}@keyframes chest-glow{0%,to{box-shadow:inset 0 0 4px #ffd70000}50%{box-shadow:inset 0 0 8px #ffd70066}}.direction-grid-player{position:absolute;transition:left .25s ease-out,top .25s ease-out;pointer-events:none}.player-sprite-img{image-rendering:pixelated}.player-confused-indicator{position:absolute;top:-16px;left:50%;transform:translate(-50%);font-size:14px;animation:confused-pop .3s ease-out;z-index:30}@keyframes confused-pop{0%{transform:translate(-50%) scale(0)}50%{transform:translate(-50%) scale(1.3)}to{transform:translate(-50%) scale(1)}}.direction-grid-speech{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:#fff;color:#1a1a2e;padding:4px 8px;border-radius:8px;font-family:var(--font-body);font-size:11px;white-space:nowrap;z-index:20;font-weight:600;opacity:0;transition:opacity .3s}.direction-grid-speech.visible{opacity:1}.direction-grid-speech:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:#fff}.direction-grid-history{width:100%;max-width:320px;display:flex;flex-direction:column;gap:8px;max-height:160px;overflow-y:auto;padding:12px;background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:10px}.direction-grid-history-entry{display:flex;flex-direction:column;gap:2px}.history-user{font-family:var(--font-body);font-size:13px;font-weight:600;color:var(--color-text-primary)}.history-response{font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--color-text-muted);padding-left:8px}.history-response.history-clear{color:#2a8a35}.history-response.history-unclear,.history-response.history-wrong_language{color:var(--color-error, #c0392b)}.history-moves{font-weight:700;color:var(--color-primary)}.direction-grid-transcript{font-family:var(--font-body);font-size:15px;font-weight:600;color:var(--color-text-primary);text-align:center;padding:8px 16px;background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:10px;width:100%;max-width:320px;min-height:2em}.direction-grid-controls{display:flex;justify-content:center;gap:10px}.direction-grid-record.recording{background:var(--color-error, #c0392b)}.direction-grid-record.recording:hover:not(:disabled){background:#a93226}.direction-grid-processing{font-family:var(--font-body);font-size:14px;font-weight:600;color:var(--color-text-muted)}[data-theme=dark] .review-answer{background:#5ec2690f;border-color:#5ec26938}[data-theme=dark] .cloze-explanation{background:#5ec2690f;border-color:#5ec2692e}[data-theme=dark] .cloze-choice.cloze-correct{background:#5ec2691a}[data-theme=dark] .cloze-choice.cloze-wrong{background:#e85c5c14}[data-theme=dark] .btn.secondary{background:#a89e942e;color:var(--color-text-primary)}[data-theme=dark] .btn.secondary:hover:not(:disabled){background:#a89e9447}[data-theme=dark] .review-stat-mastered{background:#5ec26914;border-color:#5ec2692e}[data-theme=dark] .review-stat-strengthened{background:#29b5e814;border-color:#29b5e82e}[data-theme=dark] .review-stat-improve{background:#a89e941a;border-color:#a89e9433}[data-theme=dark] .kanji-writer-canvas:active{box-shadow:0 0 0 3px #5ec26926}[data-theme=dark] .morpheme-radical-chip{background:#5ec26914;border-color:#5ec26933}[data-theme=dark] .knowledge-answer-value,[data-theme=dark] .review-summary-next-time,[data-theme=dark] .morpheme-review-prompt,[data-theme=dark] .morpheme-meaning,[data-theme=dark] .morpheme-radical-meaning,[data-theme=dark] .usage-sentence{color:var(--color-text-primary)}[data-theme=dark] .review-answer-value,[data-theme=dark] .review-stat-mastered .review-stat-number,[data-theme=dark] .review-stat-mastered .review-stat-label,[data-theme=dark] .morpheme-radical-chip,[data-theme=dark] .cloze-correct-kanji,[data-theme=dark] .cloze-correct-kanji-inline,[data-theme=dark] .cloze-choice.cloze-correct{color:var(--color-primary)}[data-theme=dark] .review-stat-strengthened .review-stat-number,[data-theme=dark] .review-stat-strengthened .review-stat-label{color:#4ec8f0}[data-theme=dark] .review-stat-improve .review-stat-number,[data-theme=dark] .review-stat-improve .review-stat-label{color:var(--color-text-muted)}[data-theme=dark] .kanji-writer-canvas:hover,[data-theme=dark] .cloze-choice:hover:not(:disabled){border-color:var(--color-primary)}*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:var(--font-body);background:var(--color-background);color:var(--color-text-primary)}.err{color:var(--color-error);font-size:14px;font-family:var(--font-body);font-weight:600}.muted{color:var(--color-text-muted);font-size:14px;font-family:var(--font-body);font-weight:500}.card{background:var(--color-surface);border-radius:var(--radius-md);padding:20px;box-shadow:var(--shadow-md)}.col{display:flex;flex-direction:column;gap:12px}
