:root{--bg:#faf8f3;--ink:#1a1a1a;--muted:#6b6357;--line:#e7e2d6;--paper:#fffdf8;--accent:#c0392b;--good:#1e7d3a;--hard:#b8860b;--again:#d35400;--bad:#c0392b}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--bg);color:var(--ink);-webkit-user-select:none;user-select:none;font-family:-apple-system,system-ui,Hiragino Sans,Noto Sans JP,sans-serif;overflow:hidden}.app{flex-direction:column;height:100%;display:flex}.app.center{color:var(--muted);text-align:center;justify-content:center;align-items:center;padding:24px}.appbar{border-bottom:1px solid var(--line);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:8px 14px;display:flex}.appbar .stats{gap:8px;display:flex}.pill{border:1px solid var(--line);border-radius:999px;padding:4px 10px;font:600 13px ui-monospace,monospace}.pill.due{color:var(--good)}.pill.new{color:#2471a3}.appbar .controls{color:var(--muted);align-items:center;gap:14px;font:13px system-ui;display:flex}.toggle,.numset{align-items:center;gap:6px;display:flex}.numset input{border:1px solid var(--line);border-radius:6px;width:52px;padding:4px 6px;font:14px system-ui}.ghost{background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:6px 12px;font:600 13px system-ui}.diagrams{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.diagram{border:1px solid var(--line);background:#fff;border-radius:8px;width:96px;height:96px}.lvl{color:var(--muted);border:1px solid var(--line);border-radius:6px;margin-left:auto;padding:2px 8px;font:600 12px ui-monospace,monospace}.study{min-height:0;padding:4px 8px calc(12px + env(safe-area-inset-bottom));flex-direction:column;flex:1;gap:10px;width:100%;display:flex;overflow:hidden}.fab{background:var(--paper);border:1px solid var(--line);z-index:30;border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;line-height:1;display:flex}.fab:active{transform:scale(.95)}.fab:disabled{opacity:.3}.session{flex-direction:column;height:100%;display:flex}.session-bar{padding:calc(8px + env(safe-area-inset-top)) 8px 4px;align-items:center;gap:8px;display:flex}.icon-btn{background:var(--paper);border:1px solid var(--line);width:34px;height:34px;color:var(--ink);border-radius:10px;justify-content:center;align-items:center;font-size:17px;line-height:1;display:flex}.icon-btn:active{transform:scale(.95)}.icon-btn:disabled{opacity:.3}.counts{gap:6px;margin-left:auto;display:flex}.cnt{text-align:center;color:#fff;border-radius:999px;min-width:34px;padding:4px 11px;font:700 15px ui-monospace,monospace}.cnt.new{background:#2471a3}.cnt.learn{background:var(--again)}.cnt.review{background:var(--good)}.home{flex-direction:column;justify-content:center;align-items:center;gap:28px;height:100%;padding:24px;display:flex;position:relative}.home-title{letter-spacing:.04em;font-size:clamp(28px,5vw,44px);font-weight:700}.overview{gap:48px;display:flex}.ov-stat{flex-direction:column;align-items:center;gap:4px;display:flex}.ov-num{font-size:clamp(44px,9vw,72px);font-weight:800;line-height:1}.ov-num.newc{color:#2471a3}.ov-num.duec{color:var(--good)}.ov-label{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:14px}.home-actions{flex-wrap:wrap;justify-content:center;gap:14px;display:flex}.home-actions button{border:none;border-radius:14px;min-width:180px;padding:16px 32px;font:700 17px system-ui}.home-actions button:active{transform:scale(.98)}.home-actions .primary{background:var(--ink);color:#fff}.home-actions .secondary{background:var(--paper);color:var(--ink);border:1px solid var(--line)}.home-actions button:disabled{opacity:.4}.home-today{color:var(--good);font-size:15px;font-weight:600}.home-foot{color:var(--muted);font-size:13px}.gear{color:var(--muted);background:0 0;border:none;font-size:22px;position:absolute;top:14px;right:16px}.sync-fab{position:absolute;top:10px;left:10px}.home-level{color:var(--accent);font-size:15px;font-weight:600}.settings{flex-direction:column;align-items:flex-start;gap:18px;max-width:480px;margin:0 auto;padding:24px;display:flex}.settings .back{color:var(--muted);background:0 0;border:none;font:600 14px system-ui}.settings h2{font-size:22px}.settings .ghost{text-align:left;width:100%;padding:12px 14px}.set-section{border-top:1px solid var(--line);flex-direction:column;gap:10px;width:100%;padding-top:14px;display:flex}.set-section h3{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-size:13px}.dl-bar{background:var(--line);border-radius:4px;width:100%;height:8px;overflow:hidden}.dl-fill{background:var(--good);height:100%;transition:width .2s}.dl-note{color:var(--muted);font-size:12px}.menu{z-index:30;position:fixed;top:10px;right:10px}.menu-scrim{z-index:25;position:fixed;inset:0}.menu-panel{background:var(--paper);border:1px solid var(--line);border-radius:12px;flex-direction:column;gap:14px;width:250px;padding:14px;display:flex;position:absolute;top:52px;right:0;box-shadow:0 10px 34px #00000029}.menu-stats{gap:8px;display:flex}.menu-panel .ghost{width:100%}.menu-panel .numset input{width:60px}.col-left{flex-direction:column;flex:1;gap:12px;min-height:0;display:flex}.col-right,.answer-area{flex-direction:column;flex:1;min-height:0;display:flex}@media (orientation:landscape) and (width>=760px){.study{flex-direction:row;align-items:stretch;gap:20px}.col-left{flex:1}.col-right{flex:1.15}}.topbar{justify-content:flex-end;display:flex}.count{color:var(--muted);background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:4px 10px;font:600 13px ui-monospace,monospace}.prompt{text-align:center}.sentence{font-size:clamp(20px,3.4vw,30px);line-height:1.7}.cloze{color:var(--accent);border-bottom:2px dashed var(--accent);padding:0 4px;font-weight:700}.instruction{color:var(--muted);margin-top:6px;font-size:13px}.canvas-wrap{flex:1;min-height:220px;position:relative}.pad{touch-action:none;background:linear-gradient(var(--paper), var(--paper)) padding-box, repeating-linear-gradient(0deg, var(--line) 0 1px, transparent 1px 25%), repeating-linear-gradient(90deg, var(--line) 0 1px, transparent 1px 25%);border:1px solid var(--line);border-radius:14px;width:100%;height:100%;display:block}.canvas-tools{gap:8px;display:flex;position:absolute;top:10px;right:10px}.canvas-tools button{color:var(--ink);border:1px solid var(--line);background:#fffdf8eb;border-radius:8px;padding:9px 14px;font:600 13px system-ui}.canvas-tools button:active{transform:scale(.96)}.canvas-tools .tool-erase.on{background:var(--accent);color:#fff;border-color:var(--accent)}.write-controls{height:62px;margin-bottom:10px}.write-controls .reveal-btn{height:100%;margin:0}.write-controls .grades{grid-template-columns:repeat(auto-fit,minmax(108px,1fr));grid-auto-rows:1fr;height:100%;margin-top:0}.write-controls .grade{justify-content:center;height:100%}.reveal-btn{color:#fff;background:var(--ink);border:none;border-radius:12px;width:100%;padding:16px;font:600 16px system-ui}.reveal-btn:active{transform:scale(.99)}.answer{background:var(--paper);border:1px solid var(--line);border-radius:14px;flex:1;min-height:0;padding:14px 16px;overflow-y:auto}.answer-head{justify-content:space-between;align-items:center;gap:14px;display:flex}.kanji-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.kdiagram{border:3px solid var(--line);background:#fff;border-radius:12px;width:clamp(76px,11vw,110px);height:clamp(76px,11vw,110px);padding:4px;position:relative}.kdiagram img{width:100%;height:100%;display:block}.kdiagram:active{transform:scale(.97)}.kdiagram.open{outline:3px solid var(--ink);outline-offset:2px}.kdiagram.stroke{border-color:var(--hard)}.kdiagram.lookalike{border-color:#2471a3}.kdiagram.homophone{border-color:#6c3483}.kdiagram.blank{border-color:var(--bad)}.kdiagram.stroke:after,.kdiagram.lookalike:after,.kdiagram.homophone:after,.kdiagram.blank:after{color:#fff;border-radius:10px;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 4px;font-size:12px;font-weight:700;display:flex;position:absolute;top:-9px;right:-9px}.kdiagram.stroke:after{content:"✎";background:var(--hard)}.kdiagram.lookalike:after{content:"形";background:#2471a3}.kdiagram.homophone:after{content:"音";background:#6c3483}.kdiagram.blank:after{content:"✗";background:var(--bad)}.kfallback{font-size:40px;font-weight:700}.picker{border:1px solid var(--line);background:#fbf7ee;border-radius:12px;margin-top:10px;padding:10px}.picker-head{align-items:center;gap:10px;margin-bottom:8px;display:flex}.picker-kanji{font-size:28px;font-weight:700}.opts{grid-template-columns:repeat(2,1fr);gap:6px;display:grid}.opt{border:1px solid var(--line);color:var(--ink);text-align:left;background:#fff;border-radius:8px;padding:9px 10px;font:600 13px system-ui}.opt .opt-jp{color:var(--muted);font-size:11px}.opt.sel{outline:2px solid var(--ink)}.opt.ok{background:#e6f1e8;margin-left:auto}.opt.stroke.sel{background:#fdf2d8}.opt.lookalike.sel{background:#d6e6f2}.opt.homophone.sel{background:#e8dcf0}.opt.blank.sel{background:#f6dcd8}.cand-label{color:var(--muted);margin-top:8px;font-size:12px}.cand{flex-wrap:wrap;gap:6px;margin-top:6px;display:flex}.candchip{border:1px solid var(--line);background:#fff;border-radius:8px;min-width:44px;padding:4px 12px;font-size:22px;font-weight:700}.candchip.sel{background:var(--ink);color:#fff}.wrote{border:1px solid var(--line);border-radius:8px;width:100%;margin-top:8px;padding:8px 10px;font:16px system-ui}.okuri{border:1px dashed var(--muted);color:var(--muted);background:0 0;border-radius:8px;margin-top:10px;padding:8px 12px;font:600 13px system-ui}.okuri.on{background:var(--hard);border-style:solid;border-color:var(--hard);color:#fff}.kana{color:var(--muted);font-size:clamp(30px,6vw,44px)}.meta-row{align-items:baseline;gap:12px;margin-top:8px;display:flex}.reading{color:var(--accent);font-size:18px;font-weight:600}.meaning{color:var(--muted);font-size:15px}.legend{color:var(--muted);margin-top:8px;font-size:12px}.kanji-info{flex-direction:column;gap:6px;margin-top:10px;display:flex}.ki{text-align:left;border:1px solid var(--line);background:#fff;border-radius:10px;align-items:center;gap:10px;width:100%;padding:7px 11px;font-size:14px;display:flex}.ki:active{background:#f4efe4}.ki-rad{border:1px solid var(--line);background:#faf6ee;border-radius:6px;align-items:center;gap:4px;padding:2px 6px;font-weight:600;display:inline-flex}.ki-rad img{width:18px;height:18px}.ki-ch{font-size:20px;font-weight:700}.ki-yomi b{color:var(--accent);margin-right:2px;font-weight:700}.ki-more{color:var(--muted);white-space:nowrap;margin-left:auto;font-size:12px}.dialog-scrim{z-index:50;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#14120e73;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.dialog{background:var(--paper);border-radius:16px;width:100%;max-width:820px;max-height:88vh;padding:20px 24px;position:relative;overflow-y:auto;box-shadow:0 16px 50px #0000004d}.dlg-cols{columns:2;column-gap:28px;margin-top:14px}.dlg-cols>*{break-inside:avoid;margin:0 0 18px}@media (width<=620px){.dlg-cols{columns:1}}.dialog-close{border:1px solid var(--line);background:#fff;border-radius:9px;width:34px;height:34px;font-size:16px;position:absolute;top:12px;right:12px}.dlg-head{align-items:center;gap:16px;display:flex}.dlg-diagram{border:1px solid var(--line);background:#fff;border-radius:10px;flex-shrink:0;width:104px;height:104px}.dlg-char-big{font-size:72px;font-weight:700;line-height:1}.dlg-char{font-size:30px;font-weight:700}.dlg-sub{color:var(--muted);margin:2px 0 8px;font:600 13px ui-monospace,monospace}.dlg-rad{align-items:center;gap:6px;font-size:15px;display:flex}.dlg-rad img{width:22px;height:22px}.dlg-rad-label{color:var(--muted);background:#f0ebe0;border-radius:5px;padding:2px 6px;font-size:11px}.dlg-rad-char{color:var(--muted)}.dlg-readings{flex-direction:column;gap:6px;margin-top:14px;display:flex}.dlg-row{align-items:baseline;gap:10px;font-size:17px;display:flex}.dlg-label{color:#fff;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:13px;font-weight:700;display:inline-flex}.dlg-label.on{background:var(--accent)}.dlg-label.kun{background:var(--good)}.dlg-mean{color:#2e2a22;margin-top:14px;font-size:15px;line-height:1.7}.dlg-section{margin-top:16px}.dlg-section-title{color:var(--muted);letter-spacing:.06em;border-bottom:1px solid var(--line);margin-bottom:8px;padding-bottom:5px;font-size:12px;font-weight:700}.dlg-words{flex-direction:column;gap:7px;list-style:none;display:flex}.dlg-word{flex-wrap:wrap;align-items:baseline;gap:8px;display:flex}.dw-word{font-size:17px;font-weight:600}.dw-reading{color:var(--accent);font-size:13px}.dw-gloss{color:var(--muted);font-size:13px}.dlg-kchips{flex-wrap:wrap;gap:8px;display:flex}.dlg-kchip{border:1px solid var(--line);background:#fff;border-radius:8px;flex-direction:column;align-items:center;gap:1px;min-width:46px;padding:5px 9px;display:flex}.dlg-kchip.nav{background:#f4f9fd;border-color:#b9cfe0}.dlg-kchip:disabled{opacity:.85}.dk-char{font-size:20px;font-weight:700}.dk-gloss{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;max-width:64px;font-size:9px;overflow:hidden}.legend .forgot{color:var(--again)}.legend .confused{color:#6c3483}.audio{border:1px solid var(--line);background:0 0;border-radius:10px;padding:8px 12px;font-size:22px}.full-sentence{margin-top:10px;font-size:20px}.spk{opacity:.6;font-size:15px}.en{color:var(--muted);margin-top:2px;font-size:14px}.grades{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px;margin-top:14px;display:grid}.grade{color:#fff;border:none;border-radius:12px;flex-direction:column;align-items:center;gap:2px;padding:12px 8px;display:flex}.grade:active{transform:scale(.97)}.g-label{font:700 14px system-ui}.g-sub{opacity:.85;font-size:11px}.g-due{opacity:.9;margin-top:2px;font:600 12px ui-monospace,monospace}.grade.easy{background:#2471a3}.grade.good{background:var(--good)}.grade.hard{background:var(--hard)}.grade.again{background:var(--again)}.grade.bad{background:var(--bad)}.done{text-align:center;flex-direction:column;align-items:center;gap:10px;margin:auto;display:flex}.done h1{color:var(--good);font-size:40px}.done .reviews{color:var(--muted);font-size:14px}.done button{background:var(--paper);border:1px solid var(--line);border-radius:10px;margin-top:8px;padding:10px 18px;font:600 14px system-ui}.game-link{color:var(--ink);background:var(--paper);border:1px solid var(--line);border-radius:12px;align-items:baseline;gap:8px;margin:14px auto 0;padding:12px 20px;font:700 17px system-ui;display:flex}.game-link .gl-sub{color:var(--muted);font:500 12px system-ui}.game-link:active{transform:scale(.99)}.game{min-height:0;padding:12px 14px calc(16px + env(safe-area-inset-bottom));flex-direction:column;flex:1;align-items:center;gap:12px;width:100%;max-width:560px;margin:0 auto;display:flex;overflow-y:auto}.game .back{color:var(--muted);background:0 0;border:none;align-self:flex-start;font:600 14px system-ui}.game-head{justify-content:space-between;align-items:center;width:100%;display:flex}.game-head h2{margin:0}.conn-mistakes{gap:6px;display:flex}.conn-mistakes .dot{background:var(--line);border-radius:50%;width:11px;height:11px;transition:background .2s,transform .2s}.conn-mistakes .dot.used{background:var(--bad);animation:.3s dot-pop}@keyframes dot-pop{0%{transform:scale(1)}50%{transform:scale(1.5)}to{transform:scale(1)}}.conn-solved{flex-direction:column;gap:8px;width:100%;display:flex}.conn-group{text-align:center;color:#2a2410;border-radius:12px;padding:10px 14px}.conn-group .cg-label{font:700 14px system-ui;display:block}.conn-group .cg-members{letter-spacing:6px;margin-top:2px;font-size:24px;display:block}.conn-group.miss{opacity:.72}.conn-group.pop-in{animation:.42s cubic-bezier(.2,.8,.25,1.25) backwards group-in}@keyframes group-in{0%{opacity:0;transform:scale(.8)translateY(-8px)}to{opacity:1;transform:none}}.conn-group.c0{background:#f2d65e}.conn-group.c1{background:#9ec96f}.conn-group.c2{background:#7fb4e6}.conn-group.c3{background:#c39bd8}.conn-grid{grid-template-columns:repeat(4,1fr);gap:8px;width:100%;display:grid}.conn-tile{aspect-ratio:1;color:var(--ink);background:var(--paper);border:1px solid var(--line);border-radius:12px;justify-content:center;align-items:center;font-size:clamp(28px,9vw,40px);transition:transform .1s,background .12s,color .12s,box-shadow .12s;animation:.34s cubic-bezier(.2,.7,.3,1) backwards tile-in;display:flex}.conn-tile:active{transform:scale(.92)}.conn-tile.on{background:var(--ink);color:#fff;border-color:var(--ink);transform:scale(.95);box-shadow:0 6px 16px #0000002e}.conn-tile.wrong{animation:.4s both conn-shake}.conn-tile.pop{animation:.45s both tile-pop}@keyframes tile-in{0%{opacity:0;transform:translateY(12px)scale(.85)}to{opacity:1;transform:none}}@keyframes tile-pop{0%{transform:scale(.95)}35%{transform:translateY(-16px)scale(1.08)}70%{transform:translateY(0)scale(1)}to{transform:scale(.95)}}@keyframes conn-shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-5px)}40%,80%{transform:translate(5px)}}.conn-flash{min-height:22px;color:var(--accent);margin:2px 0;font:600 15px system-ui;animation:.25s flash-in}@keyframes flash-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.conn-actions{align-items:center;gap:10px;width:100%;margin-top:auto;display:flex}.conn-actions .ghost{border-radius:999px;flex:none;padding:13px 18px;font:600 14px system-ui}.conn-actions .ghost:disabled{opacity:.4}.conn-actions .primary{background:var(--ink);color:#fff;letter-spacing:.06em;border:none;border-radius:999px;flex:1;min-height:54px;font:700 18px system-ui;transition:transform 80ms,opacity .2s}.conn-actions .primary:disabled{opacity:.32}.conn-actions .primary:not(:disabled){animation:1.9s ease-out infinite cta-ready}.conn-actions .primary:not(:disabled):active{transform:scale(.97)}@keyframes cta-ready{0%{box-shadow:0 0 #1a1a1a47}70%,to{box-shadow:0 0 0 10px #1a1a1a00}}.conn-result{flex-direction:column;align-items:center;gap:14px;margin:auto 0;display:flex}.conn-result.pop-in{animation:.4s cubic-bezier(.2,.8,.25,1.25) backwards group-in}.conn-result .cr-msg{font:700 24px system-ui;animation:.6s cubic-bezier(.2,.8,.25,1.3) both cr-bounce}@keyframes cr-bounce{0%{opacity:0;transform:scale(.6)}60%{opacity:1;transform:scale(1.12)}to{transform:scale(1)}}.conn-result .secondary{border:1px solid var(--line);background:var(--paper);color:var(--ink);border-radius:999px;padding:13px 30px;font:700 16px system-ui}.game-empty .primary{background:var(--ink);color:#fff;border:none;border-radius:14px;align-self:center;padding:14px 30px;font:700 16px system-ui}@media (prefers-reduced-motion:reduce){.conn-tile,.conn-tile.pop,.conn-group.pop-in,.conn-result.pop-in,.conn-result .cr-msg,.conn-actions .primary:not(:disabled),.conn-flash,.conn-mistakes .dot.used{animation:none}}.game-empty{text-align:center;flex-direction:column;gap:10px;max-width:360px;margin:auto;display:flex}.game-empty .ge-jp{font:700 20px system-ui}.game-empty .ge-en{color:var(--muted);font-size:14px;line-height:1.5}.home-links{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.stats{width:100%;max-width:760px;height:100%;padding:16px 16px calc(24px + env(safe-area-inset-bottom));flex-direction:column;gap:18px;margin:0 auto;display:flex;overflow-y:auto}.stats .back{color:var(--muted);background:0 0;border:none;align-self:flex-start;font:600 14px system-ui}.stats h2{margin:-6px 0 0;font-size:22px}.stats-empty{text-align:center;flex-direction:column;gap:8px;margin:auto;display:flex}.stats-empty .se-jp{font:700 20px system-ui}.stats-empty .se-en{color:var(--muted);font-size:14px}.stat-cards{grid-template-columns:repeat(auto-fit,minmax(96px,1fr));gap:10px;display:grid}.stat-card{background:var(--paper);border:1px solid var(--line);border-radius:12px;flex-direction:column;align-items:center;gap:2px;padding:12px 10px;display:flex}.sc-value{color:var(--ink);white-space:nowrap;font:800 24px/1.1 system-ui}.sc-label{text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-size:11px}.sc-sub{color:var(--muted);font-size:11px}.stat-section{flex-direction:column;gap:8px;display:flex}.stat-section h3{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-size:13px}.chart-wrap{width:100%}.chart-wrap svg{display:block}.hm-0{fill:var(--line)}.hm-1{fill:#cde9d3}.hm-2{fill:#9ed8ad}.hm-3{fill:#57b277}.hm-4{fill:var(--good)}.minibars{background:var(--paper);border:1px solid var(--line);border-radius:10px;overflow:hidden}.minibars .mb{fill:var(--good)}.range-tabs{flex-wrap:wrap;gap:6px;display:flex}.range-tab{background:var(--paper);border:1px solid var(--line);color:var(--muted);cursor:pointer;border-radius:999px;padding:5px 12px;font:600 13px system-ui}.range-tab.active{background:var(--good);border-color:var(--good);color:#fff}.breakdown{flex-direction:column;gap:6px;display:flex}.bd-row{grid-template-columns:92px 1fr 40px;align-items:center;gap:8px;display:grid}.bd-label{color:var(--ink);font-size:13px}.bd-track{background:var(--line);border-radius:7px;height:14px;overflow:hidden}.bd-fill{background:var(--muted);border-radius:7px;min-width:2px;height:100%;display:block}.bd-fill.bd-again{background:var(--again)}.bd-fill.bd-hard{background:var(--hard)}.bd-fill.bd-good{background:var(--good)}.bd-fill.bd-easy{background:#2471a3}.bd-val{color:var(--muted);text-align:right;font:600 13px ui-monospace,monospace}
