:is(.plan-lite:has(.reader-root),.plan-premium:has(.reader-root)){flex-direction:column;height:100dvh;display:flex;overflow:hidden}:is(.plan-lite:has(.reader-root) .topbar,.plan-premium:has(.reader-root) .topbar){display:none}:is(.plan-lite:has(.reader-root) .reader-root,.plan-premium:has(.reader-root) .reader-root){flex:1;min-height:0}.reader-root{flex-direction:column;display:flex;overflow:hidden}.warmup-overlay{z-index:200;background:var(--paper);flex-direction:column;justify-content:flex-start;align-items:center;padding:8vh 24px 24px;display:flex;position:absolute;inset:0;overflow-y:auto}.warmup-overlay .vkb-wrap{width:100%;margin-top:auto}.warmup-box{background:var(--paper-d);text-align:center;border-radius:16px;width:100%;max-width:380px;padding:28px 24px;box-shadow:0 4px 24px #1a27441f}.warmup-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.warmup-title{font-family:var(--font-noto-sans-tc),"Noto Sans TC",sans-serif;color:var(--navy);font-size:16px;font-weight:700}.warmup-progress{color:var(--soft);font-size:13px;font-weight:600}.warmup-word-area{margin-bottom:16px}.warmup-word{font-family:var(--font-noto-serif-jp),"Noto Serif JP",serif;color:var(--navy);margin-bottom:4px;font-size:32px;font-weight:900}.warmup-furi{color:var(--soft);font-size:16px;font-family:var(--font-noto-serif-jp),"Noto Serif JP",serif;margin-bottom:6px}.warmup-meaning{color:var(--navy);opacity:.7;font-size:14px;font-family:var(--font-noto-sans-tc),"Noto Sans TC",sans-serif}.warmup-feedback{font-size:14px;font-weight:700;font-family:var(--font-noto-sans-tc),"Noto Sans TC",sans-serif;margin-bottom:10px}.warmup-feedback.correct{color:#2e7d32}.warmup-feedback.wrong{color:var(--red)}.warmup-input-row{margin-bottom:16px}.warmup-input{letter-spacing:2px;width:100%;color:var(--navy);text-align:center;font-size:18px;font-weight:700;font-family:var(--font-noto-sans-tc),"Noto Sans TC",sans-serif;background:#fff;border:2px solid #1a274426;border-radius:12px;outline:none;padding:12px 16px;transition:border-color .2s}.warmup-input:focus{border-color:var(--navy)}.warmup-input.correct{background:#2e7d320f;border-color:#2e7d32}.warmup-input.wrong{border-color:var(--red);background:#c8371a0f}.warmup-skip{color:var(--soft);cursor:pointer;font-size:13px;font-family:var(--font-noto-sans-tc),"Noto Sans TC",sans-serif;background:0 0;border:none;padding:8px 16px;transition:color .2s}.warmup-hint{letter-spacing:2px;color:var(--soft);opacity:.6;font-size:15px;font-weight:700;font-family:var(--font-noto-sans-tc),"Noto Sans TC",sans-serif;margin-bottom:10px;transition:opacity .3s,color .3s}.warmup-hint.full{opacity:1;color:var(--navy)}.warmup-skip:hover{color:var(--navy)}.page-wrap,.reading-panel{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.read-toolbar{border-bottom:1px solid var(--border);background:#fff;flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;padding:10px 28px;display:flex}.toolbar-left,.toolbar-right{align-items:center;gap:8px;display:flex}.view-toggle{background:var(--paper-d);border-radius:20px;gap:2px;padding:2px;display:flex}.vt-btn{color:var(--soft);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:16px;padding:4px 12px;font-family:inherit;font-size:11.5px;font-weight:700;transition:all .2s}.vt-btn.active{color:var(--navy);background:#fff;box-shadow:0 1px 4px #1a27441f}.speed-wrap{color:var(--soft);align-items:center;gap:6px;font-size:11.5px;display:flex}.speed-slider{width:72px;accent-color:var(--navy)}.speed-val{color:var(--navy);min-width:28px;font-size:11px;font-weight:700}.sound-btn{border:1.5px solid var(--border-md);cursor:pointer;color:var(--mid);background:0 0;border-radius:16px;align-items:center;gap:5px;padding:4px 12px;font-family:inherit;font-size:11.5px;font-weight:700;transition:all .2s;display:flex}.sound-btn.active{background:var(--navy);color:#fff;border-color:var(--navy)}.sound-btn svg{width:13px;height:13px}.progress-bar-wrap{border-bottom:1px solid var(--border);background:#fff;flex-shrink:0;padding:0 28px 10px}.progress-label{color:var(--soft);justify-content:space-between;margin-bottom:4px;font-size:10px;display:flex}.progress-track{background:var(--paper-d);border-radius:4px;height:4px;overflow:hidden}.progress-fill{background:var(--navy);border-radius:4px;height:100%;transition:width .4s}.text-area{flex:1;justify-content:center;align-items:flex-start;padding:32px 32px 24px;display:flex;position:relative;overflow-y:auto}.text-area-inner{width:100%;max-width:1020px}.read-book-title{font-family:var(--font-noto-serif-jp),"Noto Serif JP",serif;color:var(--navy);border-bottom:1px solid var(--border);cursor:pointer;align-items:center;gap:10px;margin-bottom:24px;padding-bottom:14px;font-size:18px;font-weight:900;text-decoration:none;transition:color .15s;display:flex}.read-book-title:hover{color:var(--red)}.read-book-title:hover .read-book-title-back{opacity:1;transform:translate(0)}.read-book-title-text{flex:1;min-width:0}.read-book-title-back{letter-spacing:.04em;color:var(--soft);opacity:.5;white-space:nowrap;margin-left:auto;font-family:Newsreader,Georgia,serif;font-size:11px;font-style:italic;font-weight:500;transition:opacity .15s,transform .15s;transform:translate(4px)}.chapter-badge{background:var(--navy);color:#fff;letter-spacing:1px;border-radius:3px;padding:2px 9px;font-size:9px;font-weight:700}.text-line-group{margin-bottom:44px;transition:opacity .4s,filter .4s,transform .4s}.text-line-group.line-done{opacity:.55;filter:blur(.6px);pointer-events:auto;transform:scale(.98)}.text-line-group.line-done-old{opacity:.18;filter:blur(1.8px);pointer-events:none;transform:scale(.95)}.line-replay-btn{background:var(--navy);color:#fff;cursor:pointer;opacity:.7;vertical-align:middle;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;margin-right:4px;padding:0;transition:opacity .15s,transform .15s;display:inline-flex}.line-replay-btn:hover{opacity:1;transform:scale(1.15)}.line-replay-btn:active{transform:scale(.9)}.text-line-group.line-done-old .line-replay-btn{display:none}.text-line-group.line-next{opacity:.38;filter:blur(.8px);transform:scale(.97)}.text-line-group.line-future{opacity:.18;filter:blur(2px);pointer-events:none;transform:scale(.94)}.text-line-group.line-active{opacity:1;filter:none;transform:scale(1)}.text-line-group.line-done .text-line-jp,.text-line-group.line-done-old .text-line-jp,.text-line-group.line-next .text-line-jp,.text-line-group.line-future .text-line-jp{font-size:clamp(31px,3.9vw,47px)}.text-line-jp{font-family:var(--font-noto-serif-jp),"Noto Serif JP",serif;flex-wrap:wrap;align-items:flex-end;gap:1px;margin-bottom:6px;font-size:clamp(47px,5.85vw,68px);font-weight:700;line-height:2.2;display:flex}.text-line-zh{color:var(--soft);padding-left:2px;font-size:18px;line-height:1.7}.speaker-badge{color:#fff;background:var(--navy);letter-spacing:.5px;font-size:14px;font-weight:700;font-family:var(--font-noto-sans-tc),"Noto Sans TC",sans-serif;border-radius:14px;margin-bottom:8px;padding:4px 14px;display:inline-block}.char-cell{cursor:pointer;-webkit-tap-highlight-color:transparent;flex-direction:column;align-items:center;gap:0;display:inline-flex;position:relative}.char-cell ruby{flex-direction:column-reverse;align-items:center;gap:0;display:inline-flex}.char-rt{color:var(--soft);letter-spacing:.3px;min-height:16px;font-size:14px;line-height:1;font-family:var(--font-noto-sans-tc),"Noto Sans TC",sans-serif;text-align:center;white-space:nowrap;display:block}.char-kana{color:var(--untyped);line-height:1.4;transition:color .2s}.char-kana.done{color:var(--done)}.char-kana.cur{color:var(--done);border-bottom:4px solid var(--red)}.char-kana.punc{color:#1a27444d}.char-romaji-popup{background:var(--navy);color:#fff;letter-spacing:.5px;white-space:nowrap;z-index:50;pointer-events:none;font-size:11px;font-weight:700;font-family:var(--font-noto-sans-tc),"Noto Sans TC",sans-serif;border-radius:6px;padding:4px 8px;display:none;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);box-shadow:0 3px 10px #1a274440}.char-romaji-popup:after{content:"";border:5px solid #0000;border-top-color:var(--navy);position:absolute;top:100%;left:50%;transform:translate(-50%)}.char-cell.show-romaji .char-romaji-popup{display:block}.char-cell.show-romaji .char-kana{color:var(--navy-mid)!important}.char-correct-flash{color:var(--red);letter-spacing:.5px;white-space:nowrap;pointer-events:none;z-index:55;font-size:12px;font-weight:900;font-family:var(--font-noto-sans-tc),"Noto Sans TC",sans-serif;animation:.6s ease-out forwards correctFlashAnim;position:absolute;bottom:calc(100% + 2px);left:50%;transform:translate(-50%)}@keyframes correctFlashAnim{0%{opacity:1;transform:translate(-50%)translateY(0)}60%{opacity:1;transform:translate(-50%)translateY(-6px)}to{opacity:0;transform:translate(-50%)translateY(-12px)}}.fulltext-view{display:none}.fulltext-view.show{display:block}.fulltext-block{font-family:var(--font-noto-serif-jp),"Noto Serif JP",serif;color:var(--untyped);letter-spacing:.5px;font-size:clamp(16px,1.8vw,20px);line-height:2.2}.fulltext-block .ft-done{color:var(--done)}.fulltext-block .ft-cur{color:var(--done);border-bottom:3px solid var(--red)}.fulltext-block .ft-punc{color:#1a274447}.bottom-zone{background:var(--paper);flex-direction:column;flex:1;min-height:0;display:flex;position:relative;overflow:hidden}.bottom-zone:before{content:"";pointer-events:none;z-index:0;background-image:repeating-linear-gradient(0deg,#0000,#0000 31px,#1a27440a 31px 32px),repeating-linear-gradient(90deg,#0000,#0000 31px,#1a274409 31px 32px);position:absolute;inset:0}.bottom-zone:after{content:"";z-index:1;background:linear-gradient(90deg,#0000 0%,#c8371a2e 30%,#1a27441f 60%,#0000 100%);height:2px;position:absolute;top:0;left:0;right:0}.detail-bar{background:var(--paper-d);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:8px;padding:8px 28px 6px;display:flex}.detail-bar-btn{border:1.5px solid var(--border-md);color:var(--mid);cursor:pointer;background:#fff;border-radius:16px;align-items:center;gap:5px;padding:5px 14px;font-family:inherit;font-size:12px;font-weight:700;transition:all .2s;display:flex}.detail-bar-btn:hover{background:var(--navy);color:#fff;border-color:var(--navy)}.char-detail-tag{color:#fff;background:var(--navy);letter-spacing:.4px;font-weight:700;line-height:1;font-family:var(--font-noto-sans-tc),"Noto Sans TC",sans-serif;opacity:0;pointer-events:none;white-space:nowrap;z-index:5;cursor:pointer;border:none;border-radius:999px;justify-content:center;align-items:center;height:auto;min-height:0;max-height:20px;padding:3px 8px;transition:opacity .2s,transform .1s,background .15s;display:inline-flex;position:absolute;bottom:calc(100% + 2px);left:50%;transform:translate(-50%);box-shadow:0 1px 3px #1a274433;font-size:10px!important}.char-detail-tag:active{background:var(--red);transform:translate(-50%)scale(.92)}.char-cell.word-first-done .char-detail-tag{opacity:1;pointer-events:auto}.detail-bar{padding:6px 28px 4px}.detail-bar-btn{border-radius:999px;padding:3px 12px;font-size:11px}.detail-bar-btn svg{width:11px;height:11px}.input-row{background:var(--paper);border-top:1px solid var(--border);z-index:2;flex-shrink:0;justify-content:center;align-items:center;gap:10px;padding:16px 32px;display:flex;position:relative}.replay-above-input{display:none}.input-wrapper{flex:1;min-width:0;max-width:320px;position:relative;overflow:visible}.typing-target-row{justify-content:center;align-items:center;gap:16px;margin-bottom:8px;display:flex}.target-side-btn{display:none}.typing-target-area{-webkit-user-select:none;user-select:none;flex-direction:column;justify-content:center;align-items:center;min-height:64px;display:flex}.typing-target-char{color:var(--navy);font-family:Noto Serif JP,serif;font-size:42px;font-weight:700;line-height:1.2;transition:color .2s}.typing-target-char.segment-target{text-align:center;overflow-wrap:anywhere;flex-wrap:wrap;justify-content:center;gap:2px;max-width:min(320px,90vw);font-size:clamp(26px,8vw,42px);display:flex}.typing-target-char.segment-target .seg-done{color:var(--navy);opacity:1}.typing-target-char.segment-target .seg-active{color:var(--red);opacity:1}.typing-target-char.segment-target .seg-pending{color:var(--soft);opacity:.35}.typing-target-char.segment-target.right .seg-done,.typing-target-char.segment-target.right .seg-active{color:#2d8b5a}.typing-target-char.segment-target.wrong .seg-active,.typing-target-char.wrong{color:var(--red)}.typing-target-char.right{color:#2d8b5a}.typing-target-ruby{color:var(--soft);margin-top:2px;font-size:13px}.typing-target-subseg-info{color:var(--soft);opacity:.55;letter-spacing:.05em;margin-top:1px;font-size:10px}.typing-target-hint{letter-spacing:.08em;min-height:22px;color:var(--red);opacity:0;font-size:18px;font-weight:700;font-family:var(--font-noto-sans-tc),"Noto Sans TC",sans-serif;-webkit-user-select:none;user-select:none;text-align:center;margin-top:6px;line-height:1.2;transition:opacity .25s ease-out}.typing-target-hint.visible.partial{opacity:.55}.typing-target-hint.visible.full{opacity:1}.typing-target-char.ruby-split{letter-spacing:.06em;gap:2px;display:flex}.typing-target-char.ruby-split .rs-done,.typing-target-char.ruby-split .rs-active{color:var(--navy);opacity:1}.typing-target-char.ruby-split .rs-pending{color:var(--soft);opacity:.35}.typing-target-char.ruby-split.wrong .rs-active{color:var(--red)}.input-field{width:100%;font-size:18px;font-weight:700;font-family:var(--font-noto-sans-tc),"Noto Sans TC",sans-serif;border:2px solid var(--border-md);color:var(--navy);text-align:center;background:#fff;border-radius:28px;outline:none;padding:13px 20px;transition:all .2s}.input-field::placeholder{color:var(--soft);opacity:.5}.input-field:focus{border-color:var(--navy-mid);background:#fff}.input-field.wrong{border-color:var(--red);background:#fff8f6;animation:.3s shake}.input-field.right{background:#f2fbf6;border-color:#2d8b5a}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.input-hint{color:var(--soft);white-space:nowrap;font-size:11px}.action-row{background:var(--paper);z-index:2;border-top:1px solid #1a27440d;flex-wrap:wrap;flex-shrink:0;align-items:center;gap:8px;padding:10px 32px 16px;display:flex;position:relative}.action-btn{border:1.5px solid var(--border-md);color:var(--mid);cursor:pointer;background:0 0;border-radius:16px;align-items:center;gap:5px;padding:5px 14px;font-family:inherit;font-size:11.5px;font-weight:700;transition:all .2s;display:flex}.action-btn:hover{background:var(--paper-d);border-color:var(--navy)}.action-btn.primary{background:var(--navy);color:#fff;border-color:var(--navy)}.action-btn.primary:hover{opacity:.85}.action-btn.reading-all{background:var(--red);color:#fff;border-color:var(--red)}.action-btn.reading-all:hover{opacity:.85}@keyframes readPulse{0%,to{opacity:1}50%{opacity:.5}}.action-btn.reading-all svg{animation:.8s ease-in-out infinite readPulse}.read-all-bar{background:var(--navy);color:#fff;flex-shrink:0;justify-content:space-between;align-items:center;gap:10px;padding:8px 20px;font-size:12px;font-weight:700;display:none}.read-all-bar.show{display:flex}.read-all-bar-text{align-items:center;gap:8px;display:flex}.read-all-bar-text svg{flex-shrink:0;width:14px;height:14px;animation:.8s ease-in-out infinite readPulse}.read-all-stop{color:#fff;cursor:pointer;white-space:nowrap;background:#ffffff26;border:1px solid #ffffff4d;border-radius:10px;flex-shrink:0;padding:4px 12px;font-family:inherit;font-size:11px;font-weight:700;transition:all .15s}.read-all-stop:hover{background:#ffffff47}.action-btn svg{flex-shrink:0;width:13px;height:13px}.orb-row{align-items:center;gap:10px;padding:8px 0 2px;display:flex}.orb-wrap{align-items:center;display:flex;position:relative}.orb{z-index:1;background:#1a2744;border-radius:50%;flex-shrink:0;width:16px;height:16px;transition:background .4s,width .3s cubic-bezier(.34,1.56,.64,1),height .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s;position:relative}.orb.orb-bounce{animation:.4s cubic-bezier(.34,1.56,.64,1) orbBounce}@keyframes orbBounce{0%{transform:scale(1)}40%{transform:scale(1.55)}70%{transform:scale(.9)}to{transform:scale(1)}}.orb.orb-rainbow{background:conic-gradient(red,orange,#ff0,green,#4169e1,indigo,violet,red);animation:2s linear infinite orbSpin}@keyframes orbSpin{to{transform:rotate(360deg)}}.orb-streak{background:linear-gradient(90deg,#0000,#c8371a4d);border-radius:2px;width:0;height:3px;margin-left:2px;transition:width .2s}.orb-combo{color:var(--soft);min-width:40px;font-family:DM Serif Display,serif;font-size:11px;font-weight:700;transition:color .3s}.upgrade-toast{background:var(--navy);color:#fff;z-index:var(--z-top);white-space:nowrap;border-radius:8px;padding:10px 20px;font-size:13px;font-weight:600;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #00000040}.romaji-float-hint{z-index:10;pointer-events:none;opacity:0;justify-content:center;margin-bottom:8px;transition:opacity .4s,transform .4s;display:flex;position:sticky;top:8px;transform:translateY(-6px)}.romaji-float-hint.show{opacity:1;transform:translateY(0)}.romaji-float-hint span{background:var(--navy);color:#fff;letter-spacing:2px;font-size:18px;font-weight:900;font-family:var(--font-noto-sans-tc),"Noto Sans TC",sans-serif;opacity:.7;border:2px solid #c8371a33;border-radius:24px;padding:8px 24px;transition:opacity .3s,border-color .3s,box-shadow .3s;box-shadow:0 4px 18px #1a27444d}.romaji-float-hint.hint-full span{opacity:1;border-color:#c8371a80;box-shadow:0 4px 18px #1a27444d,0 0 8px #c8371a4d}.detail-content{flex:1;padding:16px 20px;overflow-y:auto}.settings-panel{border:1px solid var(--border);background:#fff;border-radius:10px;margin-bottom:14px;padding:16px}.settings-row{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.settings-row:last-child{margin-bottom:0}.settings-label{color:var(--navy);font-size:12px;font-weight:700}.settings-sub{color:var(--soft);margin-top:1px;font-size:10.5px}.settings-control{align-items:center;gap:8px;display:flex}.speed-track{width:90px;accent-color:var(--navy)}.speed-display{color:var(--navy);text-align:right;min-width:32px;font-size:13px;font-weight:700}.toggle-switch{background:var(--paper-d);cursor:pointer;border:1.5px solid var(--border-md);border-radius:10px;width:36px;height:20px;transition:all .2s;position:relative}.toggle-switch.on{background:var(--navy);border-color:var(--navy)}.toggle-knob{background:#fff;border-radius:50%;width:14px;height:14px;transition:all .2s;position:absolute;top:2px;left:2px}.toggle-switch.on .toggle-knob{left:18px}.detail-empty{text-align:center;height:100%;color:var(--soft);flex-direction:column;justify-content:center;align-items:center;padding:32px 20px;display:flex}.detail-empty-icon{opacity:.4;margin-bottom:12px;font-size:36px}.detail-empty-text{font-size:12px;line-height:1.8}.detail-modal-ov{z-index:300;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);width:100%;height:100%;padding-bottom:env(safe-area-inset-bottom,0px);background:#0a10238c;justify-content:center;align-items:flex-end;display:none;position:fixed;top:0;left:0}.detail-modal-ov.open{display:flex}.detail-modal{background:var(--paper);box-sizing:border-box;border-radius:20px 20px 0 0;width:100%;max-width:600px;max-height:85vh;padding:0 0 32px;animation:.28s cubic-bezier(.34,1.2,.64,1) slideUp;overflow-y:auto}.detail-modal-handle{background:var(--border-md);border-radius:2px;width:40px;height:4px;margin:12px auto 0}.detail-modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 22px 10px;display:flex}.detail-modal-title{letter-spacing:2px;color:var(--soft);text-transform:uppercase;font-size:11px;font-weight:700}.detail-modal-close{background:var(--paper-d);cursor:pointer;width:28px;height:28px;color:var(--soft);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:16px;transition:all .2s;display:flex}.detail-modal-close:hover{background:var(--navy);color:#fff}.detail-modal-body{padding:18px 22px}.dm-furigana{font-family:var(--font-noto-serif-jp),"Noto Serif JP",serif;color:var(--soft);margin-bottom:2px;font-size:12px}.dm-jp{font-family:var(--font-noto-serif-jp),"Noto Serif JP",serif;color:var(--navy);margin-bottom:8px;font-size:28px;font-weight:900}.dm-badge{background:var(--navy);color:#fff;letter-spacing:1px;border-radius:3px;margin-bottom:12px;padding:2px 9px;font-size:9px;font-weight:700;display:inline-block}.dm-divider{border:none;border-top:1px solid var(--border);margin:10px 0}.dm-meaning-row{align-items:baseline;gap:8px;margin-bottom:5px;display:flex}.dm-meaning-label{letter-spacing:1px;color:var(--red);flex-shrink:0;font-size:10px;font-weight:700}.dm-meaning-text{color:var(--navy);font-size:15px;font-weight:500}.dm-note{color:var(--soft);margin-bottom:12px;font-size:12px;line-height:1.75}.dm-example{background:var(--paper-d);border-radius:8px;margin-bottom:16px;padding:12px 14px}.dm-example-jp{font-family:var(--font-noto-serif-jp),"Noto Serif JP",serif;color:var(--navy);margin-bottom:4px;font-size:14px}.dm-example-zh{color:var(--soft);font-size:12px}.dm-collect-btn{background:var(--navy);color:#fff;cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;width:100%;padding:13px;font-family:inherit;font-size:14px;font-weight:900;transition:all .2s;display:flex}.dm-collect-btn:hover{opacity:.85}.dm-collect-btn.collected{background:var(--gold-btn);color:var(--navy)}.dm-collect-btn svg{width:16px;height:16px}.completion-banner{z-index:200;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0a1023b3;justify-content:center;align-items:center;padding:24px;display:none;position:fixed;inset:0}.completion-banner.show{display:flex}.completion-box{background:var(--paper);text-align:center;border-radius:16px;width:100%;max-width:520px;padding:34px 32px;animation:.3s cubic-bezier(.34,1.56,.64,1) popIn}@keyframes popIn{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.completion-emoji{margin-bottom:14px;font-size:48px}.completion-title{font-family:var(--font-noto-serif-jp),"Noto Serif JP",serif;color:var(--navy);margin-bottom:8px;font-size:22px;font-weight:900}.completion-sub{color:var(--soft);margin-bottom:24px;font-size:13px;line-height:1.8}.completion-stats{border:1px solid var(--border);border-radius:10px;grid-template-columns:repeat(4,1fr);gap:0;margin-bottom:18px;display:grid;overflow:hidden}.cs-item{text-align:center;border-right:1px solid var(--border);flex:1;padding:14px 8px}.cs-item:last-child{border-right:none}.cs-num{color:var(--navy);font-family:DM Serif Display,serif;font-size:24px}.cs-label{color:var(--soft);margin-top:2px;font-size:10px}.completion-insights{text-align:left;gap:10px;margin-bottom:22px;display:grid}.ci-row{border:1px solid var(--border);color:var(--soft);background:#ffffff59;border-radius:8px;justify-content:space-between;align-items:center;padding:9px 12px;font-size:12px;display:flex}.ci-row b{color:var(--navy);font-size:13px}.ci-weak{border:1px solid var(--border);background:#ffffff59;border-radius:8px;padding:11px 12px}.ci-title{letter-spacing:.08em;color:var(--soft);margin-bottom:8px;font-size:11px;font-weight:800;display:block}.ci-tags{flex-wrap:wrap;gap:7px;display:flex}.ci-tags span{background:var(--paper-d);color:var(--navy);border-radius:999px;align-items:center;gap:5px;padding:6px 9px;font-size:12px;font-weight:800;display:inline-flex}.ci-tags small{color:var(--soft);font-size:10px;font-weight:700}.ci-perfect{color:#2d8b5a;background:#2d8b5a14;border:1px solid #2d8b5a40;border-radius:8px;padding:11px 12px;font-size:12px;font-weight:800}.completion-actions{gap:10px;display:flex}.ca-btn{cursor:pointer;border:none;border-radius:8px;flex:1;padding:12px;font-family:inherit;font-size:13.5px;font-weight:700;transition:all .15s}.ca-btn.outline{color:var(--navy);border:2px solid var(--navy);background:0 0}.ca-btn.solid{background:var(--navy);color:#fff}.ca-btn:hover{opacity:.85}.toolbar-toggle{display:none}.toolbar-panel{display:contents}@media (max-width:768px){.toolbar-toggle{background:var(--paper-d);border:1px solid var(--border);color:var(--navy);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:4px;width:100%;padding:4px 12px;font-family:inherit;font-size:11px;font-weight:600;display:flex}.toolbar-panel{flex-direction:column;gap:6px;width:100%;padding-top:8px;display:none}.toolbar-panel.open{display:flex}.read-toolbar{flex-direction:column;align-items:stretch;gap:4px;padding:6px 14px}.toolbar-left,.toolbar-right{flex-wrap:wrap;gap:4px}.vt-btn,.sound-btn{padding:3px 10px;font-size:10.5px}.speed-wrap{font-size:10.5px}.speed-slider{width:56px}.progress-bar-wrap{padding:0 14px 4px}.progress-label{margin-bottom:2px;font-size:9px}.orb-row{margin-top:2px}.detail-bar{display:none}.target-side-btn{border:1px solid var(--border-md);color:var(--mid);cursor:pointer;background:0 0;border-radius:10px;flex-direction:column;align-items:center;gap:2px;min-width:44px;padding:6px 8px;font-family:inherit;font-size:10px;font-weight:600;transition:all .15s;display:flex}.target-side-btn:active{background:var(--paper-d);transform:scale(.95)}.typing-target-row{justify-content:space-between;margin-bottom:4px;padding:0 4px}.text-area{flex:1;min-height:0;padding:8px 16px 4px}.text-line-group{margin-bottom:36px}.text-line-jp{font-size:36px;line-height:2.2}.text-line-group.line-done .text-line-jp,.text-line-group.line-done-old .text-line-jp,.text-line-group.line-next .text-line-jp,.text-line-group.line-future .text-line-jp{font-size:24px}.text-line-zh{font-size:15px;line-height:1.5}.read-book-title{margin-bottom:14px;padding-bottom:10px;font-size:12px}.read-book-title-back{display:none}.char-rt{min-height:12px;font-size:10px}.char-detail-tag{padding:2px 6px;font-size:8px}.input-row{z-index:10;background:var(--paper);gap:4px;padding:4px 16px;position:sticky;bottom:0}.input-wrapper{max-width:100%}.typing-target-char{font-size:28px}.typing-target-char.ruby-split{gap:1px}.typing-target-ruby{margin-top:1px;font-size:11px}.input-field{padding:8px 16px;font-size:15px}.replay-above-input,.input-hint{display:none}.action-row{padding:6px 16px 10px;display:none}}.vkb-wrap{display:none}@media (max-width:768px){.vkb-wrap{padding:6px 3px calc(8px + env(safe-area-inset-bottom,0px));-webkit-user-select:none;user-select:none;background:#d1d4d9;flex-direction:column;flex-shrink:0;gap:5px;width:100%;display:flex}.vkb-row{justify-content:center;gap:3px;display:flex}.vkb-key{color:#1a2744;cursor:pointer;-webkit-tap-highlight-color:transparent;text-transform:lowercase;background:#fefffe;border:none;border-radius:6px;flex:1;justify-content:center;align-items:center;max-width:38px;height:42px;font-family:inherit;font-size:19px;font-weight:600;transition:background 80ms;display:flex;box-shadow:0 1px #00000040}.vkb-key:active{background:#b8bbc1;transform:scale(.93)}.vkb-row:first-child .vkb-key{max-width:32px;height:36px;font-size:15px}.vkb-key-bs{color:#1a2744;background:#adb0b7;flex:1.5;max-width:72px}.vkb-key-bs:active{background:#8e9198}}.reader-root.ts-sm .text-line-jp{font-size:clamp(36px,4.5vw,52px)}.reader-root.ts-sm .text-line-group.line-done .text-line-jp,.reader-root.ts-sm .text-line-group.line-done-old .text-line-jp,.reader-root.ts-sm .text-line-group.line-next .text-line-jp,.reader-root.ts-sm .text-line-group.line-future .text-line-jp{font-size:clamp(24px,3vw,36px)}.reader-root.ts-sm .char-rt{min-height:13px;font-size:11px}.reader-root.ts-sm .text-line-zh{font-size:15px}.reader-root.ts-sm .typing-target-char{font-size:34px}.reader-root.ts-lg .text-line-jp{font-size:clamp(56px,7vw,82px)}.reader-root.ts-lg .text-line-group.line-done .text-line-jp,.reader-root.ts-lg .text-line-group.line-done-old .text-line-jp,.reader-root.ts-lg .text-line-group.line-next .text-line-jp,.reader-root.ts-lg .text-line-group.line-future .text-line-jp{font-size:clamp(38px,4.8vw,56px)}.reader-root.ts-lg .char-rt{min-height:20px;font-size:17px}.reader-root.ts-lg .text-line-zh{font-size:21px}.reader-root.ts-lg .typing-target-char{font-size:52px}.reader-root.beginner .typing-target-hint.visible{color:var(--red)}.reader-root.beginner .char-romaji-popup{opacity:.95}.beginner-toggle{border-color:var(--border)}.beginner-toggle.active{background:var(--gold-btn);color:var(--navy)}@media (max-width:768px){.reader-root.ts-sm .text-line-jp{font-size:28px}.reader-root.ts-sm .text-line-group.line-done .text-line-jp,.reader-root.ts-sm .text-line-group.line-done-old .text-line-jp,.reader-root.ts-sm .text-line-group.line-next .text-line-jp,.reader-root.ts-sm .text-line-group.line-future .text-line-jp{font-size:18px}.reader-root.ts-sm .typing-target-char{font-size:22px}.reader-root.ts-lg .text-line-jp{font-size:46px}.reader-root.ts-lg .text-line-group.line-done .text-line-jp,.reader-root.ts-lg .text-line-group.line-done-old .text-line-jp,.reader-root.ts-lg .text-line-group.line-next .text-line-jp,.reader-root.ts-lg .text-line-group.line-future .text-line-jp{font-size:32px}.reader-root.ts-lg .typing-target-char{font-size:36px}.completion-box{max-height:92dvh;padding:28px 18px;overflow:auto}.completion-stats{grid-template-columns:repeat(2,1fr)}.cs-item:nth-child(2){border-right:none}.completion-actions{flex-direction:column}}
