:root{--bg: #0f1115;--surface: #1a1d24;--surface-2: #242833;--border: #2e3440;--text: #e6e8ee;--muted: #9aa1b1;--accent: #7c8cff;--accent-ink: #fff;--ok: #3fce8f;--err: #ff6b6b;--tabbar-h: 56px}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Hiragino Kaku Gothic ProN,Segoe UI,system-ui,sans-serif;-webkit-text-size-adjust:100%;overscroll-behavior:none;touch-action:manipulation;-webkit-tap-highlight-color:transparent}#app{min-height:100%;min-height:100dvh;display:flex;flex-direction:column;background:var(--bg)}.view{flex:1;background:var(--bg);padding:max(16px,env(safe-area-inset-top)) 16px calc(var(--tabbar-h) + env(safe-area-inset-bottom) + 16px);overflow-y:auto}.view h1{font-size:22px;margin:8px 0 16px}.muted{color:var(--muted)}.tabbar{position:fixed;left:0;right:0;bottom:0;height:calc(var(--tabbar-h) + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);display:flex;background:var(--surface);border-top:1px solid var(--border);z-index:10}.tabbar button{flex:1;background:none;border:none;color:var(--muted);font-size:11px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer}.tabbar button .ico{font-size:20px;line-height:1}.tabbar button.active{color:var(--accent)}.field{margin-bottom:14px}.field label{display:block;font-size:13px;color:var(--muted);margin-bottom:6px}.field input{width:100%;padding:12px;font-size:16px;background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--text)}.field input:focus{outline:none;border-color:var(--accent)}button.btn{width:100%;padding:14px;font-size:16px;font-weight:600;border:none;border-radius:10px;background:var(--accent);color:var(--accent-ink);cursor:pointer}button.btn.secondary{background:var(--surface-2);color:var(--text)}button.btn.danger{background:#d9534f;color:#fff}button.btn:disabled{opacity:.5}.prompt-input{width:100%;padding:12px;margin-bottom:12px;font-size:16px;border:1px solid var(--border);border-radius:10px;background:var(--surface-2);color:var(--text);box-sizing:border-box}.row{display:flex;gap:10px}.row>*{flex:1}.status{margin-top:14px;font-size:14px;min-height:20px}.status.ok{color:var(--ok)}.status.err{color:var(--err);white-space:pre-wrap}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:14px}.head-row{display:flex;align-items:center;justify-content:space-between}.head-row h1{margin:8px 0 12px}button.mini{padding:7px 14px;font-size:13px;font-weight:600;border:none;border-radius:8px;background:var(--accent);color:var(--accent-ink);cursor:pointer}button.mini.danger{background:var(--surface-2);color:var(--muted)}button.mini.secondary{background:var(--surface-2);color:var(--text)}button.mini:disabled{background:var(--surface-2);color:var(--muted);cursor:default}.mini svg{width:1.25em;height:1.25em;vertical-align:-.22em}.ico-btn{display:inline-flex;align-items:center;gap:5px}.ico-btn svg{width:1.1em;height:1.1em}.tabbar button .ico{display:inline-flex}.tabbar button .ico svg{display:block}.chev svg{width:18px;height:18px;display:block}.lib-crumbs .crumb-sep svg{width:13px;height:13px;display:block}.src-pin{display:inline-flex}.src-pin svg{width:13px;height:13px}.lbl-ico{display:inline-flex;gap:2px;color:var(--muted);vertical-align:-.2em}.lbl-ico svg{width:1.1em;height:1.1em}.ib-ico{display:inline-flex;vertical-align:-.22em}.ib-ico svg{width:1.15em;height:1.15em}.install-banner .ib-x svg{width:18px;height:18px;display:block}.item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:10px}.item-ico{font-size:24px}.item-body{flex:1;min-width:0}.folder-row{cursor:pointer}.folder-row:active{background:var(--surface-2)}.item.playable{cursor:pointer}.item.playable:active{background:var(--surface-2)}.item.undl .item-ico,.item.undl .item-name,.item.undl .item-meta{opacity:.42}.play-hint{display:inline-flex;align-items:center;color:var(--accent);font-size:22px;margin-right:2px}.play-hint svg{width:1em;height:1em;display:block}.play-hint.locked-ico{color:var(--muted);font-size:18px}.item.locked-row .item-ico,.item.locked-row .item-name{opacity:.55}.lib-crumbs{display:flex;align-items:center;flex-wrap:wrap;gap:4px;font-size:13px;margin-bottom:8px}.lib-crumbs .crumb{color:var(--accent);cursor:pointer;white-space:nowrap}.lib-crumbs .crumb.current{color:var(--muted);cursor:default}.lib-crumbs .crumb-sep{color:var(--muted)}.item-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-meta{font-size:12px;margin-top:2px}.badge{display:inline-block;font-size:10px;padding:1px 6px;border-radius:6px;background:var(--surface-2);color:var(--accent);margin-left:4px}.item-action{flex-shrink:0}.paywall-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;padding:24px;z-index:2147483646}.paywall{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px 20px;max-width:340px;width:100%;text-align:center}.paywall-lock{color:var(--accent);font-size:34px;line-height:1;margin-bottom:8px}.paywall-lock svg{width:1em;height:1em}.paywall-title{font-weight:700;font-size:18px;margin-bottom:8px}.paywall-desc{color:var(--muted);font-size:14px;line-height:1.6;margin:0 0 16px}.paywall .btn{margin-bottom:8px}.paywall-note{color:var(--muted);font-size:11px;margin-top:8px;line-height:1.5}.mini.locked{opacity:.8}.mini.ico-only{padding:8px;line-height:0}.mini.ico-only svg{width:1.4em;height:1.4em;vertical-align:middle}.sheet-overlay{align-items:flex-end;justify-content:center;padding:0}.menu-sheet{background:var(--surface);border-top-left-radius:18px;border-top-right-radius:18px;padding:10px 14px calc(18px + env(safe-area-inset-bottom));width:100%;max-width:520px;box-shadow:0 -8px 24px #0000004d}.menu-head{font-weight:700;font-size:15px;padding:10px 8px 12px;border-bottom:1px solid var(--border);margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.menu-item{display:flex;align-items:center;gap:12px;flex-wrap:wrap;width:100%;background:none;border:none;color:var(--text);text-align:left;font-size:16px;padding:14px 8px;border-radius:12px;cursor:pointer}.menu-item:active{background:var(--surface-2)}.menu-item svg{width:1.4em;height:1.4em;color:var(--accent);flex-shrink:0}.menu-item.danger{color:var(--muted)}.menu-item.danger svg{color:var(--muted)}.menu-item .menu-sub{flex-basis:100%;font-size:12px;line-height:1.5;margin-left:calc(1.4em + 12px)}.menu-sheet .btn{margin-top:8px}.toast-wrap{position:fixed;left:0;right:0;top:42%;display:flex;flex-direction:column;align-items:center;gap:8px;z-index:2147483647;pointer-events:none}.toast{max-width:84vw;padding:13px 22px;border-radius:24px;background:#141622f5;color:#fff;font-size:15px;font-weight:700;box-shadow:0 8px 28px #00000080;opacity:0;transform:translateY(14px) scale(.96);transition:opacity .18s ease,transform .18s ease}.toast.show{opacity:1;transform:translateY(0) scale(1)}.toast.ok{border:1px solid var(--accent)}.toast.err{border:1px solid #ff6b6b}.w-search{width:100%;box-sizing:border-box;padding:9px 12px;margin-bottom:10px;border:1px solid var(--border);border-radius:10px;background:var(--surface);color:inherit;font-size:15px}.w-search:focus{outline:none;border-color:var(--accent)}.word-row{cursor:pointer;align-items:flex-start}.word-head{display:flex;align-items:center;gap:6px}.word-term{font-weight:700;font-size:16px}.word-1stsense{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.word-detail{margin-top:8px}.word-ctx{font-size:13px;margin-top:6px;font-style:italic}.word-src{font-size:12px;margin-top:4px;display:flex;align-items:center;gap:4px}.badge.due{background:var(--accent);color:var(--accent-ink)}.badge.muted-badge{color:var(--muted)}.item-progress{display:flex;align-items:center;gap:8px;margin-top:6px}.item-progress .bar{flex:1;height:5px;background:var(--surface-2);border-radius:3px;overflow:hidden}.item-progress .bar>span{display:block;height:100%;width:0;background:var(--accent);transition:width .15s}.item-progress .pct{font-size:11px;color:var(--muted);min-width:90px;text-align:right}.err-inline{color:var(--err)}.install-banner{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--surface);border:1px solid var(--accent);border-radius:12px;padding:12px;margin-bottom:14px;font-size:13px;line-height:1.5}.install-banner .ib-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.install-banner .ib-x{background:none;border:none;color:var(--muted);font-size:20px;cursor:pointer;flex-shrink:0;padding:0 4px}.item-action{display:flex;gap:6px}.word{cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.rp{position:fixed;inset:0;background:#000;z-index:50;color:var(--text)}.rp-stage{position:absolute;inset:0;display:flex;align-items:flex-start;justify-content:center;overflow:hidden;padding-top:calc(env(safe-area-inset-top) + 50px)}#media{max-width:100%;max-height:100%;object-fit:contain;display:block}audio#media{display:none}.rp-cover svg{width:96px;height:96px;color:var(--muted);opacity:.6}.rp-subs{position:absolute;left:0;right:0;bottom:var(--subPos, 230px);text-align:center;pointer-events:none;padding:0 12px}.sub-line{pointer-events:auto;display:inline-block;max-width:96%;touch-action:none}.sub-main{font-size:22px;font-weight:700;color:#ffe14d;text-shadow:0 2px 6px rgba(0,0,0,.95),0 0 3px rgba(0,0,0,.95);line-height:1.35}.sub-trans{font-size:17px;color:#fff;text-shadow:0 2px 6px rgba(0,0,0,.95);margin-top:4px}.word.cur{background:#ffffff47;border-radius:3px}.rp-seekhint{position:absolute;bottom:100%;margin-bottom:44px;right:6%;background:#0000009e;color:#fff;font-size:20px;font-weight:700;padding:6px 14px;border-radius:20px;pointer-events:none;z-index:40;opacity:0;transition:opacity .12s;font-variant-numeric:tabular-nums}.rp-seekhint.left{left:6%;right:auto}.rp-seekhint.show{opacity:1}.rp-top{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:max(6px,env(safe-area-inset-top)) 10px 14px;background:linear-gradient(to bottom,rgba(0,0,0,.65),transparent);z-index:10}.back,.rp-gear{background:none;border:none;color:var(--text);cursor:pointer;padding:4px 8px}.back svg,.rp-gear svg{width:26px;height:26px}.rp-time{font-size:13px;color:#fff;font-variant-numeric:tabular-nums;text-shadow:0 1px 3px #000}.rp-title{flex:1;min-width:0;margin:0 8px;text-align:center;font-size:14px;font-weight:600;color:#fff;text-shadow:0 1px 3px #000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rp-chrome{position:absolute;left:0;right:0;bottom:0;z-index:10}.rp.chrome-hidden .rp-top,.rp.chrome-hidden .rp-chrome,.rp.immersive .rp-top,.rp.immersive .rp-panel,.rp.immersive .rp-seek{display:none}.rp.immersive .rp-stage{padding-top:env(safe-area-inset-top)}.rp.immersive .rp-chrome{padding-bottom:0}.rp-imm{position:absolute;inset:0;z-index:20;pointer-events:none;display:none}.rp.immersive .rp-imm{display:block}.rp-imm-flash{position:absolute;top:50%;left:50%;width:86px;height:86px;display:flex;align-items:center;justify-content:center;background:#00000073;border-radius:50%;color:#fff;opacity:0;transform:translate(-50%,-50%) scale(.8)}.rp-imm-flash svg{width:40px;height:40px}.rp-imm-flash.flash{animation:immflash .55s ease-out forwards}@keyframes immflash{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}18%{opacity:.95;transform:translate(-50%,-50%) scale(1)}55%{opacity:.85;transform:translate(-50%,-50%) scale(1.06)}to{opacity:0;transform:translate(-50%,-50%) scale(1.3)}}.rp-imm-skip{position:absolute;top:50%;width:86px;height:86px;display:flex;align-items:center;justify-content:center;background:#00000073;border-radius:50%;color:#fff;font-size:22px;font-weight:700;font-variant-numeric:tabular-nums;opacity:0;transform:translateY(-50%) scale(.8)}.rp-imm-skip.left{left:12%}.rp-imm-skip.right{right:12%}.rp-imm-skip.flash{animation:immskip .6s ease-out forwards}@keyframes immskip{0%{opacity:0;transform:translateY(-50%) scale(.8)}18%{opacity:.95;transform:translateY(-50%) scale(1)}55%{opacity:.85;transform:translateY(-50%) scale(1.06)}to{opacity:0;transform:translateY(-50%) scale(1.3)}}.rp.immersive .rp-timeline{height:20px;background:transparent;border-top:none}.rp.immersive .tl-ruler,.rp.immersive .tl-now,.rp.immersive .tl-edge,.rp.immersive .tl-abband,.rp.immersive .tl-pin{display:none}.rp.immersive .tl-inner{top:7px;bottom:7px;height:auto}.rp.immersive .tl-box,.rp.immersive .tl-box.active{background:#ffffff2e}.rp.immersive .tl-playhead{width:1px;background:#fff;opacity:.28}.rp.immersive .rp-subs{bottom:calc(34px + env(safe-area-inset-bottom))}.rp-timeline{position:relative;height:68px;background:var(--surface);border-top:1px solid var(--border);overflow:hidden;touch-action:none;cursor:ew-resize}.tl-now{position:absolute;left:50%;bottom:1px;margin-left:4px;font-size:10px;color:var(--muted);pointer-events:none;z-index:3}.tl-ruler{position:absolute;inset:0}.tl-tick{position:absolute;top:2px;transform:translate(-50%);font-size:10px;color:var(--muted);border-left:1px solid var(--border);padding-left:3px;height:100%}.tl-inner{position:absolute;left:0;right:0;bottom:18px;height:34px}.tl-box{position:absolute;top:0;height:100%;background:#3a4a8a;border-radius:3px}.tl-box.active{background:var(--accent)}.tl-edge{position:absolute;top:0;bottom:0;background:#08080c9e;z-index:2;pointer-events:none}.tl-edge-s{left:0;border-right:2px solid #ff6b6b}.tl-edge-e{right:0;border-left:2px solid #ff6b6b}.tl-abband{position:absolute;top:0;bottom:0;background:#ff9f0a2e;pointer-events:none;z-index:1;border-radius:2px}.tl-pin{position:absolute;top:0;bottom:0;width:2px;margin-left:-1px;background:#ff9f0a;pointer-events:none;z-index:3}.tl-pin-l{position:absolute;top:0;left:50%;transform:translate(-50%);font-size:9px;font-weight:700;line-height:12px;color:#1a1a1a;background:#ff9f0a;border-radius:3px;padding:0 3px}.tl-playhead{position:absolute;top:0;bottom:0;left:50%;width:2px;background:#ff4d4d;transform:translate(-50%);pointer-events:none}.rp-panel{flex-shrink:0;background:var(--surface);padding:8px 8px 4px}.rp-row{display:flex;align-items:center;justify-content:center;gap:10px;padding:4px 0}.rp-controls{display:grid;grid-template-areas:"sub prev replay next rep" "spd back play   fwd  ab";align-items:center;justify-items:center;column-gap:14px;row-gap:6px;width:max-content;margin:0 auto;padding:4px 0}#btnSpd{grid-area:spd}#btnT{grid-area:sub}#btnPrev{grid-area:prev}#btnReplay{grid-area:replay}#btnNext{grid-area:next}#btnLoopSeg{grid-area:rep}#btnBack{grid-area:back}#btnPlay{grid-area:play}#btnFwd{grid-area:fwd}#btnAB{grid-area:ab}.rp-controls button{transition:transform .08s ease,filter .08s ease}.rp-controls button:active{transform:scale(.9);filter:brightness(1.4)}.rp-ico{background:var(--surface-2);border:none;color:var(--text);border-radius:10px;padding:8px;min-width:44px;height:40px;cursor:pointer;display:flex;align-items:center;justify-content:center}.rp-ico svg{width:22px;height:22px}.rp-ico.on{background:var(--accent);color:#fff}.rp-ico.half{background:#e0883a;color:#fff}.rp-round{background:var(--surface-2);border:none;color:var(--text);width:54px;height:54px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}.rp-round svg{width:26px;height:26px}.rp-round.small{width:46px;height:46px}.rp-round.small svg{width:22px;height:22px}.rp-round.play{width:66px;height:66px;background:var(--accent);color:#fff}.rp-round.play svg{width:30px;height:30px}.rp-spd{background:var(--surface-2);border:none;color:var(--text);border-radius:8px;padding:6px 10px;font-size:14px;font-weight:700;cursor:pointer;font-variant-numeric:tabular-nums}.rp-spdmenu{position:fixed;display:none;z-index:70;background:var(--surface-2);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 30px #00000080}.rp-spdmenu.show{display:block}.spd-wheel{width:84px;overflow:hidden}.spd-reel{height:102px;overflow-y:auto;scroll-snap-type:y mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;overscroll-behavior:contain}.spd-reel::-webkit-scrollbar{display:none}.spd-pad{height:34px}.spd-item{height:34px;display:flex;align-items:center;justify-content:center;scroll-snap-align:center;font-size:14px;color:var(--muted);font-variant-numeric:tabular-nums;transition:color .12s}.spd-item.sel{color:var(--text);font-weight:700}.spd-band{position:absolute;left:6px;right:6px;top:50%;height:34px;transform:translateY(-50%);border-top:1px solid var(--accent);border-bottom:1px solid var(--accent);background:#309eff1a;border-radius:6px;pointer-events:none}.rp-top-right{display:flex;align-items:center;gap:2px}.rp-ico.topico{background:none;min-width:auto;height:auto;padding:4px 6px}.rp-ico.topico svg{width:26px;height:26px}.rp-ico.topico.on{background:none;color:var(--accent)}.rp-seek{position:relative;flex-shrink:0;padding:14px 18px calc(12px + env(safe-area-inset-bottom));background:var(--surface);border-top:1px solid var(--border)}.rp-seek-bar{position:relative;height:6px;background:var(--surface-2);border-radius:3px;touch-action:none;cursor:pointer}.rp-seek-fill{position:absolute;left:0;top:0;bottom:0;width:0;background:var(--accent);border-radius:3px}.rp-seek-thumb{position:absolute;top:50%;left:0;width:14px;height:14px;margin-left:-7px;border-radius:50%;background:#fff;transform:translateY(-50%);box-shadow:0 1px 4px #00000080}.rp-seek-prev{position:absolute;bottom:100%;margin-bottom:8px;left:0;transform:translate(-50%);background:#000000d9;border:1px solid var(--border);border-radius:8px;padding:4px;pointer-events:none;display:none;z-index:50}.rp-seek-prev.show{display:block}.rp-seek-prev canvas{display:block;width:132px;height:74px;border-radius:5px;background:#000}.rp-seek-prev .t{text-align:center;color:#fff;font-size:12px;margin-top:3px;font-variant-numeric:tabular-nums}.rp-sheet{position:absolute;left:12px;right:12px;bottom:calc(env(safe-area-inset-bottom) + 70px);background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:14px;z-index:60;box-shadow:0 8px 30px #0009}.sheet-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.sheet-row label{font-size:13px;color:var(--muted)}.sheet-row select{flex:1;max-width:60%;padding:8px;font-size:15px;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:8px}.stepper{display:flex;align-items:center;gap:8px}.stepper button{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:6px 10px;font-size:13px;cursor:pointer}.stepper span{font-size:14px;min-width:48px;text-align:center;font-variant-numeric:tabular-nums}#dictPopup{position:fixed;display:none;z-index:100;pointer-events:none;max-width:min(360px,92vw);max-height:50vh;overflow-y:auto;background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:12px;box-shadow:0 8px 30px #00000080;font-size:14px}#dictPopup.live{pointer-events:auto}#dictPopup .entry{margin-bottom:10px}#dictPopup .head{font-weight:700;margin-bottom:4px}#dictPopup .tag{font-size:10px;background:var(--accent);color:#fff;padding:1px 6px;border-radius:6px;margin-right:6px}#dictPopup .sense{margin:2px 0;line-height:1.5}#dictPopup .pos{color:var(--accent);margin-right:6px}#dictPopup .dict-src{font-size:11px;color:var(--muted);margin:6px 0 2px;font-weight:600}.dict-actions{display:flex;gap:6px;margin-top:6px}.dict-actions #dictSave{flex:1}.dict-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}.dict-row:last-child{border-bottom:none}.dict-row .dict-meta{flex:1;min-width:0}.dict-row .dict-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dict-toggle{position:relative;display:inline-flex;flex-shrink:0;cursor:pointer}.dict-toggle input{position:absolute;opacity:0;width:0;height:0}.dict-toggle span{width:40px;height:24px;border-radius:12px;background:var(--surface-2);transition:background .15s;position:relative}.dict-toggle span:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .15s}.dict-toggle input:checked+span{background:var(--accent)}.dict-toggle input:checked+span:after{transform:translate(16px)}.review-card{text-align:center;display:flex;flex-direction:column;gap:10px}.rv-word{font-size:30px;font-weight:700;margin:0}.rv-word .mini{font-size:15px;vertical-align:middle}.rv-context{font-size:14px;margin:0;line-height:1.5}.rv-back{text-align:left;background:var(--surface-2);border-radius:10px;padding:12px;margin:0}.rv-back .sense{margin:3px 0;line-height:1.5}.rv-back .pos{color:var(--accent);margin-right:6px}.rv-grades{display:grid;grid-template-columns:1fr 1fr;gap:10px}.grade{padding:12px;border:none;border-radius:10px;font-size:15px;font-weight:600;color:#fff;cursor:pointer;display:flex;flex-direction:column;gap:2px}.grade small{font-weight:400;opacity:.85;font-size:11px}.grade.again{background:#d9534f}.grade.hard{background:#e0883a}.grade.good{background:#3f9ece}.grade.easy{background:#3fce8f}
