.reference-image{display:block;width:100%;max-width:320px;max-height:30vh;margin:0 auto 8px;object-fit:contain}.reference-image--fallback{width:100%;max-width:320px;margin:0 auto 8px;padding:8px;text-align:center;color:#888;border:1px dashed #ccc;border-radius:6px;box-sizing:border-box}.canvas-underlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;pointer-events:none}.mini-canvas{position:relative;width:100%;max-width:320px;aspect-ratio:1 / 1;background:var(--color-surface);border-radius:20px;box-shadow:var(--shadow-inset);touch-action:none;overflow:hidden}.mini-canvas__svg,.mini-canvas__canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.draw-settings{position:fixed;left:50%;bottom:0;transform:translate(-50%);z-index:50;display:flex;flex-direction:column;gap:12px;width:100%;max-width:420px;max-height:85dvh;overflow-y:auto;overscroll-behavior:contain;touch-action:auto;padding:16px;padding-bottom:calc(16px + env(safe-area-inset-bottom));background:var(--color-surface);border-radius:20px 20px 0 0;box-shadow:0 -6px 24px #503c282e}.draw-settings__preview{width:100%;max-width:200px;margin:0 auto;aspect-ratio:1 / 1;background:var(--color-bg);border-radius:12px;overflow:hidden}.draw-settings__preview svg{width:100%;height:100%}.draw-settings__sample{fill:var(--color-ink);stroke:none}.draw-settings__row{display:flex;flex-direction:column;gap:6px;font-size:17px;color:var(--color-ink)}.draw-settings__row input[type=range]{width:100%;height:44px}.draw-settings__toggle{display:flex;align-items:center;gap:10px;min-height:44px;font-size:17px;color:var(--color-ink)}.draw-settings__toggle input[type=checkbox]{width:24px;height:24px}.draw-settings__actions{display:flex;gap:12px}.draw-settings__reset,.draw-settings__close{min-height:44px;padding:0 16px;font-size:17px;font-family:inherit;border:none;border-radius:14px;cursor:pointer}.draw-settings__reset{background:var(--color-track);color:var(--color-ink)}.draw-settings__close{background:var(--color-primary);color:var(--color-surface)}.finish-screen{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:32px;text-align:center}.finish-screen__burst{font-size:64px;line-height:1}.finish-screen__message{margin:0;font-size:20px;font-weight:700;line-height:1.5;color:var(--color-ink)}.finish-screen__xp{display:inline-flex;align-items:baseline;gap:2px;margin:0;color:var(--color-primary);font-weight:700}.finish-screen__xp-plus{font-size:24px}.finish-screen__xp-value{font-size:40px}.finish-screen__xp-unit{font-size:20px}.finish-screen__actions{display:flex;flex-direction:column;gap:12px;width:100%;max-width:280px;margin-top:8px}.finish-screen__secondary{min-height:56px;padding:0 24px;border:2px solid var(--color-track-strong);border-radius:999px;background:var(--color-surface);color:var(--color-ink);font-size:17px;font-weight:700;cursor:pointer}.finish-screen__feedback{min-height:48px;padding:0 24px;border:none;border-radius:999px;background:transparent;color:var(--color-accent);font-size:15px;font-weight:700;text-decoration:underline;cursor:pointer}.finish-screen__feedback:disabled{color:var(--color-ink-soft);text-decoration:none;cursor:default;opacity:.6}.choice-grid{display:flex;flex-direction:column;gap:16px;width:100%;max-width:320px}.canvas-question{display:flex;flex-direction:column;align-items:center;gap:20px;width:100%}.place-surface{position:relative;width:100%;max-width:320px;aspect-ratio:1 / 1;background:var(--color-surface);border-radius:20px;box-shadow:var(--shadow-inset);touch-action:none;overflow:hidden}.place-target{position:absolute;transform:translate(-50%,-50%);border:2px dashed var(--color-track-strong);border-radius:50%;pointer-events:none}.place-part{position:absolute;display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;padding:2px 6px;border:2px solid var(--color-part);border-radius:12px;background:var(--color-accent);color:var(--color-surface);font-size:12px;font-weight:700;transform:translate(-50%,-50%);cursor:grab;touch-action:none}.place-part--placed{border-color:var(--color-correct);background:var(--color-correct);cursor:default}.draw-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;align-items:center}.draw-undo{min-height:60px;min-width:96px;padding:0 20px;border:2px solid var(--color-track-strong);border-radius:999px;background:var(--color-surface);color:var(--color-ink);font-size:16px;font-weight:700;cursor:pointer}.draw-undo:disabled{opacity:.4;cursor:default}.draw-settings-toggle{min-height:60px;min-width:96px;padding:0 18px;border:2px solid var(--color-track-strong);border-radius:999px;background:var(--color-surface);color:var(--color-ink);font-size:16px;font-weight:700;cursor:pointer}.draw-settings-toggle[aria-expanded=true]{background:var(--color-track)}.choice-btn{min-height:60px;padding:12px 20px;border:2px solid var(--color-track-strong);border-radius:16px;background:var(--color-surface);color:var(--color-ink);font-size:18px;font-weight:700;box-shadow:var(--shadow-soft);cursor:pointer;transition:transform .1s ease,border-color .2s ease,background-color .2s ease}.choice-btn:active{transform:scale(.98)}.choice-btn--wrong{border-color:var(--color-wrong);background:var(--color-wrong-soft);color:var(--color-wrong-ink);animation:choice-shake .5s ease}@keyframes choice-shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.character-bubble{display:flex;align-items:center;gap:12px;margin:0 16px;padding:12px 16px;background:var(--color-surface);border-radius:18px;box-shadow:var(--shadow-soft)}.character-bubble__avatar{flex:0 0 auto;display:flex;align-items:center;justify-content:center;width:44px;height:44px;font-size:28px;background:var(--color-bg);border-radius:50%}.character-bubble__text{margin:0;font-size:17px;font-weight:700;line-height:1.4;color:var(--color-ink)}.progress-bar{display:flex;gap:8px;align-items:center;justify-content:center;padding:12px 16px}.progress-bar__dot{width:10px;height:10px;border-radius:50%;background:var(--color-track);transition:background-color .2s ease,transform .2s ease}.progress-bar__dot--done{background:var(--color-accent)}.progress-bar__dot--current{background:var(--color-primary);transform:scale(1.4)}.lesson-runner{flex:1 1 auto;min-height:0;display:flex;flex-direction:column}.lesson-runner__question{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:24px;text-align:center}.lesson-runner__next{min-height:60px;min-width:160px;padding:0 32px;border:none;border-radius:999px;background:var(--color-primary);color:#fff;font-size:18px;font-weight:700;box-shadow:var(--shadow-soft);cursor:pointer}.lesson-runner__next:active{transform:translateY(1px)}.lesson-runner--done{flex:1 1 auto;display:flex;align-items:center;justify-content:center}.lesson-runner__done-text{font-size:24px;font-weight:700;color:var(--color-primary)}.course-screen{flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:16px 16px 32px}.course-screen__header{padding:8px 4px 16px}.course-screen__title{margin:0;font-size:24px;font-weight:700;color:var(--color-ink)}.course-screen__sub{margin:4px 0 0;font-size:15px;color:var(--color-ink-soft)}.course-unit{margin-top:20px}.course-unit__title{margin:0 0 10px;font-size:17px;font-weight:700;color:var(--color-ink)}.course-unit__lessons{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.lesson-card{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;min-height:56px;padding:12px 16px;border:2px solid var(--color-track-strong);border-radius:16px;background:var(--color-surface);color:var(--color-ink);font-size:17px;font-weight:700;text-align:left;box-shadow:var(--shadow-soft);cursor:pointer}.lesson-card:active{transform:scale(.99)}.lesson-card--special{border-color:var(--color-primary)}.lesson-card__badge{flex:0 0 auto;padding:2px 10px;border-radius:999px;background:var(--color-primary);color:#fff;font-size:12px}:root{--color-bg: #fdf6ec;--color-backdrop: #ece2d2;--color-surface: #ffffff;--color-ink: #3a3a3a;--color-ink-soft: #93897b;--color-primary: #ff8a5b;--color-accent: #6cc6c9;--color-correct: #4caf8f;--color-correct-soft: #e6f6ef;--color-correct-ink: #1f7a5a;--color-wrong: #e5634d;--color-wrong-soft: #fcebe7;--color-wrong-ink: #b23a28;--color-track: #ece2d2;--color-track-strong: #cdbfaa;--color-part: #7a5c43;--shadow-soft: 0 6px 16px rgba(80, 60, 40, .12);--shadow-inset: inset 0 0 0 2px rgba(120, 100, 80, .06);--font-rounded: "Hiragino Maru Gothic ProN", "ヒラギノ丸ゴ ProN W4", "Quicksand", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}html{overscroll-behavior:none}body{font-family:var(--font-rounded);color:var(--color-ink);background:var(--color-backdrop);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;-webkit-text-size-adjust:100%;user-select:none;-webkit-user-select:none;touch-action:manipulation}#root{display:flex;justify-content:center;align-items:stretch}.app-shell{position:relative;width:100%;max-width:420px;height:100dvh;min-height:100dvh;background:var(--color-bg);overflow:hidden;display:flex;flex-direction:column;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);box-shadow:0 0 40px #00000014}.screen{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;width:100%}button{font-family:inherit}
