@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&family=Literata:ital,opsz,wght@0,7..72,400;0,7..72,500;1,7..72,400&display=swap";@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;700&display=swap";:root{--font-display: "DM Sans", system-ui, sans-serif;--font-reading: "Literata", "Georgia", serif;--bg: #f8f6f3;--card-bg: #fff;--text: #1c1c1c;--muted: #5c5c5c;--border: #e5e2de;--accent: #b85c38}*{box-sizing:border-box}body{margin:0;font-family:var(--font-display);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.5}#root{min-height:100vh}.shelf{min-height:100vh;background:#f5f0e8;font-family:Noto Sans SC,system-ui,sans-serif;color:#2c2a24}.shelf-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;color:#8a8478}.shelf-spinner{width:36px;height:36px;border-radius:50%;border:2.5px solid #e0dbd0;border-top-color:#b8845c;animation:shelfSpin .7s linear infinite}@keyframes shelfSpin{to{transform:rotate(360deg)}}.shelf-nav{display:flex;align-items:center;gap:14px;padding:12px 32px;border-bottom:1px solid #e8e3d8;position:sticky;top:0;z-index:100;background:#f5f0e8eb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.shelf-nav__brand{font-family:Playfair Display,Georgia,serif;font-size:1.2rem;font-weight:700;color:#3d3228;letter-spacing:-.02em}.shelf-nav__search{flex:1;max-width:260px;padding:6px 14px;border-radius:99px;border:1px solid #d4cfc4;background:#faf8f4;font:inherit;font-size:.78rem;outline:none;transition:border-color .12s}.shelf-nav__search:focus{border-color:#b8845c}.shelf-nav__user{display:flex;align-items:center;gap:6px;margin-left:auto}.shelf-nav__avatar{width:24px;height:24px;border-radius:50%;background:#ede8de;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;color:#7a6d5c}.shelf-nav__uname{font-size:.75rem;font-weight:600;color:#3d3228}.shelf-nav__logout{border:none;background:none;color:#a8a09a;font-size:.6rem;cursor:pointer;text-decoration:underline}.shelf-nav__login{padding:4px 14px;border-radius:99px;border:1.5px solid #b8845c;background:none;color:#b8845c;font-weight:700;font-size:.75rem;cursor:pointer;margin-left:auto;transition:all .12s}.shelf-nav__login:hover{background:#b8845c;color:#fff}.shelf-hero{padding:40px 32px 28px;text-align:center}.shelf-hero__title{font-family:Playfair Display,Georgia,serif;font-size:1.8rem;font-weight:500;letter-spacing:-.03em;line-height:1.4;color:#3d3228}.shelf-hero__sub{font-size:.78rem;color:#8a8478;margin-top:8px;letter-spacing:.03em;line-height:1.7;max-width:400px;margin-left:auto;margin-right:auto}.shelf-hero__line{width:32px;height:1.5px;background:#b8845c;margin:14px auto 0}.shelf-features{max-width:800px;margin:0 auto}.shelf-feat{padding:28px 32px;border-top:.5px solid #e0dbd0}.shelf-feat--alt{background:#f0ebe0}.shelf-feat__row{display:flex;gap:28px;align-items:center}.shelf-feat__row--rev{flex-direction:row-reverse}.shelf-feat__text{flex:1;min-width:0}.shelf-feat__num{font-size:.6rem;color:#b8845c;font-family:monospace;letter-spacing:.1em;margin-bottom:3px}.shelf-feat__title{font-family:Playfair Display,Georgia,serif;font-size:1.1rem;font-weight:500;color:#3d3228;margin-bottom:1px}.shelf-feat__title-en{font-size:.72rem;color:#a8a09a;font-style:italic;margin-bottom:6px}.shelf-feat__desc{font-size:.78rem;color:#6a655c;line-height:1.75}.shelf-feat__vis{width:240px;flex-shrink:0}.shelf-section{padding:0 32px}.shelf-section--alt{background:#f0ebe0;margin:0;padding:0 32px}.shelf-section--lib{border-top:1px solid #e0dbd0;margin-top:20px;padding-top:8px}.shelf-section__head{display:flex;align-items:baseline;gap:10px;padding:24px 0 12px;border-bottom:.5px solid #e0dbd0}.shelf-section__num{font-size:.6rem;color:#b8845c;font-family:monospace;letter-spacing:.1em}.shelf-section__title{font-family:Playfair Display,Georgia,serif;font-size:1.15rem;font-weight:500;color:#3d3228}.shelf-section__tags{margin-left:auto;font-size:.65rem;color:#a8a09a;letter-spacing:.03em}.shelf-section__count{font-size:.6rem;color:#b8845c;margin-left:4px}.shelf-wall{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:14px;padding:18px 0 28px}.shelf-wall--dense{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px}.shelf-wall--dense{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;padding:16px 0 28px}.album{cursor:pointer;transition:transform .2s;position:relative}.album:hover{transform:translateY(-3px)}.album__cover{width:100%;aspect-ratio:1;background:#ece7dc;border-radius:3px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;box-shadow:0 2px 8px #00000014,inset 0 0 0 1px #ffffff14}.album__cover:after{content:"";position:absolute;inset:0;border:.5px solid rgba(0,0,0,.1);border-radius:3px;pointer-events:none}.album__icon{font-size:2.2rem}.album__name{font-size:.75rem;font-weight:600;color:#3d3228;margin-top:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.album__meta{display:flex;justify-content:space-between;font-size:.6rem;color:#a8a09a;margin-top:2px}.album__fav{position:absolute;top:6px;right:6px;width:24px;height:24px;border-radius:50%;border:none;background:#ffffffd9;font-size:.8rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .12s;color:#c4bfb4;z-index:2}.album:hover .album__fav{opacity:1}.album__fav--on{opacity:1;color:#dc2626}.album__fav:hover{transform:scale(1.15)}.shelf-cta{padding:40px 32px;text-align:center;border-top:.5px solid #e0dbd0}.shelf-cta__main{font-family:Playfair Display,Georgia,serif;font-size:1.1rem;font-weight:500;color:#3d3228;line-height:1.6}.shelf-cta__en{font-size:.75rem;color:#a8a09a;font-style:italic;margin-top:4px;letter-spacing:.03em}.shelf-cta__line{width:36px;height:1.5px;background:#b8845c;margin:14px auto 0}.shelf-foot{display:flex;justify-content:space-between;padding:16px 32px;font-size:.58rem;color:#c4bfb4;letter-spacing:.06em;text-transform:uppercase}.shelf-modal{position:fixed;inset:0;z-index:500;background:#00000059;display:flex;align-items:center;justify-content:center}.shelf-modal__card{background:#faf8f4;border-radius:14px;padding:28px;width:300px;max-width:88vw;box-shadow:0 12px 40px #0000001f;text-align:center}.shelf-modal__card h3{font-family:Playfair Display,Georgia,serif;font-size:1.2rem;color:#3d3228;margin:0 0 3px}.shelf-modal__hint{font-size:.68rem;color:#a8a09a;margin:0 0 14px}.shelf-modal__input{width:100%;padding:9px 12px;border-radius:8px;border:1.5px solid #d4cfc4;background:#fff;font:inherit;font-size:.82rem;outline:none;box-sizing:border-box;margin-bottom:10px}.shelf-modal__input:focus{border-color:#b8845c}.shelf-modal__btn{width:100%;padding:9px;border-radius:8px;border:none;background:#b8845c;color:#fff;font-weight:700;font-size:.82rem;cursor:pointer}.shelf-modal__btn:hover{opacity:.85}@media(max-width:640px){.shelf-nav{padding:10px 16px}.shelf-hero{padding:40px 20px 28px}.shelf-hero__title{font-size:1.6rem}.shelf-feat{padding:20px 16px}.shelf-feat__row,.shelf-feat__row--rev{flex-direction:column;gap:12px}.shelf-feat__vis{width:100%;max-width:280px}.shelf-section,.shelf-section--alt{padding:0 16px}.shelf-wall{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:12px}.shelf-cta{padding:28px 16px}.shelf-foot{padding:12px 16px}}:root{--bg:#f5f0e8;--text:#2c2520;--muted:#8d7f74;--accent:#b8845c;--font-display:"Playfair Display","Noto Serif SC",Georgia,serif;--font-reading:"Inter","Noto Sans SC",-apple-system,BlinkMacSystemFont,sans-serif;--ws-bg:#f5f0e8;--ws-paper:#faf6ef;--ws-paper-2:#efe8dc;--ws-ink:#2c2520;--ws-ink-soft:#6b5d54;--ws-ink-mid:#8d7f74;--ws-ink-faint:#b8aca2;--ws-ink-ghost:#d9cfc2;--ws-accent:#b8845c;--ws-accent-dark:#8d5f3f;--ws-accent-soft:#e6d4bf;--ws-red:#c0392b;--ws-red-dark:#992a1f;--ws-red-soft:#e8b5af;--ws-red-bg:rgba(192,57,43,.08);--ws-active:#3d3530;--ws-line:#d9cfc2;--ws-line-soft:#ebe3d6;--ws-green:#5a7247;--ws-gold:#c9a84c}.reading-page{background:var(--ws-bg);min-height:100vh;color:var(--ws-ink);font-family:var(--font-reading);font-feature-settings:"kern","liga";-webkit-font-smoothing:antialiased}.reading-page--loading,.reading-page--error{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;color:var(--ws-ink-mid);text-align:center;max-width:36rem;margin:0 auto}.reading-back-btn{position:fixed;top:14px;left:18px;z-index:120;font:500 12px/1 var(--font-display);letter-spacing:.04em;padding:6px 12px;border-radius:999px;border:1px solid var(--ws-line);background:var(--ws-paper);color:var(--ws-ink-soft);cursor:pointer;transition:all .15s}.reading-back-btn:hover{border-color:var(--ws-accent);color:var(--ws-accent)}.reading-layout{display:grid;grid-template-columns:minmax(0,1fr);max-width:52rem;margin:0 auto;padding:0 1.5rem 4rem;min-height:100vh}.reading-layout--waterfall{grid-template-columns:170px minmax(0,1fr) 320px;gap:0 40px;max-width:1320px;padding:48px 32px 96px}.reading-layout__main{min-width:0;position:relative}.reading-layout--follow{padding-bottom:96px}.reading-chapnav{display:flex;flex-direction:column;gap:4px;padding-top:56px;position:sticky;top:0;align-self:start;height:fit-content;width:170px;flex-shrink:0}.reading-chapnav__item{display:flex;align-items:flex-start;gap:12px;padding:10px 8px 10px 4px;border:none;background:none;cursor:pointer;border-radius:0;text-align:left;transition:all .2s ease;position:relative;min-height:44px}.reading-chapnav__num{font:600 11px/1 var(--font-display);letter-spacing:.02em;color:var(--ws-red);background:transparent;border:1.5px solid var(--ws-red);width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s ease;margin-top:2px}.reading-chapnav__item:hover .reading-chapnav__num{background:var(--ws-red-bg);color:var(--ws-red-dark);border-color:var(--ws-red-dark)}.reading-chapnav__item--active .reading-chapnav__num{background:var(--ws-red);color:var(--ws-paper);border-color:var(--ws-red)}.reading-chapnav__label{font:500 10.5px/1.4 var(--font-display);color:var(--ws-ink-mid);text-transform:uppercase;letter-spacing:.1em;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;transition:color .2s ease;max-width:130px}.reading-chapnav__item:hover .reading-chapnav__label{color:var(--ws-ink-soft)}.reading-chapnav__item--active .reading-chapnav__label{color:var(--ws-ink);font-weight:600}.reading-chapnav__progress{font:400 10px/1.5 var(--font-display);color:var(--ws-ink-mid);padding:12px 8px;margin-top:16px;border-top:1px solid var(--ws-line-soft);font-style:italic;opacity:.7}.reading-top-toolbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:4px;padding:10px 0;margin-bottom:18px;background:linear-gradient(to bottom,var(--ws-bg) 85%,transparent);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:none;flex-wrap:wrap}.reading-viewmode{display:inline-flex;gap:0;margin-right:12px;background:var(--ws-paper);border:1px solid var(--ws-line);border-radius:4px;padding:2px;overflow:hidden}.reading-viewmode__btn{font:600 11px/1 var(--font-display);letter-spacing:.04em;padding:6px 14px;border-radius:3px;border:none;background:transparent;color:var(--ws-ink-mid);cursor:pointer;transition:all .15s ease;white-space:nowrap}.reading-viewmode__btn:hover{color:var(--ws-ink)}.reading-viewmode__btn--active{background:var(--ws-accent);color:var(--ws-paper)}.reading-playback__tool-btn{font:600 11px/1 var(--font-display);letter-spacing:.03em;padding:6px 12px;border-radius:3px;border:1px solid var(--ws-line);background:var(--ws-paper);color:var(--ws-ink-soft);cursor:pointer;transition:all .15s ease;white-space:nowrap}.reading-playback__tool-btn:hover:not(:disabled){border-color:var(--ws-accent);color:var(--ws-accent)}.reading-playback__tool-btn:disabled{opacity:.4;cursor:not-allowed}.reading-playback__tool-btn--active{background:var(--ws-accent);color:var(--ws-paper);border-color:var(--ws-accent)}.reading-toolbar__fontsize{display:flex;align-items:center;gap:6px;margin-left:auto;padding-left:12px}.reading-toolbar__fontsize input[type=range]{-webkit-appearance:none;height:2px;background:var(--ws-line);border-radius:2px;outline:none}.reading-toolbar__fontsize input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:var(--ws-accent);cursor:pointer;border:2px solid var(--ws-paper);box-shadow:0 1px 3px #00000026}.reading-skin-picker{position:relative;display:inline-block}.reading-skin-picker__panel{position:absolute;top:calc(100% + 4px);right:0;z-index:60;background:var(--ws-paper);border:1px solid var(--ws-line);border-radius:4px;box-shadow:0 4px 12px #3c281414;padding:4px;min-width:120px}.reading-skin-picker__item{display:flex;align-items:center;gap:8px;padding:7px 10px;border:none;background:transparent;width:100%;text-align:left;font:500 12px/1 var(--font-display);color:var(--ws-ink);cursor:pointer;border-radius:3px;transition:background .12s}.reading-skin-picker__item:hover{background:var(--ws-paper-2)}.reading-skin-picker__item--active{background:var(--ws-accent);color:var(--ws-paper)}.reading-skin-picker__icon{font-family:monospace;font-size:13px;width:26px;text-align:center}.reading-article{position:relative;max-width:none;width:100%}.reading-article__header{margin-bottom:22px;padding-bottom:14px;border-bottom:1px solid var(--ws-line-soft)}.reading-article__meta{font:500 11.5px/1.6 var(--font-display);text-transform:uppercase;letter-spacing:.14em;color:var(--ws-ink-mid);display:block;margin-bottom:10px}.reading-article__meta strong,.reading-article__meta b{color:var(--ws-ink);font-weight:700;letter-spacing:.16em}.reading-article__meta em{color:var(--ws-accent);font-weight:600;font-style:normal;letter-spacing:.14em}.reading-article__meta span{color:var(--ws-ink-faint);font-weight:400;letter-spacing:.08em}.reading-article__title{font:600 1.7em/1.25 var(--font-display);color:var(--ws-ink);letter-spacing:-.01em;margin:0}.reading-article__body{font:400 1em/1.95 var(--font-reading);color:var(--ws-ink)}.reading-chapters{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding:2px 0;flex-wrap:wrap}.reading-chapters__info{font:500 11px/1 var(--font-display);color:var(--ws-ink-mid);letter-spacing:.04em}.reading-seg{position:relative;margin:0 0 20px;cursor:pointer;padding:10px 10px 8px;border-radius:4px;transition:background .15s ease;border-left:2px solid transparent}.reading-seg:hover{background:#b8845c08}.reading-seg__words{position:relative;z-index:1;line-height:2}.reading-seg--follow{background:#b8845c12;border-left-color:var(--ws-accent)}.reading-seg--clicked{background:#b8845c0a;border-left-color:#b8845c80;transition:background .2s,border-color .2s}.reading-seg__translation{font:400 .85em/1.7 var(--font-display);color:var(--ws-accent-dark);padding:10px 14px;margin:16px 0 6px;background:#b8845c0f;border-radius:4px;border-left:3px solid var(--ws-accent);position:relative;z-index:2}.reading-seg__trans-toggle{display:inline-flex;align-items:center;justify-content:center;font:600 10px/1 var(--font-display);width:18px;height:18px;border-radius:3px;background:#b8845c1f;color:var(--ws-accent);cursor:pointer;margin-left:6px;vertical-align:middle;transition:all .12s;-webkit-user-select:none;user-select:none}.reading-seg__trans-toggle:hover,.reading-seg__trans-toggle--open{background:var(--ws-accent);color:var(--ws-paper)}.reading-seg__follow-btn{display:inline-flex;align-items:center;justify-content:center;font:600 10px/1 var(--font-display);width:18px;height:18px;border-radius:3px;background:#c0392b1a;color:var(--ws-red);cursor:pointer;margin-left:4px;vertical-align:middle;transition:all .12s;-webkit-user-select:none;user-select:none;border:none}.reading-seg__follow-btn:hover,.reading-seg__follow-btn--active{background:var(--ws-red);color:var(--ws-paper)}.reading-seg__follow-zone{margin:12px 0 8px;padding:14px 16px;background:var(--ws-paper);border:1px solid var(--ws-line);border-radius:6px;display:flex;flex-direction:column;gap:10px;position:relative;z-index:2}.reading-seg__follow-status{font:600 12px/1 var(--font-display);color:var(--ws-ink-soft);display:flex;align-items:center;gap:8px}.reading-seg__follow-countdown{font:700 28px/1 var(--font-display);color:var(--ws-red);text-align:center;padding:12px 0;animation:countPop .5s ease}.reading-seg__follow-rec{display:flex;align-items:center;gap:6px;font:600 12px/1 var(--font-display);color:var(--ws-red)}.reading-seg__follow-rec-dot{width:8px;height:8px;border-radius:50%;background:var(--ws-red);animation:fp 1s ease-in-out infinite}.reading-seg__follow-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.reading-seg__follow-btn-action{font:600 11px/1 var(--font-display);padding:6px 12px;border-radius:3px;border:1px solid var(--ws-line);background:var(--ws-paper);color:var(--ws-ink-soft);cursor:pointer;transition:all .12s;white-space:nowrap}.reading-seg__follow-btn-action:hover{border-color:var(--ws-accent);color:var(--ws-accent)}.reading-seg__follow-btn-action--primary{background:var(--ws-red);color:var(--ws-paper);border-color:var(--ws-red)}.reading-seg__follow-btn-action--primary:hover{opacity:.88}.reading-seg__follow-btn-action--stop{background:var(--ws-red);color:var(--ws-paper);border-color:var(--ws-red)}.reading-seg__follow-score{font:700 20px/1 var(--font-display);color:var(--ws-accent)}.reading-seg__follow-feedback{font:500 12px/1.4 var(--font-reading);color:var(--ws-ink-soft)}.reading-w{font:inherit;color:inherit;padding:1px;margin:0;white-space:nowrap;border-radius:2px;transition:color .12s,background-color .12s;line-height:1.9;position:relative;display:inline}.reading-w--active{color:var(--ws-red);font-weight:600;background:#c0392b1a;border-radius:2px;transition:color .08s,background .08s}.reading-w--active:after{content:"";position:absolute;left:50%;bottom:-6px;transform:translate(-50%);width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid var(--ws-red);pointer-events:none;animation:pointerPulse .6s ease-in-out infinite alternate}@keyframes pointerPulse{0%{opacity:.7;transform:translate(-50%) translateY(0)}to{opacity:1;transform:translate(-50%) translateY(1px)}}.reading-w--played{color:var(--ws-ink-mid)}.reading-w--flash{animation:wordFlash .5s ease 3}@keyframes wordFlash{0%,to{background:transparent}50%{background:#c0392b33}}.reading-w__vocab-arrow{position:absolute;bottom:-.5em;left:50%;transform:translate(-50%);font-size:.5em;color:var(--ws-red);opacity:.85;pointer-events:none;line-height:1;font-weight:700}.reading-w--admin-editable:hover{outline:1.5px dashed var(--ws-red);outline-offset:2px;cursor:context-menu}.reading-wave__canvas{display:block;pointer-events:none}.reading-audio-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.reading-chapter-divider{display:flex;align-items:center;gap:12px;margin:40px 0 18px;padding:0}.reading-chapter-divider__label{font:700 10px/1 var(--font-display);letter-spacing:.14em;color:var(--ws-accent);background:transparent;padding:4px 10px;border:1px solid var(--ws-accent);border-radius:3px;white-space:nowrap}.reading-chapter-divider__line{flex:1;height:1px;background:var(--ws-line)}.reading-ets-info{display:flex;gap:18px;padding:6px 0;margin-bottom:10px;font:500 11px/1 var(--font-display);color:var(--ws-ink-mid);border-bottom:1px solid var(--ws-line-soft)}.reading-ets-info__item{display:flex;align-items:baseline;gap:4px}.reading-ets-info__label{font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:10px}.reading-ets-info__value{font-variant-numeric:tabular-nums;font-weight:500;color:var(--ws-ink)}.reading-vocab{position:sticky;top:48px;max-height:calc(100vh - 64px);overflow-y:auto;overflow-x:visible;padding:18px 14px 24px;background:transparent;border:none;border-left:1px solid var(--ws-line-soft);font:400 14px/1.5 var(--font-reading)}.reading-vocab::-webkit-scrollbar{width:3px}.reading-vocab::-webkit-scrollbar-thumb{background:var(--ws-line);border-radius:99px}.reading-vocab__header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:8px;padding:0 4px}.reading-vocab__title{font:600 11px/1 var(--font-display);text-transform:uppercase;letter-spacing:.24em;color:var(--ws-ink-soft);margin:0}.reading-vocab__title:after{content:" LEDGER";color:var(--ws-accent);font-weight:700}.reading-vocab__count{font:500 11px/1 var(--font-display);color:var(--ws-ink-mid);margin-left:6px;letter-spacing:0}.reading-vocab__toolbar{display:flex;flex-direction:column;gap:8px;margin-bottom:12px;padding:0 4px 12px;border-bottom:1px solid var(--ws-line-soft)}.reading-vocab__levels-row{display:flex;gap:6px;flex-wrap:wrap;align-items:center}.reading-vocab__level-btn{font:600 11px/1 var(--font-display);letter-spacing:.04em;padding:6px 11px;border-radius:3px;border:1px solid var(--ws-line);background:var(--ws-paper);color:var(--ws-ink-mid);cursor:pointer;transition:all .15s ease;white-space:nowrap}.reading-vocab__level-btn:hover{border-color:var(--ws-accent);color:var(--ws-accent)}.reading-vocab__level-btn--active{background:var(--ws-accent);color:var(--ws-paper);border-color:var(--ws-accent)}.reading-vocab__level-hint{font:400 11px/1.5 var(--font-display);color:var(--ws-ink-mid);padding:0 4px;font-style:italic;margin:6px 0 10px}.reading-vocab__actions{display:flex;align-items:center;gap:6px;padding-top:8px;border-top:1px dashed var(--ws-line-soft);margin-top:4px}.reading-vocab__ai-btn,.reading-toolbar__action-btn{font:600 11px/1 var(--font-display);letter-spacing:.03em;padding:6px 11px;border-radius:3px;border:1px solid var(--ws-accent);background:var(--ws-paper);color:var(--ws-accent);cursor:pointer;transition:all .12s}.reading-vocab__ai-btn:hover:not(:disabled),.reading-toolbar__action-btn:hover:not(:disabled){background:var(--ws-accent);color:var(--ws-paper)}.reading-vocab__ai-btn:disabled,.reading-toolbar__action-btn:disabled{opacity:.4;cursor:not-allowed}.reading-vocab__config-btn,.reading-toolbar__config-btn{font-size:14px;border:none;background:none;color:var(--ws-ink-mid);cursor:pointer;padding:3px 6px;border-radius:3px}.reading-vocab__config-btn:hover,.reading-toolbar__config-btn:hover{color:var(--ws-accent)}.reading-vocab__tip{font:500 12px/1.5 var(--font-reading);color:var(--ws-accent-dark);background:#b8845c14;padding:8px 10px;border-radius:4px;margin-bottom:10px;border-left:2.5px solid var(--ws-accent)}.reading-toolbar__api-panel,.reading-vocab__api-panel{margin:8px 0;padding:10px;border-radius:4px;background:var(--ws-paper-2);border:1px solid var(--ws-line);display:flex;flex-direction:column;gap:6px}.reading-toolbar__api-label,.reading-vocab__api-label{display:flex;flex-direction:column;gap:3px;font:600 9.5px/1 var(--font-display);color:var(--ws-ink-mid);text-transform:uppercase;letter-spacing:.08em}.reading-toolbar__api-input,.reading-vocab__api-input{font:400 12px/1 var(--font-reading);padding:6px 8px;border-radius:3px;border:1px solid var(--ws-line);background:var(--ws-paper);color:var(--ws-ink);outline:none}.reading-toolbar__api-input:focus,.reading-vocab__api-input:focus{border-color:var(--ws-accent)}.reading-toolbar__api-save,.reading-vocab__api-save{font:600 11px/1 var(--font-display);padding:6px 12px;border-radius:3px;border:none;background:var(--ws-accent);color:var(--ws-paper);cursor:pointer;align-self:flex-start;margin-top:2px}.reading-vocab__col-header{display:none}.reading-vocab__empty{margin:12px 4px;font:400 12px/1.5 var(--font-reading);color:var(--ws-ink-mid);font-style:italic}.reading-vocab__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:0}.reading-vocab__item{display:flex;align-items:center;gap:10px;padding:10px 8px 10px 16px;border-radius:0;cursor:default;transition:background-color .12s;border:none;border-bottom:1px solid var(--ws-line-soft);position:relative;min-height:auto}.reading-vocab__item:before{content:"";position:absolute;left:4px;top:12px;bottom:12px;width:2px;background:var(--ws-red);opacity:.75}.reading-vocab__item:hover{background:#b8845c0a}.reading-vocab__item:hover:before{opacity:1}.reading-vocab__item--active{background:#b8845c14}.reading-vocab__item--active:before{background:var(--ws-accent);opacity:1;width:3px}.reading-vocab__item--phrase .reading-vocab__word{font-style:italic}.reading-vocab__phrase-tag{display:inline-block;font:700 9px/1.2 var(--font-display);padding:2px 5px;border-radius:2px;background:#8b5cf61f;color:#7c4ddf;margin-right:5px;vertical-align:middle;letter-spacing:.04em}.reading-vocab__status{width:10px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:8px;line-height:1}.reading-vocab__arrow{color:var(--ws-accent);font-size:11px;font-weight:700}.reading-vocab__dot{color:var(--ws-red);font-size:7px}.reading-vocab__word-row{flex:1;min-width:0;cursor:pointer;display:flex;flex-direction:row;align-items:baseline;gap:10px;padding-right:4px;overflow:hidden}.reading-vocab__word{font:600 17px/1.25 var(--font-display);color:var(--ws-ink);white-space:nowrap;flex-shrink:0;max-width:55%;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:baseline;gap:4px;letter-spacing:-.005em}.reading-vocab__meaning{font:400 13.5px/1.4 var(--font-reading);color:var(--ws-ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.reading-vocab__item--admin-editable:hover{outline:1.5px dashed var(--ws-red);outline-offset:-1px}.reading-vocab__repeat{font:500 10px/1 var(--font-display);color:var(--ws-ink-mid);margin-left:2px;padding:1px 5px;background:var(--ws-line-soft);border-radius:99px;letter-spacing:.02em}.reading-vocab__me-btn{font-size:13px;width:22px;height:22px;display:flex;align-items:center;justify-content:center;border:1.2px solid var(--ws-line);border-radius:50%;background:transparent;color:var(--ws-ink-mid);cursor:pointer;flex-shrink:0;transition:all .12s;line-height:1}.reading-vocab__me-btn:hover{border-color:#22c55e;color:#22c55e;background:#22c55e14}.reading-vocab__item--editing{background:var(--ws-paper);border:1px solid var(--ws-accent);border-radius:4px;padding:8px 10px 8px 16px}.reading-vocab__item--editing:before{background:var(--ws-accent);width:3px;opacity:1}.reading-vocab__edit-input{font:500 15px/1 var(--font-reading);color:var(--ws-ink);border:none;border-bottom:1.5px solid var(--ws-accent);background:transparent;outline:none;padding:2px 0;width:100%}.reading-vocab__edit-input--word{font:600 16px/1 var(--font-display);max-width:45%;flex-shrink:0}.reading-vocab__edit-input--meaning{font:400 13.5px/1 var(--font-reading);flex:1;min-width:0;color:var(--ws-ink-soft)}.reading-vocab__edit-input:focus{border-bottom-color:var(--ws-red)}.reading-vocab__edit-hint{font:400 10px/1 var(--font-display);color:var(--ws-ink-faint);position:absolute;right:8px;bottom:2px}.reading-vocab__chapters{display:flex;flex-direction:column;gap:0}.reading-vocab__chapter-group{border-radius:0;overflow:hidden}.reading-vocab__chapter-label{display:flex;align-items:center;gap:8px;padding:16px 4px 8px;border-bottom:none;position:sticky;top:0;background:var(--ws-bg);z-index:1}.reading-vocab__chapter-tag{font:700 10px/1 var(--font-display);letter-spacing:.12em;padding:3px 8px;border-radius:2px;background:transparent;color:var(--ws-ink-mid);border:1px solid var(--ws-line);transition:all .12s}.reading-vocab__chapter-tag--active{background:var(--ws-accent);color:var(--ws-paper);border-color:var(--ws-accent)}.reading-vocab__chapter-count{font:500 11px/1 var(--font-display);color:var(--ws-ink-mid);letter-spacing:.04em}.reading-vocab__report-btn{font-size:10px;color:var(--ws-ink-mid);border:none;background:transparent;cursor:pointer;padding:2px 4px;border-radius:2px;flex-shrink:0;opacity:0;transition:opacity .15s}.reading-vocab__item:hover .reading-vocab__report-btn{opacity:.8}.reading-vocab__report-btn:hover{color:var(--ws-red)}.reading-w--highlight{transition:background-color .15s,border-color .15s}.reading-w--highlight:hover{filter:brightness(.94)}.reading-w--hidden{color:transparent!important;-webkit-user-select:none;user-select:none;pointer-events:none}.reading-highlight-legend{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.reading-highlight-legend__item{font:600 10px/1 var(--font-display);letter-spacing:.06em;padding:4px 10px;border-radius:2px;color:#2c2520bf}.reading-w--cloze,.reading-w--cloze-blank{display:inline-block;text-align:center;font:inherit;font-size:.92em;padding:2px 6px;border:none;border-bottom:1.5px solid var(--ws-ink-mid);background:transparent;color:transparent;cursor:pointer;transition:all .15s;letter-spacing:.06em;-webkit-user-select:none;user-select:none;vertical-align:baseline;line-height:1.5;min-width:60px}.reading-w--cloze:hover,.reading-w--cloze-blank:hover{border-bottom-color:var(--ws-accent);background:#b8845c0f}.reading-w--cloze-show,.reading-w--cloze-revealed{color:#16a34a!important;font-weight:500;background:#22c55e0f;padding:1px 4px;border-radius:2px;border-bottom:1.5px solid rgba(34,197,94,.5)}.reading-w--cloze-phrase{min-width:120px}.reading-cloze-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:14px;padding:8px 12px;border-radius:4px;background:var(--ws-paper-2);border:1px solid var(--ws-line);flex-wrap:wrap}.reading-cloze-toolbar__stats{font:500 12px/1 var(--font-display);color:var(--ws-ink-soft)}.reading-cloze-toolbar__stats strong{color:var(--ws-ink);font-weight:700}.reading-cloze-toolbar__btn{font:600 11px/1 var(--font-display);padding:5px 12px;border-radius:3px;border:1px solid var(--ws-accent);background:transparent;color:var(--ws-accent);cursor:pointer;transition:all .12s;margin-left:auto}.reading-cloze-toolbar__btn:hover{background:var(--ws-accent);color:var(--ws-paper)}.reading-w--cloze-hidden{display:inline-block;width:0;overflow:hidden;height:0;margin:0;padding:0}.reading-player{position:fixed;bottom:0;left:0;right:0;z-index:100;background:#f5f0e8f2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--ws-line)}.reading-player__progress-bar{position:relative;height:2px;background:var(--ws-line-soft);cursor:pointer}.reading-player__progress-fill{height:100%;background:var(--ws-accent);transition:width .08s linear}.reading-player__scrub{position:absolute;inset:-6px 0 0;width:100%;opacity:0;cursor:pointer;margin:0;height:14px}.reading-player__row{display:flex;align-items:center;justify-content:center;gap:14px;padding:8px 24px;max-width:1320px;margin:0 auto}.reading-player__speeds{display:flex;gap:2px}.reading-playback__speed{font:600 11px/1 var(--font-display);letter-spacing:.02em;padding:5px 9px;border-radius:2px;border:1px solid transparent;background:transparent;color:var(--ws-ink-mid);cursor:pointer;transition:all .1s;min-width:32px}.reading-playback__speed:hover{color:var(--ws-accent)}.reading-playback__speed--active{color:var(--ws-ink);font-weight:700;border-bottom:1.5px solid var(--ws-ink);border-radius:0}.reading-player__controls{display:flex;align-items:center;gap:6px}.reading-player__nav{font:500 26px/1 var(--font-display);color:var(--ws-ink-mid);background:none;border:none;cursor:pointer;padding:2px 8px;border-radius:4px;transition:all .12s;-webkit-user-select:none;user-select:none}.reading-player__nav:hover:not(:disabled){color:var(--ws-ink);background:#2c25200d}.reading-player__nav:disabled{opacity:.25;cursor:not-allowed}.reading-playback__btn{width:30px;height:30px;border:none;background:none;cursor:pointer;font-size:13px;color:var(--ws-ink-soft);border-radius:50%;transition:all .12s;display:flex;align-items:center;justify-content:center}.reading-playback__btn:hover:not(:disabled){background:#2c25200f;color:var(--ws-ink)}.reading-playback__btn:disabled{opacity:.25;cursor:not-allowed}.reading-playback__btn--primary{width:42px;height:42px;border-radius:50%;background:var(--ws-ink);color:var(--ws-paper);font-size:16px;box-shadow:0 1px 3px #2c252026}.reading-playback__btn--primary:hover:not(:disabled){background:var(--ws-active);transform:scale(1.04)}.reading-playback__btn--follow-play{width:34px;height:34px;border-radius:50%;background:var(--ws-accent);color:var(--ws-paper);font-size:13px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s}.reading-playback__btn--follow-play:hover:not(:disabled){background:var(--ws-accent-dark);transform:scale(1.04)}.reading-playback__btn--follow-play:disabled{opacity:.25;cursor:not-allowed}.reading-playback__btn--rec{width:38px;height:38px;border:2px solid var(--ws-line);border-radius:50%;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.reading-playback__btn--rec:hover:not(:disabled){border-color:var(--ws-red)}.reading-playback__btn--rec:disabled{opacity:.25;cursor:not-allowed}.reading-playback__btn--rec-active{border-color:var(--ws-red);background:#c0392b0f}.reading-player__rec-dot{display:block;width:14px;height:14px;border-radius:50%;background:var(--ws-red);transition:all .15s}.reading-player__rec-dot--active{animation:recPulse 1s ease-in-out infinite}@keyframes recPulse{0%,to{opacity:1}50%{opacity:.2}}.reading-player__replay-btn{font:500 24px/1 var(--font-reading);color:var(--ws-ink-mid);background:none;border:none;cursor:pointer;padding:2px 6px;border-radius:4px;transition:all .12s}.reading-player__replay-btn:hover:not(:disabled){color:var(--ws-accent);background:#b8845c0f}.reading-player__replay-btn:disabled{opacity:.25;cursor:not-allowed}.reading-player__right-group{display:flex;align-items:center;gap:16px;margin-left:20px}.reading-player__mode-btn{font:600 12px/1 var(--font-display);letter-spacing:.04em;padding:7px 16px;border-radius:4px;border:1px solid var(--ws-line);background:var(--ws-paper);color:var(--ws-ink-soft);cursor:pointer;transition:all .12s;white-space:nowrap}.reading-player__mode-btn:hover:not(:disabled){border-color:var(--ws-accent);color:var(--ws-accent)}.reading-player__mode-btn:disabled{opacity:.35;cursor:not-allowed}.reading-player__mode-btn--report{color:var(--ws-accent);border-color:var(--ws-accent)}.reading-player__mode-btn--report:hover:not(:disabled){background:var(--ws-accent);color:var(--ws-paper)}.reading-player__mode-btn--exit{color:var(--ws-ink-mid)}.reading-player__mode-btn--exit:hover{border-color:var(--ws-red);color:var(--ws-red)}.reading-player__time{font:500 11.5px/1 var(--font-display);color:var(--ws-ink-mid);font-variant-numeric:tabular-nums;letter-spacing:.04em;white-space:nowrap}.reading-playback__error{margin:0;padding:6px 24px;font:500 12px/1.3 var(--font-reading);color:#991b1b;background:#f871711a}.reading-user-wave-overlay{pointer-events:none}.reading-follow-report{max-width:560px;margin:48px auto 32px;padding:32px 36px 28px;background:var(--ws-paper);border:1px solid var(--ws-line);border-radius:2px;box-shadow:0 1px 3px #3c28140a,0 8px 32px #3c28140d;position:relative}.reading-follow-report:before{content:"";position:absolute;top:-1px;left:-1px;width:24px;height:24px;border-top:2px solid var(--ws-accent);border-left:2px solid var(--ws-accent);pointer-events:none}.reading-follow-report:after{content:"";position:absolute;bottom:-1px;right:-1px;width:24px;height:24px;border-bottom:2px solid var(--ws-accent);border-right:2px solid var(--ws-accent);pointer-events:none}.reading-follow-report__topline{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}.reading-follow-report__eyebrow{font:600 10px/1 var(--font-display);letter-spacing:.24em;color:var(--ws-ink-faint);text-transform:uppercase}.reading-follow-report__close{border:none;background:none;font-size:15px;color:var(--ws-ink-mid);cursor:pointer;padding:2px 6px;border-radius:2px;transition:all .12s;line-height:1}.reading-follow-report__close:hover{color:var(--ws-red);background:var(--ws-red-bg)}.reading-follow-report__title{font:600 24px/1.3 var(--font-display);color:var(--ws-ink);margin:0 0 24px;letter-spacing:-.005em}.reading-follow-report__hero{display:flex;align-items:center;gap:24px;padding:20px 0 28px;margin-bottom:24px;border-bottom:1px solid var(--ws-line-soft)}.reading-follow-report__ring{flex-shrink:0;display:block}.reading-follow-report__ring-bg{fill:none;stroke:var(--ws-line-soft);stroke-width:6}.reading-follow-report__ring-fg{fill:none;stroke-width:6;stroke-linecap:round;transition:stroke-dashoffset .9s cubic-bezier(.2,.8,.3,1)}.reading-follow-report__ring-num{font:700 32px/1 var(--font-display);fill:var(--ws-ink);letter-spacing:-.02em}.reading-follow-report__ring-denom{font:500 11px/1 var(--font-display);fill:var(--ws-ink-mid);letter-spacing:.04em}.reading-follow-report__hero-text{flex:1;min-width:0}.reading-follow-report__encouragement{font:600 15px/1.5 var(--font-reading);color:var(--ws-ink);margin:0 0 8px}.reading-follow-report__meta{font:500 11px/1.5 var(--font-display);color:var(--ws-ink-mid);letter-spacing:.03em;margin:0;display:flex;flex-wrap:wrap;gap:6px}.reading-follow-report__meta-sep{color:var(--ws-ink-faint)}.reading-follow-report__dims{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--ws-line-soft);border:1px solid var(--ws-line-soft);border-radius:2px;margin-bottom:24px;overflow:hidden}.reading-follow-report__dim{background:var(--ws-paper);padding:16px 10px;text-align:center}.reading-follow-report__dim-num{font:700 28px/1 var(--font-display);letter-spacing:-.02em;margin-bottom:4px;font-variant-numeric:tabular-nums}.reading-follow-report__dim-label{font:600 12px/1.2 var(--font-display);color:var(--ws-ink);letter-spacing:.04em;margin-bottom:3px}.reading-follow-report__dim-sub{font:400 10px/1.3 var(--font-display);color:var(--ws-ink-mid);letter-spacing:.02em;font-style:italic}.reading-follow-report__toggle{display:inline-flex;align-items:center;gap:8px;background:none;border:none;cursor:pointer;padding:4px 0;font:600 12px/1 var(--font-display);color:var(--ws-accent);letter-spacing:.04em;margin-bottom:14px;transition:color .12s}.reading-follow-report__toggle:hover{color:var(--ws-accent-dark)}.reading-follow-report__toggle-arrow{display:inline-block;font-size:14px;transition:transform .2s ease}.reading-follow-report__toggle-arrow--open{transform:rotate(90deg)}.reading-follow-report__factors{background:#b8845c08;padding:18px 20px;border-radius:2px;margin-bottom:24px;border:1px dashed var(--ws-line)}.reading-follow-report__factor{margin-bottom:12px}.reading-follow-report__factor:last-of-type{margin-bottom:0}.reading-follow-report__factor-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:5px}.reading-follow-report__factor-label{font:500 12.5px/1 var(--font-reading);color:var(--ws-ink);letter-spacing:.02em}.reading-follow-report__factor-value{font:500 11px/1 var(--font-display);color:var(--ws-ink-mid);font-variant-numeric:tabular-nums;letter-spacing:.02em}.reading-follow-report__factor-track{height:4px;background:var(--ws-line-soft);border-radius:2px;overflow:hidden}.reading-follow-report__factor-fill{height:100%;border-radius:2px;transition:width .6s cubic-bezier(.2,.8,.3,1)}.reading-follow-report__upgrade-note{margin-top:18px;padding-top:14px;border-top:1px dashed var(--ws-line);display:flex;flex-direction:column;gap:4px}.reading-follow-report__upgrade-note strong{font:600 10px/1 var(--font-display);letter-spacing:.12em;text-transform:uppercase;color:var(--ws-ink-faint)}.reading-follow-report__upgrade-note span{font:400 11.5px/1.6 var(--font-reading);color:var(--ws-ink-mid);font-style:italic}.reading-follow-report__block{margin-bottom:24px}.reading-follow-report__block-title{font:600 13px/1 var(--font-display);color:var(--ws-ink);letter-spacing:.04em;margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--ws-line-soft);position:relative}.reading-follow-report__block-title:before{content:"";position:absolute;left:0;bottom:-1px;width:32px;height:1px;background:var(--ws-accent)}.reading-follow-report__chips{display:flex;flex-wrap:wrap;gap:6px}.reading-follow-report__chip{display:inline-block;padding:5px 10px;background:#c9a84c1a;border:1px solid rgba(201,168,76,.3);color:var(--ws-ink);border-radius:2px;font:500 12px/1.2 var(--font-reading);letter-spacing:.01em}.reading-follow-report__linking-list{display:flex;flex-direction:column;gap:6px}.reading-follow-report__linking-item{padding:8px 12px;background:#5a72470f;border-left:2px solid var(--ws-green);border-radius:0 2px 2px 0;font:500 12.5px/1.5 var(--font-reading);color:var(--ws-ink)}.reading-follow-report__weak-row{display:flex;align-items:baseline;gap:12px;padding:10px 0;border-bottom:1px dashed var(--ws-line-soft)}.reading-follow-report__weak-row:last-child{border-bottom:none}.reading-follow-report__weak-rank{font:700 12px/1 var(--font-display);color:var(--ws-ink-faint);min-width:16px;font-variant-numeric:tabular-nums}.reading-follow-report__weak-text{flex:1;font:400 13px/1.55 var(--font-reading);color:var(--ws-ink);min-width:0}.reading-follow-report__weak-score{font:700 15px/1 var(--font-display);font-variant-numeric:tabular-nums;letter-spacing:-.01em;min-width:32px;text-align:right}.reading-follow-report__suggestion{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;margin-bottom:8px;background:#b8845c0f;border-radius:2px;border-left:2px solid var(--ws-accent)}.reading-follow-report__suggestion:last-child{margin-bottom:0}.reading-follow-report__suggestion-icon{font-size:18px;line-height:1.4;flex-shrink:0}.reading-follow-report__suggestion-text{font:400 12.5px/1.65 var(--font-reading);color:var(--ws-ink)}.reading-follow-report__footer{margin-top:20px;padding-top:16px;border-top:1px solid var(--ws-line-soft);text-align:center}.reading-follow-report__footer-note{font:400 10.5px/1.4 var(--font-display);color:var(--ws-ink-faint);font-style:italic;letter-spacing:.06em}.ws-admin-badge{display:inline-flex;align-items:center;gap:4px;font:600 10px/1 var(--font-display);letter-spacing:.08em;padding:3px 8px;border-radius:3px;background:var(--ws-red);color:var(--ws-paper);text-transform:uppercase;margin-left:6px}@media(max-width:1100px){.reading-layout--waterfall{grid-template-columns:150px minmax(0,1fr) 280px;gap:0 24px;padding:40px 20px 96px}.reading-chapnav{width:150px}.reading-chapnav__label{max-width:110px}.reading-vocab__word{font-size:16px}}@media(max-width:900px){.reading-layout--waterfall{grid-template-columns:auto 1fr;gap:0 16px;padding:24px 16px 96px}.reading-vocab{display:none}}@media(max-width:720px){.reading-player__row{padding:6px 12px;gap:6px}.reading-player__speeds{display:none}.reading-player__right-group{margin-left:auto;gap:8px}.reading-chapnav{display:none}.reading-layout--waterfall{grid-template-columns:minmax(0,1fr);padding:16px}.reading-follow-report{padding:20px 18px;margin:24px 12px}.reading-follow-report__hero{flex-direction:column;text-align:center;gap:16px}.reading-follow-report__dims{grid-template-columns:repeat(2,1fr)}}.companion-fab{position:fixed;top:50%;right:0;transform:translateY(-50%);z-index:300;width:54px;height:54px;border-radius:16px 0 0 16px;border:none;background:#b8845c;color:#fff;font-size:.78rem;font-weight:700;letter-spacing:.5px;cursor:pointer;box-shadow:-4px 0 16px #b8845c59;transition:all .2s;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;line-height:1;padding:0}.companion-fab:hover{background:#a0703e;box-shadow:-6px 0 24px #b8845c73;padding-right:4px}.companion-fab__icon{font-size:1.1rem;margin-bottom:1px}.companion-fab__label{font-size:.64rem;font-weight:700;letter-spacing:1px}.companion-fab--open{background:#5a4a3a;width:38px;border-radius:12px 0 0 12px}.companion-fab--open .companion-fab__label{display:none}.companion-fab--open .companion-fab__icon{font-size:1rem;margin:0}.companion-panel{position:fixed;top:50%;right:60px;transform:translateY(-50%);z-index:300;width:380px;max-width:calc(100vw - 80px);height:min(520px,80vh);background:#faf8f4;border:1px solid #e0dbd0;border-radius:16px;box-shadow:0 12px 40px #0000001f;display:flex;flex-direction:column;overflow:hidden;animation:companion-in .2s ease}@keyframes companion-in{0%{opacity:0;transform:translateY(-50%) translate(16px) scale(.95)}to{opacity:1;transform:translateY(-50%) translate(0) scale(1)}}.companion-header{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#f0ebe0;border-bottom:1px solid #e0dbd0}.companion-header__icon{font-size:1.4rem}.companion-header__info{flex:1}.companion-header__title{font-size:.88rem;font-weight:700;color:#3d3228;margin:0}.companion-header__sub{font-size:.65rem;color:#8a8478;margin:0}.companion-header__close{border:none;background:none;font-size:1rem;color:#8a8478;cursor:pointer;padding:4px}.companion-header__close:hover{color:#3d3228}.companion-messages{flex:1;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:10px}.companion-messages::-webkit-scrollbar{width:4px}.companion-messages::-webkit-scrollbar-thumb{background:#d4cfc4;border-radius:99px}.companion-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#a8a09a;text-align:center;gap:12px}.companion-empty p{font-size:.85rem}.companion-start-btn{padding:8px 20px;border-radius:999px;border:1.5px solid #b8845c;background:transparent;color:#b8845c;font-weight:700;font-size:.82rem;cursor:pointer;transition:all .15s}.companion-start-btn:hover{background:#b8845c;color:#fff}.companion-msg{display:flex;align-items:flex-start;gap:6px}.companion-msg--user{flex-direction:row-reverse}.companion-msg__avatar{font-size:.9rem;flex-shrink:0;margin-top:4px}.companion-msg__bubble{max-width:85%;padding:8px 12px;border-radius:12px;font-size:.82rem;line-height:1.55}.companion-msg__bubble--ai{background:#f0ebe0;color:#3d3228;border-bottom-left-radius:4px}.companion-msg__bubble--user{background:#b8845c;color:#fff;border-bottom-right-radius:4px}.companion-msg__text{margin:0 0 4px}.companion-msg__text:last-child{margin-bottom:0}.companion-msg__correction{margin:4px 0;padding:4px 8px;background:#ef9f271f;border-left:3px solid #ef9f27;border-radius:0 6px 6px 0;font-size:.78rem;color:#7a5a1a;line-height:1.5}.companion-msg__suggestion{margin:4px 0;padding:4px 8px;background:#5dcaa51f;border-left:3px solid #5dcaa5;border-radius:0 6px 6px 0;font-size:.78rem;color:#0f6e56;line-height:1.5}.companion-msg__typing{display:flex;gap:4px;padding:10px 16px}.companion-msg__typing span{width:6px;height:6px;border-radius:50%;background:#b8a88e;animation:typing-dot .6s ease-in-out infinite}.companion-msg__typing span:nth-child(2){animation-delay:.15s}.companion-msg__typing span:nth-child(3){animation-delay:.3s}@keyframes typing-dot{0%,to{opacity:.3;transform:translateY(0)}50%{opacity:1;transform:translateY(-4px)}}.companion-input-bar{display:flex;align-items:flex-end;gap:6px;padding:10px 12px;border-top:1px solid #e0dbd0;background:#f5f0e8}.companion-input{flex:1;padding:8px 12px;border:1.5px solid #d4cfc4;border-radius:12px;background:#faf8f4;font:inherit;font-size:.82rem;resize:none;outline:none;max-height:80px;line-height:1.4;transition:border-color .15s}.companion-input:focus{border-color:#b8845c}.companion-input:disabled{opacity:.5}.companion-send{width:34px;height:34px;border-radius:50%;border:none;background:#b8845c;color:#fff;font-size:1rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s;flex-shrink:0}.companion-send:hover:not(:disabled){background:#a0703e}.companion-send:disabled{opacity:.35;cursor:not-allowed}@media(max-width:480px){.companion-panel{width:calc(100vw - 64px);right:50px;height:min(480px,75vh)}.companion-fab{width:44px;height:44px}}.follow-float{position:fixed;bottom:0;left:0;right:0;z-index:200;padding:18px 28px 14px;background:#f5f0e8f5;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-top:1px solid var(--ws-line,#d9cfc2);box-shadow:0 -6px 24px #3c281414;max-height:90vh;overflow-y:auto;font-family:var(--font-reading)}.follow-float__row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.follow-float__label{font:600 11px/1 var(--font-display);letter-spacing:.16em;text-transform:uppercase;color:var(--ws-accent,#b8845c);margin-right:6px}.follow-float__btn{font:600 11.5px/1 var(--font-display);letter-spacing:.04em;padding:7px 14px;border-radius:3px;border:1px solid var(--ws-line,#d9cfc2);background:var(--ws-paper,#faf6ef);color:var(--ws-ink,#2c2520);cursor:pointer;transition:all .14s ease;white-space:nowrap}.follow-float__btn:hover{border-color:var(--ws-accent,#b8845c);color:var(--ws-accent,#b8845c)}.follow-float__btn--primary{background:var(--ws-ink,#2c2520);color:var(--ws-paper,#faf6ef);border-color:var(--ws-ink,#2c2520)}.follow-float__btn--primary:hover{background:var(--ws-active,#3d3530);border-color:var(--ws-active,#3d3530);color:var(--ws-paper,#faf6ef)}.follow-float__btn--stop{background:var(--ws-red,#c0392b);color:var(--ws-paper,#faf6ef);border-color:var(--ws-red,#c0392b)}.follow-float__btn--stop:hover{opacity:.88}.follow-float__btn--ghost{background:transparent;color:var(--ws-ink-mid,#8d7f74);border-color:transparent;font-size:11px}.follow-float__btn--ghost:hover{color:var(--ws-accent,#b8845c);background:#b8845c0d}.follow-float__btn--sm{font-size:10.5px;padding:5px 10px}.follow-float__btn--exit{border:1px solid var(--ws-ink-ghost,#d9cfc2);background:var(--ws-paper,#faf6ef);color:var(--ws-ink-soft,#6b5d54);font-size:11.5px;padding:7px 14px}.follow-float__btn--exit:hover{border-color:var(--ws-red,#c0392b);color:var(--ws-red,#c0392b);background:var(--ws-red-bg,rgba(192,57,43,.06))}.follow-float__active{display:flex;flex-direction:column;gap:10px}.follow-float__top-row{display:flex;align-items:center;gap:12px;padding-bottom:10px;border-bottom:1px solid var(--ws-line-soft,#ebe3d6)}.follow-float__step{font:600 12px/1 var(--font-display);letter-spacing:.08em;color:var(--ws-ink-soft,#6b5d54);min-width:3.5rem;font-variant-numeric:tabular-nums}.follow-float__progress{flex:1;height:2px;border-radius:2px;background:var(--ws-line-soft,#ebe3d6);overflow:hidden}.follow-float__progress-fill{height:100%;background:var(--ws-accent,#b8845c);border-radius:2px;transition:width .3s}.follow-float__sentence{font:500 19px/1.65 var(--font-reading);color:var(--ws-ink,#2c2520);margin:0;padding:10px 18px;background:transparent;border-radius:0;border-left:2.5px solid var(--ws-accent,#b8845c)}.follow-float__state{font:500 12.5px/1 var(--font-reading);color:var(--ws-ink,#2c2520)}.follow-float__rec{display:flex;align-items:center;gap:6px;color:var(--ws-red,#c0392b);font-weight:600;font-size:12px;font-family:var(--font-display);letter-spacing:.06em}.follow-float__rec-dot{width:8px;height:8px;border-radius:50%;background:var(--ws-red,#c0392b);animation:fp 1s ease-in-out infinite}@keyframes fp{0%,to{opacity:1}50%{opacity:.3}}.follow-float__countdown{color:var(--ws-accent,#b8845c);font-weight:700;font-size:22px;font-family:var(--font-display);animation:countPop .5s ease}@keyframes countPop{0%{transform:scale(1.4);opacity:.5}to{transform:scale(1);opacity:1}}.follow-float__guide-state{color:var(--ws-accent,#b8845c);font-weight:600;animation:guidePulse 1s ease-in-out infinite}@keyframes guidePulse{0%,to{opacity:1}50%{opacity:.5}}.follow-float__scored-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;width:100%}.follow-float__line-score{font:700 22px/1 var(--font-display);color:var(--ws-accent,#b8845c);letter-spacing:-.02em}.follow-float__feedback{font:500 12.5px/1.4 var(--font-reading);color:var(--ws-ink-soft,#6b5d54)}.follow-float__hint{font:500 11px/1.4 var(--font-reading);color:var(--ws-accent-dark,#8d5f3f);background:#b8845c14;padding:3px 10px;border-radius:99px;border:1px solid rgba(184,132,92,.15)}.wave-compare{margin:6px 0;max-width:100%}.wave-compare__text{font:400 11.5px/1.4 var(--font-display);color:var(--ws-ink-mid,#8d7f74);margin:0 0 4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-style:italic}.wave-compare__canvas{display:block;width:100%;max-width:100%;border-radius:3px;background:#2c252005}.follow-float__report{display:flex;flex-direction:column;gap:10px;padding:16px 20px;background:var(--ws-paper,#faf6ef);border:1px solid var(--ws-line,#d9cfc2);border-radius:6px}.follow-float__report-head{display:flex;align-items:center;gap:16px;padding-bottom:12px;border-bottom:1px solid var(--ws-line-soft,#ebe3d6)}.follow-float__report-score{font:700 42px/1 var(--font-display);color:var(--ws-accent,#b8845c);letter-spacing:-.02em}.follow-float__report-head-right{flex:1}.follow-float__encouragement{font:600 14px/1.4 var(--font-reading);color:var(--ws-ink,#2c2520);margin:0}.follow-float__report-meta{font:500 11px/1.4 var(--font-display);color:var(--ws-ink-mid,#8d7f74);letter-spacing:.04em;margin:4px 0 0}.follow-float__scores{display:flex;gap:16px;flex-wrap:wrap;padding:4px 0}.follow-float__bar{display:flex;align-items:center;gap:6px;min-width:11rem}.follow-float__bar-label{font:600 11px/1 var(--font-display);width:3.5rem;color:var(--ws-ink-soft,#6b5d54);text-align:right;letter-spacing:.04em}.follow-float__bar-track{flex:1;height:4px;border-radius:3px;background:var(--ws-line-soft,#ebe3d6);overflow:hidden;min-width:4rem}.follow-float__bar-fill{height:100%;border-radius:3px;transition:width .3s}.follow-float__bar-num{font:600 11px/1 var(--font-display);width:1.8rem;text-align:right;color:var(--ws-ink,#2c2520);font-variant-numeric:tabular-nums}.follow-float__strengths{font:500 12px/1.5 var(--font-reading);color:#166534;background:#22c55e12;padding:8px 14px;border-radius:3px;border-left:2.5px solid rgba(34,197,94,.5)}.follow-float__improvements{font:500 12px/1.5 var(--font-reading);color:#7a3e00;background:#eab30812;padding:8px 14px;border-radius:3px;border-left:2.5px solid rgba(234,179,8,.5)}.follow-float__full-report{display:flex;flex-direction:column;gap:6px;padding:14px 18px;background:var(--ws-paper,#faf6ef);border:1px solid var(--ws-line,#d9cfc2);border-radius:6px}.follow-float__sentences-scroll{max-height:50vh;overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding:4px 0}.follow-float__sentences-scroll::-webkit-scrollbar{width:3px}.follow-float__sentences-scroll::-webkit-scrollbar-thumb{background:var(--ws-line,#d9cfc2);border-radius:99px}.follow-float__sentence-card{background:transparent;border:1px solid var(--ws-line-soft,#ebe3d6);border-radius:4px;padding:10px 12px;display:flex;flex-direction:column;gap:4px}.follow-float__sentence-card-head{display:flex;align-items:center;gap:8px;margin-bottom:2px}.follow-float__sentence-num{font:600 10px/1 var(--font-display);color:var(--ws-ink-mid,#8d7f74);letter-spacing:.08em}.follow-float__sentence-score{font:700 14px/1 var(--font-display);letter-spacing:-.02em}.follow-float__sentence-text{font:400 13px/1.55 var(--font-reading);margin:0;color:var(--ws-ink,#2c2520)}.follow-float__sentence-issue{font:500 11px/1.4 var(--font-reading);color:#991b1b;margin:0}.follow-float__speeds{display:flex;gap:2px;margin-left:auto}.follow-float__speeds--sm{margin-left:0}.follow-float__speed{font:600 11px/1 var(--font-display);padding:5px 10px;border-radius:2px;border:1px solid transparent;background:transparent;color:var(--ws-ink-mid,#8d7f74);cursor:pointer;transition:all .12s;min-width:38px;letter-spacing:.02em}.follow-float__speed:hover{color:var(--ws-accent,#b8845c)}.follow-float__speed--active{color:var(--ws-ink,#2c2520);font-weight:700;border-bottom:1.5px solid var(--ws-ink,#2c2520);border-radius:0}.follow-float__context{display:flex;flex-direction:column;gap:4px;padding:6px 0}.follow-float__context-line{font:400 14px/1.5 var(--font-reading);color:#2c25206b;margin:0;padding:0 18px;font-style:italic}.follow-float__context-line--far{font-size:12.5px;color:#2c252040}.follow-float__active .follow-float__top-row{display:flex;align-items:center;gap:14px}.follow-float__top-actions{display:flex;align-items:center;gap:8px;margin-left:auto}.follow-float__bottom-row{display:flex;align-items:center;padding-top:12px;margin-top:4px;border-top:1px solid var(--ws-line-soft,#ebe3d6);gap:12px}.follow-float__bottom-row .follow-float__speeds{margin-left:0}.follow-float__bottom-row .follow-float__btn--exit{margin-left:auto}.reading-page__nav{max-width:72rem;margin:0 auto;padding:1.5rem 1.5rem 0}.article{min-height:100vh;padding:1.5rem 1.5rem 4rem;max-width:42rem;margin:0 auto}.article-nav{margin-bottom:2rem}.back-link{font-size:.95rem;color:var(--muted);text-decoration:none;font-weight:500;transition:color .2s}.back-link:hover{color:var(--accent)}.article-body{padding-top:.5rem}.article-header{margin-bottom:2rem}.article-meta{font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);font-weight:500}.article-title{font-family:var(--font-display);font-size:clamp(1.85rem,4vw,2.25rem);font-weight:600;color:var(--text);line-height:1.25;margin:.4em 0 0;letter-spacing:-.02em}.article-content{font-family:var(--font-reading);font-size:1.125rem;line-height:1.75;color:var(--text)}.article-content p{margin:0 0 1.25em}.article-content p:last-child{margin-bottom:0}.article--missing{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:var(--muted)}.article--missing a{color:var(--accent);text-decoration:none;font-weight:500}.reading-page--loading,.reading-page--error{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;color:var(--muted);text-align:center;max-width:36rem;margin:0 auto}.reading-page--error p{margin:.5rem 0}.reading-back-btn{position:fixed;top:8px;left:8px;z-index:200;padding:4px 12px;border-radius:999px;border:1px solid #d4cfc4;background:#f5f0e8e6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#7a6d5c;font-size:.72rem;font-weight:600;cursor:pointer;transition:all .15s}.reading-back-btn:hover{background:#b8845c;color:#fff;border-color:#b8845c}
