:root{--paper:#E7E5DC;--card:#F3F2EC;--ink:#1B1A16;--ink-2:#6C6A60;--ink-3:#9A988C;--line:#CDCBC0;--line-2:#DEDCD2;--accent:#A8392A;--word:#98293A;--word-soft:rgba(152,41,58,.5);--serif:"Newsreader", Georgia, serif;--mincho:"Shippori Mincho", serif;--sans:"Zen Kaku Gothic New", system-ui, sans-serif;--ease:cubic-bezier(.2,.7,.2,1)}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}body{min-height:100vh;font-family:var(--sans);color:var(--ink);background:var(--paper)}.screen{position:relative;width:100%;max-width:480px;margin:0 auto;height:100vh;height:100dvh;overflow:hidden;background:linear-gradient(180deg,#ECEAE1 0%,var(--paper) 24%);display:flex;flex-direction:column}.state{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;padding:0;overflow:hidden}.lhead{flex:0 0 auto;padding:20px 26px 0}.scroll{flex:1 1 auto;overflow-y:auto;overflow-x:hidden;padding:6px 26px;min-height:0}.lfoot{flex:0 0 auto;padding:0 26px 18px;background:var(--paper)}.bar{display:flex;align-items:center;justify-content:space-between;flex:0 0 auto}.iconbtn{width:38px;height:38px;display:grid;place-items:center;cursor:pointer;border:1.5px solid var(--line);border-radius:10px;background:transparent;color:var(--ink);transition:background .18s var(--ease),border-color .18s var(--ease)}.iconbtn:hover{background:var(--card)}.iconbtn:active{background:var(--line-2)}.iconbtn svg{width:19px;height:19px}.runhead{font-family:var(--serif);font-size:13px;letter-spacing:.14em;color:var(--ink-2);text-transform:uppercase}.rule{height:1.5px;background:var(--line);margin:14px 0 0;flex:0 0 auto}.meta{display:flex;align-items:center;justify-content:space-between;margin-top:11px;flex:0 0 auto}.meta .lv{font-family:var(--serif);font-size:15px}.meta .lv b{font-weight:600}.meta .right{display:flex;align-items:center;gap:11px;font-size:12px;color:var(--ink-2)}.meta .track{width:50px;height:3px;background:var(--line);border-radius:2px;overflow:hidden}.meta .track i{display:block;height:100%;width:0;background:var(--accent);transition:width .4s var(--ease)}.recall{margin-top:14px;text-align:center;flex:0 0 auto}.eyebrow{font-size:11px;letter-spacing:.34em;color:var(--ink-3);text-transform:uppercase}.meaning{font-family:var(--mincho);font-weight:600;font-size:29px;line-height:1.32;margin-top:14px;letter-spacing:.02em}.meaning .s{display:block;font-size:15px;color:var(--ink-2);font-weight:500;margin-top:6px}.spell{display:flex;justify-content:center;align-items:flex-end;gap:6px;margin-top:30px;flex-wrap:nowrap;flex:0 0 auto}.glyph{width:32px;height:48px;display:grid;place-items:end center;padding-bottom:6px;font-family:var(--serif);font-size:26px;color:var(--word-soft);border-bottom:2px solid var(--line);transition:border-color .25s var(--ease),width .25s var(--ease)}.tile{width:42px;height:50px;display:grid;place-items:center;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;font-family:var(--serif);font-size:26px;color:var(--word);background:var(--card);border:1.5px solid var(--line);border-radius:5px;box-shadow:0 1px 0 var(--line);transition:transform .15s var(--ease),border-color .15s var(--ease),box-shadow .15s var(--ease),background .25s var(--ease),width .25s var(--ease);animation:rise .45s var(--ease) both}.tile:hover{border-color:var(--ink-2)}.tile.sel{border-color:var(--word);transform:translateY(-8px);box-shadow:0 8px 16px -7px #98293a73}.tile.drag{cursor:grabbing;z-index:3;border-color:var(--word);transform:scale(1.06);box-shadow:0 14px 24px -10px #98293a80;transition:box-shadow .15s var(--ease)}.tile.over{border-color:var(--word);border-style:dashed}.spell.solved{gap:1px}.spell.solved .glyph,.spell.solved .tile{width:auto;min-width:0;padding:0 1px;height:50px;place-items:center;color:var(--word);background:transparent;border:none;box-shadow:none;cursor:default;animation:none}.spell.nope{animation:nudge .35s}.pron{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:16px;flex:0 0 auto}.pron .ipa{font-family:var(--serif);font-style:italic;font-size:16px;color:var(--ink-2);letter-spacing:.04em}.sp{width:38px;height:38px;display:grid;place-items:center;border:1.5px solid var(--line);border-radius:10px;cursor:pointer;color:var(--ink);background:transparent}.sp svg{width:17px;height:17px}.entry{margin-top:6px;flex:1 1 auto}.block{margin-top:22px}.block .lab{font-size:11px;letter-spacing:.24em;color:var(--ink-3);font-weight:700;text-transform:uppercase;padding-bottom:7px;border-bottom:1.5px solid var(--line);margin-bottom:11px}.def{font-family:var(--mincho);font-size:17px;margin-top:6px;line-height:1.5}.def .pos{font-family:var(--sans);font-size:11px;font-weight:700;color:var(--card);background:var(--ink);padding:2px 7px;border-radius:3px;margin-right:9px;vertical-align:2px;letter-spacing:.05em}.cons{display:flex;flex-direction:column;gap:2px;margin-bottom:10px}.cons .ce{font-family:var(--serif);font-size:17px;font-weight:500;color:var(--accent)}.cons .cj{font-family:var(--mincho);font-size:13px;color:var(--ink-2)}.ex .en{font-family:var(--serif);font-size:20.4px;line-height:1.55}.ex .en u{text-decoration:none;background:linear-gradient(transparent 62%,#98293a33 0);color:var(--word);font-weight:500}.ex .ja{font-family:var(--mincho);font-size:16.2px;color:var(--ink-2);margin-top:7px;line-height:1.7}.ph{display:flex;flex-direction:column;gap:1px;margin-bottom:9px}.ph .pe{font-family:var(--serif);font-size:19.2px}.ph .pj{font-family:var(--mincho);font-size:15px;color:var(--ink-2)}.der{display:flex;align-items:baseline;gap:10px;margin-bottom:9px}.der .e{font-family:var(--serif);font-size:21.6px;font-weight:500;color:var(--word)}.der .p{font-family:var(--sans);font-size:10px;font-weight:700;color:var(--card);background:var(--ink-2);padding:1px 6px;border-radius:3px}.der .j{font-family:var(--mincho);font-size:15.6px;color:var(--ink-2)}.note{font-family:var(--mincho);font-size:13.5px;color:var(--ink-2);line-height:1.75;margin-bottom:4px}.mk{color:var(--ink-3);letter-spacing:.08em;font-style:normal}.tw.typing:after{content:"";display:inline-block;width:2px;height:.95em;margin-left:1px;background:var(--word);vertical-align:-1px;animation:caret .7s steps(1) infinite}@keyframes caret{50%{opacity:0}}.mastery{display:flex;align-items:center;justify-content:center;gap:8px;margin:0 0 2px;flex:0 0 auto}.mastery .ticks{display:flex;gap:4px}.mastery .t{width:13px;height:2px;background:var(--line)}.mastery .t.on{background:var(--accent)}.mastery .lab{font-size:10.5px;color:var(--ink-3);letter-spacing:.02em}.mastery .lab b{color:var(--ink-2);font-family:var(--serif)}.act{margin-top:18px;padding-top:16px;border-top:1.5px solid var(--line-2);display:flex;align-items:center;gap:14px;flex:0 0 auto}.btn{flex:1;border:1.5px solid var(--ink);background:var(--ink);color:var(--card);cursor:pointer;font-family:var(--sans);font-weight:500;font-size:15px;letter-spacing:.08em;padding:15px;border-radius:11px;transition:opacity .18s;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.btn:hover{opacity:.9}.btn:active{transform:translateY(1px)}.btn.text{flex:0 0 auto;background:transparent;border:none;color:var(--ink-2);font-size:13px;letter-spacing:.03em}.btn.hold{position:relative;overflow:hidden;touch-action:none}.btn.hold .lab{position:relative;z-index:1}.btn.hold:before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;z-index:0;background:#a8392a24}.btn:not(.text).hold:before{background:#f3f2ec4d}.btn.hold:not(.go):before{transition:width .25s var(--ease)}.btn.hold.go:before{width:100%;transition:width var(--hold-dur,3s) linear}.scrim{position:absolute;top:0;right:0;bottom:0;left:0;background:#14130f66;opacity:0;pointer-events:none;transition:opacity .3s var(--ease);z-index:5}.scrim.open{opacity:1;pointer-events:auto}.sheet{position:absolute;left:0;right:0;bottom:0;z-index:6;background:var(--card);border-top:1.5px solid var(--line);border-radius:22px 22px 0 0;padding:10px 26px 28px;transform:translateY(101%);transition:transform .4s var(--ease);max-height:84%;display:flex;flex-direction:column}.sheet.open{transform:none}.grip{width:38px;height:4px;border-radius:2px;background:var(--line);margin:0 auto 18px}.sheet h3{font-family:var(--mincho);font-weight:600;font-size:19px;letter-spacing:.04em;margin-bottom:18px}.tabs{display:flex;gap:26px;border-bottom:1.5px solid var(--line);margin-bottom:16px}.tabs button{background:none;border:none;cursor:pointer;font-family:var(--sans);font-weight:500;font-size:15px;color:var(--ink-3);padding:0 0 12px;position:relative;letter-spacing:.04em}.tabs button.on{color:var(--ink)}.tabs button.on:after{content:"";position:absolute;left:0;right:0;bottom:-1.5px;height:2px;background:var(--accent)}.tabcap{font-size:12.5px;color:var(--ink-2);margin-bottom:16px;line-height:1.6}.levels{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;overflow:auto;padding:2px;max-height:290px}.lv{aspect-ratio:1;border:1.5px solid var(--line);background:var(--paper);cursor:pointer;font-family:var(--serif);font-size:16px;display:grid;place-items:center;position:relative;transition:border-color .14s,background .14s}.lv:hover{border-color:var(--ink-2)}.lv.cur{background:var(--ink);color:var(--card);border-color:var(--ink)}.lv.off{opacity:.32;cursor:default}.lv.off:hover{border-color:var(--line)}.lv.has:after{content:"";position:absolute;top:5px;right:5px;width:5px;height:5px;background:var(--accent)}.setrow{display:flex;align-items:center;justify-content:space-between;padding:18px 0;border-bottom:1.5px solid var(--line-2)}.setrow .k{font-size:14.5px}.setrow .k small{display:block;color:var(--ink-3);font-size:11.5px;margin-top:3px}.step{display:flex;align-items:center;border:1.5px solid var(--line);border-radius:9px;overflow:hidden}.step button{width:36px;height:36px;border:none;background:transparent;cursor:pointer;color:var(--ink);font-size:18px}.step button:hover{background:var(--paper)}.step span{width:34px;text-align:center;font-family:var(--serif);font-size:17px;line-height:36px;border-left:1.5px solid var(--line);border-right:1.5px solid var(--line)}.toggle{width:48px;height:28px;border-radius:999px;border:1.5px solid var(--line);background:var(--paper);position:relative;cursor:pointer;transition:background .2s}.toggle.on{background:var(--accent);border-color:var(--accent)}.toggle i{position:absolute;top:2px;left:2px;width:22px;height:22px;border-radius:50%;background:var(--card);transition:left .2s var(--ease)}.toggle.on i{left:22px}.hint{font-size:12.5px;color:#56544b;text-align:center;letter-spacing:.03em;max-width:360px;line-height:1.7}@keyframes rise{0%{opacity:0;transform:translateY(12px)}}@keyframes nudge{0%,to{transform:none}25%{transform:translate(-6px)}75%{transform:translate(6px)}}@media (prefers-reduced-motion:reduce){*{animation:none!important;transition-duration:.01ms!important}}.barleft{display:flex;align-items:center;gap:9px}.panel{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;display:flex;flex-direction:column;background:linear-gradient(180deg,#ECEAE1 0%,var(--paper) 26%)}.panel-head{flex:0 0 auto;display:flex;align-items:center;gap:12px;padding:20px 24px 14px;border-bottom:1.5px solid var(--line);font-family:var(--mincho);font-weight:600;font-size:17px}.panel-head>span:first-child{flex:1}.panel-head .qprog{font-family:var(--serif);font-size:14px;color:var(--ink-2);font-weight:400}.panel-head .x{width:34px;height:34px;border:1.5px solid var(--line);border-radius:9px;background:transparent;font-size:20px;line-height:1;color:var(--ink-2);cursor:pointer}.panel-head .x:hover{background:var(--card)}.panel-head .back{border:none;background:none;font-family:var(--sans);font-size:14px;color:var(--accent);cursor:pointer;padding:0}.panel-body{flex:1 1 auto;overflow:auto;padding:24px}.empty{font-size:13.5px;color:var(--ink-2);line-height:1.8;text-align:center;margin-top:40px}.q-eyebrow{font-size:11px;letter-spacing:.28em;color:var(--ink-3);text-transform:uppercase;text-align:center}.q-word{font-family:var(--serif);font-size:40px;font-weight:600;color:var(--word);text-align:center;margin:14px 0 26px;letter-spacing:.01em}.choices{display:flex;flex-direction:column;gap:11px}.choice{font-family:var(--mincho);font-size:16px;text-align:left;padding:16px 18px;border:1.5px solid var(--line);border-radius:12px;background:var(--card);color:var(--ink);cursor:pointer;transition:border-color .15s,background .15s}.choice:hover:not(:disabled){border-color:var(--ink-2)}.choice:disabled{cursor:default}.choice.correct{border-color:var(--accent);background:#a8392a1a;color:var(--accent);font-weight:500}.choice.wrong{border-color:var(--ink-3);background:var(--line-2);opacity:.7}.next-q{margin-top:22px;width:100%}.result{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:10px}.result .score{font-family:var(--serif);font-size:54px;color:var(--word)}.result .score b{font-weight:600}.result .rate{font-size:15px;color:var(--ink-2)}.result-act{display:flex;gap:12px;margin-top:26px;width:100%;max-width:300px}.search{width:100%;padding:13px 16px;border:1.5px solid var(--line);border-radius:11px;background:var(--card);font-family:var(--sans);font-size:15px;color:var(--ink);margin-bottom:16px}.search:focus{outline:none;border-color:var(--ink-2)}.wordlist{list-style:none;display:flex;flex-direction:column}.wordlist li{display:flex;align-items:baseline;gap:12px;padding:14px 4px;border-bottom:1.5px solid var(--line-2);cursor:pointer}.wordlist li:hover{background:var(--card)}.wordlist .w-en{font-family:var(--serif);font-size:18px;color:var(--word);font-weight:500;min-width:96px}.wordlist .w-ja{flex:1;font-family:var(--mincho);font-size:13.5px;color:var(--ink-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wordlist .w-acc{font-family:var(--serif);font-size:13px;color:var(--ink-3)}.wordlist .w-acc.grad{color:var(--accent)}.detail .d-word{font-family:var(--serif);font-size:38px;font-weight:600;color:var(--word)}.detail .d-ipa{font-family:var(--serif);font-style:italic;font-size:16px;color:var(--ink-2);margin-top:2px}.detail .d-mean{font-family:var(--mincho);font-size:15px;line-height:1.7;margin:14px 0 20px}.d-stats{display:flex;gap:14px;margin-bottom:22px}.d-stats>div{flex:1;border:1.5px solid var(--line);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:3px}.d-stats .k{font-size:11px;letter-spacing:.16em;color:var(--ink-3);text-transform:uppercase}.d-stats .v{font-family:var(--serif);font-size:24px;color:var(--ink)}.d-stats small{font-size:11px;color:var(--ink-3)}.hint-sm{font-size:12px;color:var(--ink-2);line-height:1.7;margin-top:12px}.large-text .meaning{font-size:33px}.large-text .def,.large-text .ex .en{font-size:18.5px}
