*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0d0d14;--surface:#161620;--surface2:#1e1e2e;--surface3:#252535;--accent:#7c6af7;--accent2:#a89bf5;--accent-glow:rgba(124,106,247,.35);--text:#e8e8f0;--text2:#b0b0c8;--muted:#8888a0;--radius:12px;--card-w:180px;--green:#22c55e;--red:#ef4444}[data-theme="light"]{--bg:#f7f3ee;--surface:#faf8f4;--surface2:#f0ece5;--surface3:#e8e3db;--border:#d9d3c8;--text:#2c2418;--text2:#5a4e3e;--muted:#8a7e6e;--accent:#6c63ff;--accent2:#8b83ff;--btn-text:#fff}[data-theme="light"] header{background:rgba(250,248,244,.88);backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);box-shadow:0 1px 0 rgba(44,36,24,.06),0 4px 16px rgba(44,36,24,.05)}[data-theme="light"] .book-card{box-shadow:none}[data-theme="light"] .cover-wrap{box-shadow:0 2px 12px rgba(44,36,24,.1);border:1px solid rgba(44,36,24,.06);background:var(--surface)}[data-theme="light"] .book-card:hover{box-shadow:0 12px 32px rgba(44,36,24,.1),0 4px 12px rgba(44,36,24,.06)}[data-theme="light"] .mini-player{background:rgba(250,248,244,.94);backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);border-top:1px solid rgba(44,36,24,.08);box-shadow:0 -2px 16px rgba(44,36,24,.06)}:root{--muted:#a0a0b8}[data-theme="light"]{--muted:#595970}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;min-height:100vh;overflow-x:hidden}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button:focus:not(:focus-visible),input:focus:not(:focus-visible),select:focus:not(:focus-visible){outline:none}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(124,106,247,.3);border-radius:3px}.skip-link{position:absolute;top:-100%;left:16px;background:var(--accent);color:#fff;padding:12px 24px;border-radius:0 0 8px 8px;font-size:.9rem;font-weight:600;z-index:10000;text-decoration:none;transition:top .2s}.skip-link:focus{top:0}.fp-header-title{opacity:.7}.fp-times{opacity:.65}.fp-chapter-label{opacity:.7}body,body *{transition-property:background-color,color,border-color,box-shadow;transition-duration:0s}body.theme-transitioning,body.theme-transitioning *{transition-duration:.3s}@media(prefers-color-scheme:light){:root:not([data-theme]){--bg:#f7f3ee;--surface:#faf8f4;--surface2:#f0ece5;--surface3:#e8e3db;--border:#d9d3c8;--text:#2c2418;--text2:#5a4e3e;--muted:#8a7e6e;--accent:#6c63ff;--accent2:#8b83ff;--btn-text:#fff}}header{display:flex;align-items:center;gap:14px;padding:14px 24px;background:rgba(13,13,20,.8);backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);position:sticky;top:0;z-index:100;border-bottom:none;box-shadow:0 1px 0 rgba(255,255,255,.06),0 4px 20px rgba(0,0,0,.25)}.logo{display:flex;align-items:center;gap:10px;cursor:pointer;text-decoration:none;user-select:none}.logo-text{font-family:'Playfair Display',Georgia,'Times New Roman',serif;font-size:1.5rem;font-weight:800;font-style:italic;background:linear-gradient(135deg,#fff 0%,var(--accent2) 50%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:.5px}.logo svg{flex-shrink:0;filter:drop-shadow(0 0 6px var(--accent-glow))}.book-count{font-size:.75rem;color:var(--muted);background:var(--surface2);padding:3px 10px;border-radius:20px;border:1px solid rgba(124,106,247,.15);margin-left:4px;align-self:center;white-space:nowrap}.streak-wrap{display:flex;align-items:center;gap:3px;background:linear-gradient(135deg,rgba(255,160,0,.15),rgba(255,80,0,.1));padding:4px 10px;border-radius:20px;border:1px solid rgba(255,160,0,.25);margin-left:6px;white-space:nowrap;animation:streakPulse 2s ease-in-out infinite}.streak-fire{font-size:.9rem;line-height:1}.streak-count{font-size:.8rem;font-weight:700;color:#ffa040}@keyframes streakPulse{0%,100%{box-shadow:0 0 0 0 rgba(255,160,0,0)}50%{box-shadow:0 0 8px 2px rgba(255,160,0,.2)}}.header-right{margin-left:auto;display:flex;align-items:center;gap:10px}.btn{border:none;border-radius:20px;font-family:inherit;font-size:.85rem;font-weight:600;cursor:pointer;padding:8px 16px;transition:background .15s,transform .1s;display:flex;align-items:center;gap:6px;position:relative;overflow:hidden}.btn::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,0.12);opacity:0;border-radius:inherit;transition:opacity 0.15s}.btn:active::after{opacity:1}.btn:hover:not(:disabled){transform:scale(1.04)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:#6a59e0}.btn-premium{background:linear-gradient(135deg,#f0c040,#f97316);color:#000;font-weight:700;padding:6px 10px;font-size:.8rem;border-radius:8px;border:none;cursor:pointer;transition:opacity .15s}.btn-premium:hover{opacity:.85}.premium-benefits{list-style:none;padding:0;margin:12px 0 0}.premium-benefits li{padding:8px 0;font-size:.9rem;color:var(--text2);border-bottom:1px solid rgba(255,255,255,.05)}.premium-benefits li:last-child{border-bottom:none}.premium-gate{text-align:center;padding:16px;background:var(--surface2);border-radius:10px;margin-top:8px}.premium-gate-title{font-size:.9rem;font-weight:600;color:var(--yellow);margin-bottom:6px}.premium-gate-desc{font-size:.8rem;color:var(--muted);margin-bottom:10px}.btn-ghost{background:var(--surface2);color:var(--text2);border:1px solid rgba(255,255,255,.08)}.btn-ghost:hover:not(:disabled){background:var(--surface3)}.btn-danger{background:rgba(239,68,68,.15);color:var(--red);border:1px solid rgba(239,68,68,.25)}.btn-danger:hover:not(:disabled){background:rgba(239,68,68,.25)}.btn-sm{padding:5px 12px;font-size:.78rem}.btn-xs{padding:3px 9px;font-size:.72rem}.grid-section{padding:28px 32px 60px;max-width:1400px;margin:0 auto}.section-title{font-size:1rem;font-weight:600;color:var(--text2);margin-bottom:20px;letter-spacing:.01em}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(var(--card-w),1fr));gap:22px}.page.active{animation:pageIn .35s ease-out}@keyframes pageIn{from{opacity:0;transform:translateY(8px) scale(0.99)}to{opacity:1;transform:translateY(0) scale(1)}}.btn:hover:not(:disabled),.detail-icon-btn:hover,.filter-trigger:hover,.nav-tab:hover:not(.active){transform:scale(1.03);transition:transform .15s ease,background .15s ease,color .15s ease}header.scrolled{box-shadow:0 1px 0 rgba(255,255,255,.06),0 6px 24px rgba(0,0,0,.35)}[data-theme="light"] header.scrolled{box-shadow:0 1px 0 rgba(0,0,0,.06),0 4px 20px rgba(0,0,0,.1)}body .page{padding-bottom:calc(56px+20px+env(safe-area-inset-bottom,0px))}body.has-miniplayer .page{padding-bottom:calc(72px+56px+20px+env(safe-area-inset-bottom,0px))}.detail-panel::before{content:'';position:absolute;top:0;left:0;right:0;height:120px;background:linear-gradient(180deg,rgba(124,106,247,.08) 0%,transparent 100%);border-radius:28px 28px 0 0;pointer-events:none;z-index:0}.detail-hero{position:relative;z-index:1}[data-theme="light"] .detail-panel::before{background:linear-gradient(180deg,rgba(108,99,255,.06) 0%,transparent 100%)}.book-card{cursor:pointer;display:flex;flex-direction:column;gap:8px;transition:transform 0.4s cubic-bezier(.175,.885,.32,1.275),box-shadow 0.4s cubic-bezier(.175,.885,.32,1.275)}.book-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px rgba(0,0,0,0.35),0 6px 16px rgba(0,0,0,0.2)}.cover-wrap{position:relative;width:100%;aspect-ratio:2/3;border-radius:16px;overflow:hidden;background:var(--surface2);box-shadow:0 4px 24px rgba(0,0,0,.5)}.cover-img{width:100%;height:100%;object-fit:cover;display:block;transition:filter .3s ease,brightness .3s ease}.cover-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:linear-gradient(145deg,var(--surface2),var(--surface3));padding:16px}.cover-placeholder .book-icon{font-size:2.8rem}.cover-placeholder .ph-title{font-size:.75rem;text-align:center;color:var(--text2);font-weight:600;line-height:1.3}.cover-overlay{position:absolute;inset:0;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;border-radius:var(--radius)}.cover-wrap:hover .cover-img{filter:brightness(1.08)}.cover-wrap:hover .cover-overlay{opacity:1}.play-btn{width:52px;height:52px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 6px var(--accent-glow),0 4px 20px rgba(0,0,0,.5);transform:scale(.85);transition:transform .2s,box-shadow .2s}.cover-wrap:hover .play-btn{transform:scale(1);box-shadow:0 0 0 8px var(--accent-glow),0 6px 30px rgba(124,106,247,.5)}.play-btn svg{margin-left:3px}@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}.skeleton-card{display:flex;flex-direction:column;gap:8px}.skeleton-cover{width:100%;aspect-ratio:2/3;border-radius:var(--radius);background:linear-gradient(90deg,var(--surface2) 25%,var(--surface3) 50%,var(--surface2) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.skeleton-title{height:14px;width:80%;border-radius:4px;background:linear-gradient(90deg,var(--surface2) 25%,var(--surface3) 50%,var(--surface2) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;margin:0 auto}.skeleton-meta{height:10px;width:50%;border-radius:4px;background:linear-gradient(90deg,var(--surface2) 25%,var(--surface3) 50%,var(--surface2) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;margin:0 auto}.detail-action-btn{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;color:var(--accent);text-decoration:none;padding:4px 10px;border:1px solid var(--accent);border-radius:8px;opacity:.85;transition:opacity .2s;background:none;cursor:pointer;font-family:inherit}.detail-action-btn:hover{opacity:1}.detail-action-btn.saved{color:#22c55e;border-color:#22c55e}.new-badge{position:absolute;top:6px;right:6px;background:linear-gradient(135deg,#22c55e,#06b6d4);color:#fff;font-size:.6rem;font-weight:700;padding:2px 6px;border-radius:4px;letter-spacing:.5px;z-index:4;box-shadow:0 2px 8px rgba(6,182,212,.4);pointer-events:none;line-height:1.4}.premium-badge{position:absolute;top:6px;left:6px;font-size:.6rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#f0c040,#f97316);padding:2px 6px;border-radius:4px;z-index:4;pointer-events:none;letter-spacing:.3px;box-shadow:0 2px 8px rgba(240,192,64,.5);line-height:1.4}.premium-lock-overlay{position:absolute;inset:0;z-index:2;pointer-events:none;border-radius:var(--radius);background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center}.premium-lock-icon{font-size:2rem;filter:drop-shadow(0 2px 6px rgba(0,0,0,.6))}.cover-img.premium-blurred{filter:blur(2px) brightness(.7)}.card-fav{position:absolute;bottom:8px;right:8px;font-size:.9rem;z-index:3;pointer-events:none;filter:drop-shadow(0 1px 3px rgba(0,0,0,.6));line-height:1}.btn-fav{background:rgba(239,68,68,.1);color:#f87171;border:1px solid rgba(239,68,68,.25)}.btn-fav:hover{background:rgba(239,68,68,.2)}.btn-fav.active{background:rgba(239,68,68,.2);color:#ef4444;border-color:rgba(239,68,68,.4)}.detail-icon-btn{display:inline-flex;align-items:center;gap:6px;background:var(--surface2);color:var(--text2);border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:6px 12px;font-size:.75rem;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s,color .15s,border-color .15s}.detail-icon-btn:hover{background:var(--surface3);color:var(--text)}.detail-icon-btn.active{background:rgba(239,68,68,.15);color:#f87171;border-color:rgba(239,68,68,.3)}.detail-icon-btn.active:hover{background:rgba(239,68,68,.25)}.chapters-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;border-top:1px solid rgba(255,255,255,.06);color:var(--text);font-family:inherit;font-size:.85rem;font-weight:600;padding:12px 0 10px;cursor:pointer;letter-spacing:.02em;text-align:left}.chapters-toggle:hover{color:var(--accent)}.chapters-chevron{transition:transform .2s;flex-shrink:0;opacity:.6}.chapters-list-body{padding-bottom:8px}.card-progress{width:100%;height:3px;background:var(--surface3);border-radius:2px;overflow:hidden}.card-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s}.resume-badge{position:absolute;top:8px;left:8px;background:var(--accent);color:#fff;font-size:.65rem;font-weight:700;padding:2px 6px;border-radius:4px;letter-spacing:.03em;z-index:2}.done-badge{position:absolute;top:8px;left:8px;background:var(--green);color:#fff;font-size:.65rem;font-weight:700;padding:2px 6px;border-radius:4px;z-index:2}.card-title{font-size:.85rem;font-weight:600;color:var(--text);line-height:1.35;letter-spacing:-0.01em;text-align:center;padding:0 4px}.card-meta{font-size:.72rem;color:var(--muted);text-align:center}.book-card.now-playing .cover-wrap{border:2px solid var(--accent);box-shadow:0 0 20px rgba(124,106,247,.4),0 4px 24px rgba(0,0,0,.5)}.now-playing-badge{position:absolute;bottom:6px;left:6px;display:flex;align-items:center;gap:4px;background:rgba(124,106,247,.92);backdrop-filter:blur(6px);color:#fff;font-size:.62rem;font-weight:700;padding:3px 8px;border-radius:12px;z-index:5;letter-spacing:.03em;text-transform:uppercase}.now-playing-bars{display:flex;align-items:flex-end;gap:1.5px;height:10px}.now-playing-bars span{display:block;width:2px;border-radius:1px;background:#fff;animation:npBar 1s ease-in-out infinite}.now-playing-bars span:nth-child(1){animation-delay:0s}.now-playing-bars span:nth-child(2){animation-delay:.15s}.now-playing-bars span:nth-child(3){animation-delay:.3s}@keyframes npBar{0%,100%{height:3px}50%{height:10px}}.book-card.now-playing.now-paused .now-playing-bars span{animation-play-state:paused}.overlay{display:none;position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.75);backdrop-filter:blur(6px);align-items:flex-end;justify-content:center;padding:0}.overlay.open{display:flex}.detail-panel{background:var(--surface);border-radius:28px 28px 0 0;width:100%;max-width:760px;max-height:92vh;overflow-y:auto;display:flex;flex-direction:column;animation:slideUp .3s cubic-bezier(.25,.46,.45,.94);border:1px solid rgba(124,106,247,.15);border-bottom:none;position:relative}@keyframes slideUp{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.detail-hero{display:flex;gap:28px;padding:32px 32px 16px;align-items:flex-start}.detail-cover{width:130px;flex-shrink:0;aspect-ratio:2/3;border-radius:10px;overflow:hidden;background:var(--surface2);box-shadow:0 8px 32px rgba(0,0,0,.6);position:relative}.detail-cover img{width:100%;height:100%;object-fit:cover;display:block}.detail-cover .cover-overlay{border-radius:10px}.detail-cover:hover .cover-overlay{opacity:1}.detail-cover:hover img{filter:brightness(.6)}.detail-info{flex:1;display:flex;flex-direction:column;gap:12px;padding-top:4px}.detail-title{font-size:1.75rem;font-weight:800;line-height:1.2;letter-spacing:-0.03em;color:var(--text)}.detail-meta{font-size:.8rem;color:var(--muted)}.detail-synopsis{padding:20px 32px 8px;font-size:0.94rem;line-height:1.7;color:var(--muted);font-style:italic}.close-btn{position:absolute;top:16px;right:20px;background:var(--surface3);border:none;color:var(--text2);width:34px;height:34px;border-radius:50%;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;z-index:10}.close-btn:hover{background:rgba(124,106,247,.25);color:var(--text)}.detail-player{padding:24px 32px 0}.player-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--accent2);font-weight:600;margin-bottom:8px}audio{display:none}.custom-player{display:flex;align-items:center;gap:10px;background:var(--surface2);border-radius:10px;padding:8px 14px;width:100%}.custom-player .cp-play{background:none;border:none;color:var(--accent);font-size:1.3rem;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .15s,transform .1s;flex-shrink:0;padding:0}.custom-player .cp-play:hover{background:rgba(124,106,247,.15);transform:scale(1.1)}.custom-player .cp-play:active{transform:scale(.95)}.custom-player .cp-track{flex:1;display:flex;flex-direction:column;gap:3px;min-width:0}.custom-player .cp-bar-wrap{width:100%;height:6px;background:var(--surface3);border-radius:3px;cursor:pointer;position:relative;overflow:hidden}.custom-player .cp-bar-wrap:hover{height:8px}.custom-player .cp-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),#a78bfa);border-radius:3px;width:0;transition:width .1s linear}.custom-player .cp-thumb{position:absolute;top:50%;transform:translate(-50%,-50%);width:12px;height:12px;border-radius:50%;background:#fff;border:2px solid var(--accent);box-shadow:0 0 0 2px rgba(124,106,247,.25)}.custom-player .cp-markers{position:absolute;inset:0;pointer-events:none}.custom-player .cp-marker{position:absolute;top:0;width:2px;height:100%;background:rgba(255,255,255,.4);transform:translateX(-1px)}.custom-player .cp-time{font-size:.7rem;color:var(--muted);display:flex;justify-content:space-between;white-space:nowrap}.detail-progress{padding:20px 32px 0}.dp-bar-wrap{background:var(--surface3);border-radius:4px;height:6px;overflow:hidden;margin-bottom:8px}.dp-bar-fill{height:100%;background:var(--accent);border-radius:4px;transition:width .3s}.dp-info{display:flex;justify-content:space-between;font-size:.75rem;color:var(--muted)}.dp-actions{display:flex;gap:8px;margin-top:10px}.detail-chapters{padding:24px 32px 36px}.chapters-heading{font-size:.9rem;font-weight:600;color:var(--text2);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.05)}.chapter-row{display:grid;grid-template-columns:34px 1fr auto;column-gap:10px;padding:9px 10px;border-radius:8px;transition:background .15s;align-items:center;cursor:pointer}.chapter-row:hover{background:var(--surface2)}.chapter-row:hover .ch-play-btn{opacity:1}.ch-play-btn{width:30px;height:30px;border-radius:50%;background:var(--surface3);border:none;color:var(--accent);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .15s,transform .1s,opacity .15s;opacity:.75;padding:0}.ch-play-btn:hover,.ch-play-btn.playing{background:rgba(124,106,247,.2);opacity:1}.ch-play-btn:active{transform:scale(.9)}.ch-play-btn.playing{color:#fff}.chapter-label{font-size:.85rem;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chapter-row audio{display:none}.ch-done{font-size:.72rem;color:var(--green);white-space:nowrap}.card-stars{display:flex;align-items:center;justify-content:center;gap:2px;margin-top:2px}.card-star{font-size:.85rem;line-height:1;color:var(--muted);opacity:.35}.card-star.filled{color:#f0c040;opacity:1}.card-star-count{font-size:.65rem;color:var(--muted);margin-left:3px}.detail-rating{padding:16px 32px 0;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.rating-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--accent2);font-weight:600}.stars-widget{display:flex;gap:4px;align-items:center}.star-btn{background:none;border:none;cursor:pointer;font-size:1.5rem;line-height:1;color:var(--muted);opacity:.35;padding:2px;transition:opacity 0.1s,transform 0.1s ease,color 0.1s;transform-origin:center}.star-btn.filled{color:#f0c040;opacity:1}.star-btn:hover,.star-btn.hover{opacity:1;transform:scale(1.3)}.star-btn:hover~.star-btn{opacity:.35 !important;transform:none !important}.rating-avg{font-size:.8rem;color:var(--text2);margin-left:4px}.rating-clear{background:none;border:none;color:var(--muted);font-size:.72rem;cursor:pointer;text-decoration:underline;padding:0 4px;transition:color .15s}.rating-clear:hover{color:var(--red)}.chapter-row{position:relative}.ch-progress-wrap{position:absolute;bottom:0;left:10px;right:10px;height:2px;background:rgba(255,255,255,.06);border-radius:1px;overflow:hidden}.ch-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),#a78bfa);border-radius:1px;transition:width .3s}.ch-time{font-size:.68rem;color:var(--muted);white-space:nowrap;margin-left:auto}.detail-add-collection{padding:8px 32px}.detail-add-collection select{padding:6px 10px;border-radius:8px;border:1px solid var(--border);background:var(--surface2);color:var(--text);font-size:.82rem;font-family:inherit;cursor:pointer;max-width:200px}.reviews-section{margin:16px 32px 0;padding-top:16px;border-top:1px solid var(--border)}.reviews-title{font-weight:700;font-size:.9rem;margin-bottom:10px}.review-form{margin-bottom:16px}.review-stars{display:flex;gap:4px;margin-bottom:8px}.review-star-btn{background:none;border:none;font-size:1.3rem;cursor:pointer;color:var(--muted);transition:color .1s}.review-star-btn.filled{color:#fbbf24}.review-star-btn:hover{color:#f0c040}.review-textarea{width:100%;padding:8px 12px;border-radius:8px;border:1px solid var(--border);background:var(--surface2);color:var(--text);font-size:.82rem;font-family:inherit;resize:vertical;min-height:60px}.review-item{padding:10px 0;border-bottom:1px solid var(--border)}.review-header{display:flex;align-items:center;gap:8px}.review-user{font-weight:600;font-size:.82rem}.review-rating{color:#fbbf24;font-size:.82rem}.review-date{font-size:.68rem;color:var(--muted);margin-left:auto}.review-text{font-size:.82rem;color:var(--text2);margin-top:4px}.sync-indicator{display:inline-flex;align-items:center;gap:4px;font-size:.68rem;color:var(--muted);padding:2px 8px}.sync-dot{width:6px;height:6px;border-radius:50%;background:#22c55e}.mini-player{position:fixed;bottom:0;left:0;right:0;height:72px;background:rgba(18,15,35,.97);backdrop-filter:blur(16px);border-top:1px solid rgba(124,106,247,.25);display:flex;align-items:center;gap:12px;padding:0 16px;z-index:900;box-shadow:0 -4px 24px rgba(0,0,0,.5);transform:translateY(100%);transition:transform .3s ease}.mini-player.visible{transform:translateY(0)}.mp-cover{width:48px;height:48px;border-radius:8px;object-fit:cover;cursor:pointer;flex-shrink:0;background:var(--surface2)}.mp-info{flex:1;min-width:0;cursor:pointer}.mp-title{font-size:.82rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mp-chapter{font-size:.72rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.mp-controls{display:flex;align-items:center;gap:4px;flex-shrink:0}.mp-btn{background:none;border:none;color:var(--text2);font-size:1rem;cursor:pointer;padding:6px;border-radius:6px;transition:color .15s,background .15s,transform 0.1s ease;line-height:1}.mp-btn:hover{color:var(--text);background:rgba(255,255,255,.08)}.mp-btn:active{transform:scale(0.88)}.mp-btn.mp-play{font-size:1.2rem;color:var(--accent)}.mp-btn.mp-speed{font-size:.7rem;font-weight:700;color:var(--accent2);min-width:32px;text-align:center}.mp-progress-wrap{position:absolute;bottom:0;left:0;right:0;height:4px;background:rgba(255,255,255,.1);cursor:pointer}.mp-progress-fill{height:100%;background:var(--accent);border-radius:0;transition:width .5s linear;pointer-events:none}.mp-time{font-size:.7rem;color:var(--muted);flex-shrink:0;min-width:70px;text-align:right}.mp-close{background:none;border:none;color:var(--muted);font-size:.9rem;cursor:pointer;padding:6px;margin-left:4px;flex-shrink:0;transition:color .15s}.mp-close:hover{color:var(--text)}body.has-miniplayer .page{padding-bottom:80px}body.has-miniplayer #detail-panel{padding-bottom:80px}.sleep-timer-wrap{position:relative;flex-shrink:0}.sleep-timer-btn{background:none;border:none;color:var(--muted);font-size:.75rem;cursor:pointer;padding:5px 8px;border-radius:6px;transition:color .15s,background .15s;white-space:nowrap;font-family:inherit;line-height:1.2;display:flex;align-items:center;gap:3px}.sleep-timer-btn:hover{color:var(--text);background:rgba(255,255,255,.08)}.sleep-timer-btn.active{color:#a89bf5;background:rgba(124,106,247,.15)}.sleep-timer-dd{position:absolute;bottom:calc(100%+8px);right:0;background:var(--surface2);border:1px solid rgba(124,106,247,.2);border-radius:12px;padding:6px;min-width:150px;box-shadow:0 8px 32px rgba(0,0,0,.5);z-index:999;display:none}.sleep-timer-dd.open{display:block;animation:fadeZoom .18s ease}.sleep-timer-opt{display:block;width:100%;background:none;border:none;color:var(--text2);font-family:inherit;font-size:.85rem;cursor:pointer;padding:8px 12px;border-radius:8px;text-align:left;transition:background .12s;white-space:nowrap}.sleep-timer-opt:hover{background:var(--surface3);color:var(--text)}.sleep-timer-opt.cancel-opt{color:var(--red)}.sleep-timer-opt.cancel-opt:hover{background:rgba(239,68,68,.12)}.fp-sleep-wrap{position:relative}.fp-sleep-btn.active{color:#a89bf5!important;background:rgba(124,106,247,.15)!important}.fp-sleep-dd{position:absolute;bottom:calc(100%+10px);left:50%;transform:translateX(-50%);background:var(--surface2);border:1px solid rgba(124,106,247,.2);border-radius:12px;padding:6px;min-width:150px;box-shadow:0 8px 32px rgba(0,0,0,.5);z-index:1000;display:none}.fp-sleep-dd.open{display:block;animation:fadeZoom .18s ease}.mini-player{background:rgba(13,11,26,.92);backdrop-filter:blur(24px) saturate(1.6);border-top:1px solid rgba(124,106,247,.2);box-shadow:0 -6px 32px rgba(0,0,0,.6),0 -2px 8px rgba(124,106,247,.1)}.mp-title{font-size:.82rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:linear-gradient(90deg,var(--text),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.mp-chapter{font-size:.68rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mp-btn.mp-play{color:var(--accent);text-shadow:0 0 12px rgba(124,106,247,.4)}.mp-progress-fill{background:linear-gradient(90deg,var(--accent),#a78bfa)}.mp-wave{display:flex;align-items:center;gap:1px;height:16px;margin-left:4px;flex-shrink:0}.mp-wave span{width:2px;border-radius:1px;background:var(--accent);animation:mpWave 1s ease-in-out infinite;opacity:.6}.mp-wave span:nth-child(1){animation-delay:0s}.mp-wave span:nth-child(2){animation-delay:.12s}.mp-wave span:nth-child(3){animation-delay:.24s}@keyframes mpWave{0%,100%{height:3px}50%{height:12px}}.mp-wave.paused span{animation-play-state:paused}.continue-card{display:flex;align-items:center;gap:16px;background:linear-gradient(135deg,rgba(124,106,247,.15),rgba(168,155,245,.08));border:1.5px solid rgba(124,106,247,.3);border-radius:16px;padding:16px 20px;cursor:pointer;transition:border-color .2s,transform .15s;margin-bottom:4px}.continue-card:hover{border-color:rgba(124,106,247,.6);transform:translateY(-1px)}.continue-cover{width:56px;height:84px;border-radius:8px;object-fit:cover;flex-shrink:0;background:var(--surface2)}.continue-body{flex:1;min-width:0}.continue-eyebrow{font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:var(--accent2);font-weight:700;margin-bottom:4px}.continue-title{font-size:1rem;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.continue-sub{font-size:.78rem;color:var(--muted);margin-top:3px}.continue-bar-wrap{background:rgba(255,255,255,.1);border-radius:3px;height:4px;margin-top:8px;overflow:hidden;max-width:200px}.continue-bar-fill{height:100%;background:var(--accent);border-radius:3px}.continue-play-btn{width:48px;height:48px;border-radius:50%;background:var(--accent);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:white;flex-shrink:0;transition:transform .15s,opacity .15s;box-shadow:0 4px 16px rgba(124,106,247,.4)}.continue-play-btn:hover{transform:scale(1.08);opacity:.9}.full-player{position:fixed;inset:0;z-index:1000;display:flex;flex-direction:column;overflow:hidden;color:#fff;background:#0d0b1a}.fp-inner{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.fp-bg{display:none}.fp-header{display:flex;align-items:center;justify-content:space-between;padding:max(16px,env(safe-area-inset-top)) 20px 8px;flex-shrink:0}.fp-chevron,.fp-menu-btn{background:rgba(255,255,255,.08);border:none;color:#fff;cursor:pointer;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:.85;transition:background .15s}.fp-chevron:hover,.fp-menu-btn:hover{background:rgba(255,255,255,.15);opacity:1}.fp-header-title{font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;opacity:.5}.fp-audio-view{display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}.fp-cover-wrap{display:flex;align-items:center;justify-content:center;padding:12px 32px;flex-shrink:0}.fp-cover{width:min(72vw,240px);aspect-ratio:1;border-radius:14px;object-fit:cover;box-shadow:0 20px 60px rgba(0,0,0,.7),0 0 80px rgba(124,106,247,.25);background:var(--surface2);transition:transform .6s cubic-bezier(.34,1.56,.64,1),box-shadow .6s ease}.fp-cover.playing{transform:scale(1.05);box-shadow:0 20px 60px rgba(0,0,0,.7),0 0 120px rgba(124,106,247,.4),0 0 40px rgba(167,139,250,.3)}.fp-cover-glow{position:absolute;inset:-20%;width:140%;height:140%;border-radius:50%;background:radial-gradient(circle,rgba(124,106,247,.3) 0%,transparent 70%);filter:blur(40px);opacity:0;transition:opacity .8s ease;pointer-events:none;z-index:-1}.fp-cover.playing~.fp-cover-glow,.fp-cover-wrap:hover .fp-cover-glow{opacity:1}.fp-meta{display:flex;align-items:center;gap:12px;padding:8px 24px;flex-shrink:0}.fp-meta-left{flex:1;min-width:0}.fp-book-title{font-size:1.1rem;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em}.fp-chapter-label{font-size:.8rem;opacity:.55;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fp-mode-btn{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);color:#fff;cursor:pointer;padding:7px 14px;border-radius:20px;font-size:.72rem;font-weight:600;letter-spacing:.04em;flex-shrink:0;transition:background .15s;white-space:nowrap}.fp-mode-btn:hover{background:rgba(255,255,255,.18)}.fp-mode-btn.text-mode{background:var(--accent);border-color:var(--accent)}.fp-seek-wrap{padding:6px 24px 0;flex-shrink:0}.fp-seek{-webkit-appearance:none;appearance:none;width:100%;height:4px;border-radius:2px;background:rgba(255,255,255,.18);outline:none;cursor:pointer}.fp-seek::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#fff;cursor:pointer;box-shadow:0 2px 6px rgba(0,0,0,.4);transition:transform .15s}.fp-seek:active::-webkit-slider-thumb{transform:scale(1.4)}.fp-seek::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:#fff;cursor:pointer;border:none}.fp-times{display:flex;justify-content:space-between;font-size:.7rem;opacity:.45;padding:4px 0 0}.fp-controls{display:flex;align-items:center;justify-content:space-between;padding:10px 28px;flex-shrink:0}.fp-ctrl{background:none;border:none;color:#fff;cursor:pointer;padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:opacity .15s,transform .1s}.fp-ctrl:active{transform:scale(.88)}.fp-ctrl-sm{font-size:.78rem;font-weight:700;opacity:.65;min-width:38px}.fp-ctrl-sm:hover{opacity:1}.fp-ctrl-play{width:60px;height:60px;background:#fff;color:#000;border-radius:50%;box-shadow:0 4px 20px rgba(0,0,0,.4);flex-shrink:0}.fp-ctrl-play:hover{transform:scale(1.06)}.fp-ctrl-prev,.fp-ctrl-next{opacity:.85;width:44px;height:44px}.fp-ctrl-prev:hover,.fp-ctrl-next:hover{opacity:1}.fp-waveform{display:flex;align-items:center;justify-content:center;gap:3px;height:20px;flex-shrink:0}.fp-waveform span{width:3px;border-radius:2px;background:var(--accent);animation:waveBar 1.2s infinite}.fp-waveform.paused span{animation-play-state:paused}@keyframes waveBar{0%,100%{height:4px}50%{height:16px}}.fp-waveform span:nth-child(1){animation-delay:0s;animation-duration:1.1s}.fp-waveform span:nth-child(2){animation-delay:0.15s;animation-duration:0.9s}.fp-waveform span:nth-child(3){animation-delay:0.3s;animation-duration:1.3s}.fp-waveform span:nth-child(4){animation-delay:0.1s;animation-duration:1.0s}.fp-waveform span:nth-child(5){animation-delay:0.25s;animation-duration:0.85s}.fp-chapter-list{flex:1;overflow-y:auto;border-top:1px solid rgba(255,255,255,.07);margin:0;scrollbar-width:none;min-height:0;mask-image:linear-gradient(to bottom,transparent 0px,rgba(0,0,0,.6) 28px,black 56px);-webkit-mask-image:linear-gradient(to bottom,transparent 0px,rgba(0,0,0,.6) 28px,black 56px)}.fp-chapter-list::-webkit-scrollbar{display:none}.fp-ch-item{display:flex;align-items:center;gap:12px;padding:11px 20px;cursor:pointer;transition:background .15s;font-size:.85rem;opacity:.55;border-left:3px solid transparent}.fp-ch-item:hover{background:rgba(255,255,255,.07);opacity:.85}.fp-ch-item.active{opacity:1;font-weight:700;color:var(--accent2);background:rgba(124,106,247,.12);border-left-color:var(--accent)}.fp-ch-num{font-size:.68rem;min-width:20px;opacity:.4}.fp-ch-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fp-ch-done{font-size:.72rem;color:var(--green);opacity:.7}.fp-ch-playing-icon{font-size:.72rem;color:var(--accent)}.fp-text-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.fp-text-toolbar{display:flex;align-items:center;justify-content:space-between;padding:8px 20px;border-bottom:1px solid rgba(255,255,255,.07);flex-shrink:0;gap:12px}.fp-text-back-btn{display:flex;align-items:center;gap:6px;background:rgba(124,106,247,.18);border:1px solid rgba(124,106,247,.35);color:#c8bcff;border-radius:20px;padding:5px 14px;font-size:.8rem;font-weight:600;cursor:pointer;white-space:nowrap;font-family:inherit;transition:background .15s}.fp-text-back-btn:hover{background:rgba(124,106,247,.3)}.fp-text-close-btn{background:rgba(255,255,255,.07);border:none;color:rgba(255,255,255,.6);border-radius:50%;width:30px;height:30px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.fp-text-close-btn:hover{background:rgba(255,255,255,.15);color:#fff}.fp-text-scroll{flex:1;overflow-y:auto;padding:20px 24px;min-height:0;scrollbar-width:thin;scrollbar-color:rgba(124,106,247,.4) transparent}.fp-text-scroll::-webkit-scrollbar{width:5px}.fp-text-scroll::-webkit-scrollbar-track{background:transparent}.fp-text-scroll::-webkit-scrollbar-thumb{background:rgba(124,106,247,.4);border-radius:3px}.fp-text-content{font-size:1.05rem;line-height:1.85;color:rgba(255,255,255,.88);padding-bottom:40px;max-width:640px;margin:0 auto}.fp-text-para{margin:0 0 1.2em;transition:color .4s,opacity .4s,transform .4s;opacity:.35;cursor:pointer;border-radius:6px;padding:4px 8px;margin-left:-8px;margin-right:-8px}.fp-text-para:hover{opacity:.6;background:rgba(124,106,247,.06)}.fp-text-para.fp-text-active{opacity:1;color:#fff;font-weight:500;transform:scale(1.01)}.fp-text-para .fp-sentence{transition:color .3s,background .3s,opacity .3s;border-radius:3px;padding:1px 0}.fp-text-para .fp-sentence.fp-sentence-active{color:#fff;background:rgba(124,106,247,.2);box-shadow:0 0 12px rgba(124,106,247,.15)}.fp-text-para .fp-sentence.fp-sentence-past{opacity:.7;color:rgba(255,255,255,.75)}.fp-text-para .fp-sentence.fp-sentence-future{opacity:.4}.fp-text-loading{opacity:.4;text-align:center;padding:40px 0}.fp-text-unavailable{opacity:.4;text-align:center;padding:40px 0;font-style:italic}.fp-text-font-controls{display:flex;align-items:center;gap:6px;flex-shrink:0}.fp-text-font-btn{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);color:#fff;width:28px;height:28px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;transition:background .15s;font-family:inherit}.fp-text-font-btn:hover{background:rgba(255,255,255,.2)}.fp-text-font-size{font-size:.68rem;opacity:.5;min-width:28px;text-align:center}.fp-text-progress{height:2px;background:rgba(255,255,255,.08);flex-shrink:0}.fp-text-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),#a78bfa);border-radius:1px;transition:width .5s linear;width:0}.fp-dl-downloaded .fp-dl-icon-el{stroke:#22c55e}.fp-times{display:flex;justify-content:space-between;font-size:.72rem;opacity:.55;margin-top:6px}.fp-controls{display:flex;align-items:center;justify-content:space-between;padding:12px 0;flex-shrink:0}.fp-ctrl{background:none;border:none;color:#fff;cursor:pointer;padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:opacity .15s,transform .1s}.fp-ctrl:active{transform:scale(.88)}.fp-ctrl-sm{font-size:.78rem;font-weight:700;opacity:.7;min-width:40px}.fp-ctrl-sm:hover{opacity:1}.fp-ctrl-play{width:64px;height:64px;background:#fff;color:#000;border-radius:50%;box-shadow:0 4px 20px rgba(0,0,0,.4);flex-shrink:0}.fp-ctrl-play:hover{transform:scale(1.05)}.fp-ctrl-prev,.fp-ctrl-next{opacity:.9;width:48px;height:48px}.fp-ctrl-prev:hover,.fp-ctrl-next:hover{opacity:1}.fp-chapter-list{flex:1;flex-shrink:1;max-height:none;min-height:0;overflow-y:auto;border-top:1px solid rgba(255,255,255,.1);padding-top:0;scrollbar-width:none;mask-image:linear-gradient(to bottom,transparent 0px,rgba(0,0,0,.6) 28px,black 56px);-webkit-mask-image:linear-gradient(to bottom,transparent 0px,rgba(0,0,0,.6) 28px,black 56px)}.fp-chapter-list::-webkit-scrollbar{display:none}.fp-ch-item{display:flex;align-items:center;gap:10px;padding:6px 4px;border-radius:6px;cursor:pointer;transition:background 0.15s,border-color 0.15s;font-size:.82rem;opacity:.6;border-left:3px solid transparent}.fp-ch-item:hover{background:rgba(255,255,255,.08);opacity:1}.fp-ch-item.active{opacity:1;color:#fff;font-weight:600;background:rgba(124,106,247,0.15);border-left:3px solid var(--accent);padding-left:1px}.fp-ch-num{font-size:.7rem;min-width:24px;opacity:.5}.fp-ch-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fp-ch-done{font-size:.75rem;opacity:.4}.fp-text-panel{border-top:1px solid rgba(255,255,255,.1)}.fp-text-scroll{padding:12px 16px}.fp-text-content{font-size:1rem;line-height:1.75;padding-bottom:24px}.fp-dl-downloaded #fp-dl-icon{stroke:#22c55e}@keyframes fpSlideUp{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes fpSlideDown{from{transform:translateY(0);opacity:1}to{transform:translateY(100%);opacity:0}}.full-player.entering{animation:fpSlideUp .3s cubic-bezier(.32,.72,0,1) forwards}.full-player.leaving{animation:fpSlideDown .25s ease-in forwards}.fp-waveform{display:flex;align-items:center;justify-content:center;gap:3px;height:24px;opacity:0.5;margin-bottom:4px}.fp-waveform span{display:block;width:3px;border-radius:3px;background:var(--accent);animation:waveBar 1.2s ease-in-out infinite;height:8px}.fp-waveform span:nth-child(1){animation-delay:0s;animation-duration:1.1s}.fp-waveform span:nth-child(2){animation-delay:0.15s;animation-duration:0.9s}.fp-waveform span:nth-child(3){animation-delay:0.3s;animation-duration:1.3s}.fp-waveform span:nth-child(4){animation-delay:0.1s;animation-duration:1.0s}.fp-waveform span:nth-child(5){animation-delay:0.25s;animation-duration:0.85s}@keyframes waveBar{0%,100%{height:4px}50%{height:20px}}.fp-waveform.paused span{animation-play-state:paused}.fp-bg{position:relative}.fp-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(160deg,rgba(124,106,247,0.25) 0%,transparent 40%,rgba(0,0,0,0.6) 100%);animation:fpGradientPulse 4s ease-in-out infinite alternate;pointer-events:none}@keyframes fpGradientPulse{from{opacity:0.7}to{opacity:1}}@keyframes heartPop{0%{transform:scale(1)}40%{transform:scale(1.4)}70%{transform:scale(0.9)}100%{transform:scale(1)}}.card-fav.popping{animation:heartPop 0.35s ease}.full-player{background:linear-gradient(180deg,#120f23 0%,#0d0b1a 40%,#080612 100%)}.fp-bg{display:block;position:absolute;inset:0;z-index:-1;opacity:.4;transition:opacity 1s ease}.fp-bg-canvas{width:100%;height:100%;filter:blur(80px) saturate(1.8);opacity:.5}.fp-cover-wrap{position:relative}.fp-seek{background:rgba(255,255,255,.12)}.fp-seek::-webkit-slider-runnable-track{background:linear-gradient(90deg,var(--accent) 0%,#a78bfa 100%);border-radius:2px;height:4px}.fp-chapters-section{flex-shrink:0;border-top:1px solid rgba(255,255,255,.08)}.fp-chapters-toggle{display:flex;align-items:center;gap:10px;width:100%;background:none;border:none;color:rgba(255,255,255,.7);cursor:pointer;padding:12px 20px;font-size:.82rem;font-weight:600;font-family:inherit;transition:background .15s,color .15s}.fp-chapters-toggle:hover{background:rgba(255,255,255,.06);color:#fff}.fp-chapters-chevron{margin-left:auto;transition:transform .25s ease}.fp-chapters-section.open .fp-chapters-chevron{transform:rotate(180deg)}.fp-chapters-section.open .fp-chapter-list{display:block !important}.fp-chapters-section .fp-chapter-list{max-height:45vh;overflow-y:auto;padding-bottom:12px;animation:fpChListIn .25s ease}@keyframes fpChListIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.fp-extras{display:flex;justify-content:center;gap:16px;padding:4px 0 8px;opacity:.7}.fp-extra-btn{background:none;border:none;color:rgba(255,255,255,.7);cursor:pointer;font-size:.72rem;display:flex;align-items:center;gap:4px;padding:6px 10px;border-radius:8px;transition:background .15s,color .15s;font-family:inherit}.fp-extra-btn:hover{background:rgba(255,255,255,.1);color:#fff}.fp-bookmarks-panel,.fp-notes-panel{position:absolute;bottom:0;left:0;right:0;background:rgba(20,20,30,.97);border-top:1px solid rgba(255,255,255,.1);border-radius:16px 16px 0 0;max-height:50vh;z-index:10;animation:fpPanelIn .2s ease}@keyframes fpPanelIn{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.fp-panel-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.08);font-weight:700;font-size:.9rem;color:#fff}.fp-panel-close{background:none;border:none;color:rgba(255,255,255,.6);cursor:pointer;font-size:1.1rem;padding:4px}.fp-panel-body{max-height:35vh;overflow-y:auto;padding:8px 0}.fp-bk-item,.fp-note-item{padding:10px 16px;display:flex;align-items:flex-start;gap:10px;border-bottom:1px solid rgba(255,255,255,.05);cursor:pointer;transition:background .15s}.fp-bk-item:hover,.fp-note-item:hover{background:rgba(255,255,255,.05)}.fp-bk-time,.fp-note-time{font-size:.72rem;color:var(--accent);font-weight:600;min-width:50px;flex-shrink:0}.fp-bk-text,.fp-note-text{font-size:.8rem;color:rgba(255,255,255,.8);flex:1}.fp-bk-del,.fp-note-del{background:none;border:none;color:rgba(255,255,255,.3);cursor:pointer;font-size:.85rem;padding:2px 4px}.fp-bk-del:hover,.fp-note-del:hover{color:#ef4444}.fp-notes-input-wrap{display:flex;gap:8px;padding:10px 16px;align-items:flex-end;border-bottom:1px solid rgba(255,255,255,.08)}.fp-note-input{flex:1;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:8px;color:#fff;padding:8px 10px;font-size:.82rem;font-family:inherit;resize:none}.fp-note-input::placeholder{color:rgba(255,255,255,.35)}.fp-panel-empty{text-align:center;padding:24px;color:rgba(255,255,255,.4);font-size:.82rem}.modal-backdrop{display:none;position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.78);backdrop-filter:blur(6px);align-items:center;justify-content:center;padding:24px}.modal-backdrop.open{display:flex}.modal{background:var(--surface);border:1px solid rgba(124,106,247,.25);border-radius:20px;padding:24px;width:100%;max-width:420px;max-height:85vh;overflow-y:auto;animation:fadeZoom .22s ease;display:none;z-index:500;flex-direction:column;align-items:stretch}.modal-backdrop.open .modal{display:flex!important}#reportModal{background:rgba(0,0,0,.78);padding:0;max-width:none;display:none!important;position:fixed;inset:0;z-index:300;align-items:center;justify-content:center}#reportModal.open{display:flex!important}#reportModal .modal-content{background:var(--surface);border:1px solid rgba(124,106,247,.25);border-radius:20px;padding:32px;width:100%;max-width:420px;animation:fadeZoom .22s ease;position:relative;z-index:301}.report-textarea{width:100%;background:var(--surface2);border:1px solid rgba(124,106,247,.2);border-radius:10px;color:var(--text);font-size:.95rem;padding:11px 14px;outline:none;resize:vertical;min-height:100px;font-family:inherit;margin:12px 0}.report-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.report-textarea::placeholder{color:var(--muted)}.modal-actions{display:flex;gap:10px;margin-top:24px}@keyframes fadeZoom{from{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}.modal-title{font-size:1.2rem;font-weight:700;margin-bottom:6px}.modal-sub{font-size:.82rem;color:var(--muted);margin-bottom:24px;line-height:1.5}.form-group{margin-bottom:16px}.form-label{display:block;font-size:.8rem;font-weight:600;color:var(--text2);margin-bottom:7px;text-transform:uppercase;letter-spacing:.05em}.form-label .optional{font-weight:400;color:var(--muted);text-transform:none;letter-spacing:0;font-size:.75rem}.form-input{width:100%;background:var(--surface2);border:1px solid rgba(124,106,247,.2);border-radius:10px;color:var(--text);font-size:.95rem;padding:11px 14px;outline:none;transition:border-color .15s,box-shadow .15s;font-family:inherit}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.form-input::placeholder{color:var(--muted)}.form-error{font-size:.78rem;color:var(--red);margin-top:6px;display:none}.form-error.show{display:block}.form-actions{display:flex;gap:10px;margin-top:24px}.link-btn{background:none;border:none;color:var(--accent2);font-family:inherit;font-size:.85rem;cursor:pointer;text-decoration:underline;padding:0}.link-btn:hover{color:var(--accent)}.auth-switch{text-align:center;margin-top:18px;font-size:.82rem;color:var(--muted)}.btn-google{background:#fff;color:#3c4043;border:1px solid #dadce0;border-radius:20px;font-family:inherit;font-size:.88rem;font-weight:600;cursor:pointer;padding:10px 16px;display:flex;align-items:center;justify-content:center;gap:10px;width:100%;transition:background .15s,box-shadow .15s}.btn-google:hover{background:#f8f9fa;box-shadow:0 1px 6px rgba(0,0,0,.18)}.btn-google svg{flex-shrink:0}.or-divider{display:flex;align-items:center;gap:10px;margin:18px 0;color:var(--muted);font-size:.8rem}.or-divider::before,.or-divider::after{content:'';flex:1;height:1px;background:rgba(255,255,255,.08)}.auth-gate{display:flex;flex-direction:column;align-items:center;gap:12px;padding:28px 20px;background:var(--surface2);border-radius:12px;border:1px dashed rgba(124,106,247,.3)}.auth-gate-icon{font-size:2rem}.auth-gate-text{font-size:.9rem;color:var(--text2);font-weight:500}.nav-tabs{display:none}.nav-tab{background:none;border:none;color:var(--muted);font-family:inherit;font-size:.88rem;font-weight:600;cursor:pointer;padding:8px 16px;border-radius:20px;transition:background .15s,color .15s}.nav-tab.active{background:var(--surface2);color:var(--text)}.nav-tab:hover:not(.active){color:var(--text2)}.menu-btn{background:var(--surface2);border:1px solid rgba(255,255,255,.08);border-radius:10px;width:38px;height:38px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;cursor:pointer;flex-shrink:0;transition:background .15s}.menu-btn:hover{background:var(--surface3)}.menu-btn span{display:block;width:18px;height:2px;background:var(--text2);border-radius:2px;transition:transform .2s,opacity .2s}.menu-btn.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.menu-btn.open span:nth-child(2){opacity:0}.menu-btn.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.dropdown-menu{display:none;position:absolute;top:calc(100%+10px);right:16px;background:var(--surface2);border:1px solid rgba(124,106,247,.2);border-radius:14px;padding:8px;min-width:180px;z-index:200;box-shadow:0 12px 40px rgba(0,0,0,.5);animation:fadeZoom .18s ease}.dropdown-menu.open{display:block}.dropdown-item{display:flex;align-items:center;gap:10px;width:100%;background:none;border:none;color:var(--text2);font-family:inherit;font-size:.88rem;font-weight:500;cursor:pointer;padding:10px 12px;border-radius:8px;text-align:left;transition:background .12s,color .12s}.dropdown-item:hover{background:var(--surface3);color:var(--text)}.dropdown-item.accent{color:var(--accent2)}.dropdown-divider{height:1px;background:rgba(255,255,255,.06);margin:4px 0}.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:800;display:flex;align-items:center;justify-content:space-around;height:56px;padding-bottom:env(safe-area-inset-bottom,0px);background:rgba(13,13,20,.72);backdrop-filter:blur(24px) saturate(1.6);-webkit-backdrop-filter:blur(24px) saturate(1.6);border-top:1px solid rgba(255,255,255,.08);box-shadow:0 -4px 20px rgba(0,0,0,.3);transition:transform .3s cubic-bezier(.25,.46,.45,.94),opacity .3s ease}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;background:none;border:none;color:var(--muted);font-family:inherit;font-size:.62rem;font-weight:500;cursor:pointer;padding:6px 16px;border-radius:12px;transition:color .2s ease,transform .15s ease;position:relative;-webkit-tap-highlight-color:transparent}.bottom-nav-item svg,.bottom-nav-item .nav-icon{font-size:1.25rem;width:24px;height:24px;transition:transform .25s cubic-bezier(.175,.885,.32,1.275)}.bottom-nav-item.active{color:var(--accent)}.bottom-nav-item.active svg,.bottom-nav-item.active .nav-icon{transform:scale(1.1)}.bottom-nav-item:active{transform:scale(0.92)}.bottom-nav-item span{line-height:1}body.has-miniplayer .bottom-nav{transform:translateY(-72px)}body.full-player-open .bottom-nav{transform:translateY(100%);opacity:0;pointer-events:none}[data-theme="light"] .bottom-nav{background:rgba(250,248,244,.82);border-top:1px solid rgba(44,36,24,.06);box-shadow:0 -2px 16px rgba(44,36,24,.05)}.bnav-add-circle{width:44px;height:44px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(124,106,247,.45);transition:transform .2s cubic-bezier(.175,.885,.32,1.275),box-shadow .2s ease}.bnav-add:active .bnav-add-circle{transform:scale(.88)}.bnav-add .bnav-add-circle svg{stroke:#fff}[data-theme="light"] .bnav-add-circle{box-shadow:0 4px 16px rgba(108,99,255,.3)}.search-bar-wrap{max-width:1400px;margin:0 auto;padding:16px 32px 0;display:none}.search-bar-wrap.visible{display:block}.search-bar{display:flex;align-items:center;gap:10px;background:var(--surface2);border:1.5px solid rgba(124,106,247,.18);border-radius:14px;padding:0 14px;transition:border-color .2s,box-shadow .2s}.search-bar:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px rgba(124,106,247,.18)}.search-icon{color:var(--muted);flex-shrink:0;transition:color .2s}.search-bar:focus-within .search-icon{color:var(--accent2)}.search-input{flex:1;background:none;border:none;outline:none;color:var(--text);font-size:.95rem;font-family:inherit;padding:12px 0}.search-input::placeholder{color:var(--muted)}.search-clear{background:none;border:none;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:4px;border-radius:50%;transition:background .15s,color .15s}.search-clear:hover{background:rgba(255,255,255,.07);color:var(--text)}.search-results-info{font-size:.78rem;color:var(--muted);margin-top:8px;min-height:18px;padding:0 2px}.search-results-info .match-count{color:var(--accent2);font-weight:600}.book-card.search-hidden{display:none}.filter-bar-wrap{max-width:1400px;margin:0 auto;padding:10px 32px 0;display:none}.filter-bar-wrap.visible{display:block}.filter-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.filter-dropdown{position:relative}.filter-trigger{display:flex;align-items:center;gap:6px;background:var(--surface2);border:1px solid rgba(255,255,255,.06);border-radius:8px;color:var(--text2);font-family:inherit;font-size:.8rem;font-weight:500;cursor:pointer;padding:7px 12px;transition:all .15s;white-space:nowrap}.filter-trigger:hover{background:var(--surface3);color:var(--text);border-color:rgba(255,255,255,.12)}.filter-trigger.has-value{border-color:var(--accent);color:var(--accent2);background:rgba(124,106,247,.08)}.filter-dd-menu{display:none;position:absolute;top:calc(100%+4px);left:0;min-width:140px;background:var(--surface2);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:4px;z-index:100;box-shadow:0 8px 24px rgba(0,0,0,.4);backdrop-filter:blur(12px)}.filter-dropdown.open .filter-dd-menu{display:block}.filter-dd-item{display:block;width:100%;text-align:left;background:none;border:none;color:var(--text2);font-family:inherit;font-size:.8rem;padding:8px 12px;border-radius:6px;cursor:pointer;transition:background .12s,color .12s}.filter-dd-item:hover{background:var(--surface3);color:var(--text)}.filter-dd-item.active{color:var(--accent2);font-weight:600}.filter-dd-cats{max-height:260px;overflow-y:auto;min-width:160px}.filter-count{font-size:.75rem;color:var(--muted);margin-left:auto;white-space:nowrap}.filter-count .match-count{font-weight:700;color:var(--accent2)}@media(max-width:600px){.filter-bar-wrap{padding:8px 16px 0}.filter-trigger{font-size:.75rem;padding:6px 10px}}.recently-played{padding:0 0 16px;margin-bottom:8px}.recently-played-title{font-size:.82rem;font-weight:600;color:var(--text2);margin-bottom:12px;padding:0 32px;letter-spacing:.01em}.recently-played-scroll{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:0 32px 8px;scrollbar-width:none}.recently-played-scroll::-webkit-scrollbar{display:none}.recently-played-card{flex-shrink:0;width:100px;scroll-snap-align:start;cursor:pointer;transition:transform .25s cubic-bezier(.175,.885,.32,1.275)}.recently-played-card:hover{transform:translateY(-3px)}.recently-played-card .rp-cover{width:100px;height:100px;border-radius:12px;object-fit:cover;display:block;background:var(--surface2);box-shadow:0 2px 10px rgba(0,0,0,.25)}.recently-played-card .rp-title{font-size:.7rem;font-weight:600;color:var(--text);margin-top:6px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-align:center}@media(max-width:600px){.recently-played-scroll{padding:0 16px 8px}.recently-played-title{padding:0 16px}}.recently-played-section{padding:0 0 8px;margin-bottom:8px}.recently-played-section .recently-played-title{font-size:.82rem;font-weight:600;color:var(--text2);margin-bottom:10px;padding:0 32px;letter-spacing:.01em}.recently-played-section .recently-played-scroll{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:0 32px 8px;scrollbar-width:none}.recently-played-section .recently-played-scroll::-webkit-scrollbar{display:none}.recently-played-card{flex-shrink:0;width:90px;scroll-snap-align:start;cursor:pointer;transition:transform .2s ease}.recently-played-card:active{transform:scale(.96)}.recently-played-cover{width:90px;height:135px;border-radius:10px;object-fit:cover;display:block;background:var(--surface2);box-shadow:0 2px 8px rgba(0,0,0,.2)}.recently-played-info{padding:4px 2px 0}.recently-played-card-title{font-size:.7rem;font-weight:600;color:var(--text);margin-top:4px;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recently-played-bar{width:100%;height:3px;background:var(--surface2);border-radius:2px;margin-top:4px;overflow:hidden}.recently-played-bar-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}@media(max-width:600px){.recently-played-section .recently-played-scroll{padding:0 16px 8px}.recently-played-section .recently-played-title{padding:0 16px}}#grid:has(.library-section){display:block}.library-section{margin-bottom:28px}.library-section-header{display:flex;align-items:center;justify-content:space-between;padding:0 0 12px}.library-section-title{font-size:1.05rem;font-weight:700;color:var(--text);letter-spacing:-0.01em;margin:0}.library-section-scroll{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:0 0 12px;scrollbar-width:none}.library-section-scroll::-webkit-scrollbar{display:none}.library-section-scroll .book-card{flex-shrink:0;width:var(--card-w);scroll-snap-align:start}.library-section-all{margin-top:12px;padding-top:20px;border-top:1px solid rgba(124,106,247,.08)}.library-section-all .library-section-title{margin-bottom:8px}@media(max-width:600px){.library-section-scroll .book-card{width:130px}}.community-section{padding:20px 20px 0}.section-heading{font-size:.9rem;font-weight:600;color:var(--text2);margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.05)}.rec-grid{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;scrollbar-width:none}.rec-grid::-webkit-scrollbar{display:none}.rec-card{flex-shrink:0;width:120px;cursor:pointer}.rec-card .rec-cover{width:120px;height:180px;border-radius:8px;object-fit:cover;background:var(--surface2);display:block}.rec-card .rec-title{font-size:.75rem;font-weight:600;margin-top:6px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.rec-card .rec-author{font-size:.68rem;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trending-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.04);cursor:pointer}.trending-item:last-child{border-bottom:none}.trending-rank{width:28px;font-size:1.1rem;font-weight:800;color:var(--accent);text-align:center;flex-shrink:0}.trending-cover{width:44px;height:66px;border-radius:6px;object-fit:cover;background:var(--surface2);flex-shrink:0}.trending-info{flex:1;min-width:0}.trending-title{font-size:.85rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trending-meta{font-size:.72rem;color:var(--muted);margin-top:2px}.trending-listeners{font-size:.7rem;color:var(--accent2);margin-top:2px}.activity-item{display:flex;gap:10px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.04);align-items:flex-start}.activity-item:last-child{border-bottom:none}.activity-avatar{width:34px;height:34px;border-radius:50%;background:var(--surface3);display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:var(--accent2);flex-shrink:0}.activity-body{flex:1;min-width:0}.activity-text{font-size:.8rem;line-height:1.4}.activity-text strong{color:var(--text)}.activity-time{font-size:.68rem;color:var(--muted);margin-top:3px}.add-friend-wrap{display:flex;gap:8px;margin-bottom:10px}.friend-input{flex:1;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:10px 14px;color:var(--text);font-size:.85rem;outline:none}.friend-input:focus{border-color:var(--accent)}.friend-search-dropdown{position:absolute;top:calc(100%+4px);left:0;right:60px;background:var(--surface2);border:1px solid var(--border);border-radius:10px;overflow:hidden;z-index:100;box-shadow:0 8px 24px rgba(0,0,0,.4)}.friend-search-item{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:background .1s}.friend-search-item:hover,.friend-search-item.active{background:var(--surface3)}.fsi-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#fff;flex-shrink:0}.fsi-email{font-size:.82rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.friend-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.04)}.friend-item:last-child{border-bottom:none}.friend-avatar-btn{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:#fff;flex-shrink:0;border:none;cursor:pointer;transition:transform .15s,box-shadow .15s}.friend-avatar-btn:hover{transform:scale(1.08);box-shadow:0 0 0 3px var(--accent-glow)}.friend-profile-link{font-size:.82rem;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:pointer}.friend-profile-link:hover{color:var(--accent);text-decoration:underline}.friend-email{font-size:.82rem;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.friend-remove{background:none;border:none;color:var(--muted);cursor:pointer;font-size:.8rem;padding:4px 8px;border-radius:6px}.friend-remove:hover{color:var(--red);background:rgba(239,68,68,.1)}.user-profile-modal-box{max-width:460px;width:92%;max-height:85vh;overflow-y:auto}.pub-profile-header{display:flex;align-items:center;gap:16px;margin-bottom:20px}.pub-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:800;color:#fff;flex-shrink:0}.pub-name{font-size:1.15rem;font-weight:700}.pub-email{font-size:.78rem;color:var(--text2);margin-top:2px}.pub-friend-badge{display:inline-block;background:rgba(124,106,247,.15);color:var(--accent);font-size:.72rem;font-weight:600;padding:2px 8px;border-radius:10px;margin-top:4px}.pub-stats{display:flex;gap:8px;margin-bottom:20px}.pub-stat{flex:1;background:var(--surface2);border-radius:10px;padding:12px 8px;text-align:center}.pub-stat-val{display:block;font-size:1.3rem;font-weight:800;color:var(--accent)}.pub-stat-lbl{display:block;font-size:.7rem;color:var(--text2);margin-top:2px}.pub-section-title{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text2);margin:16px 0 8px}.pub-badges{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:4px}.pub-badge{display:flex;align-items:center;gap:6px;background:var(--surface2);border-radius:20px;padding:6px 12px}.pub-badge-emoji{font-size:1rem}.pub-badge-label{font-size:.75rem;font-weight:600}.pub-book-list{display:flex;flex-direction:column;gap:2px}.pub-book-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.04)}.pub-book-row:last-child{border-bottom:none}.pub-book-info{flex:1;min-width:0}.pub-book-title{font-size:.85rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pub-book-author{font-size:.75rem;color:var(--text2);margin-top:1px}.pub-book-action{font-size:.9rem;flex-shrink:0;color:var(--accent)}.request-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.04)}.request-item:last-child{border-bottom:none}.request-actions{display:flex;gap:6px}.btn-accept{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:6px 12px;font-size:.75rem;cursor:pointer;font-weight:600}.btn-decline{background:var(--surface3);color:var(--muted);border:none;border-radius:8px;padding:6px 12px;font-size:.75rem;cursor:pointer}.page{display:none;padding:28px 32px 60px;max-width:900px;margin:0 auto}.page.active{display:block;animation:pageFadeIn 0.2s ease}@keyframes pageFadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.profile-header{margin-bottom:28px}.profile-email{font-size:1rem;color:var(--muted);margin-top:4px}.profile-section{margin-bottom:40px}.profile-section-title{font-size:.95rem;font-weight:600;color:var(--text2);margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.06)}.profile-book{display:flex;align-items:center;gap:16px;padding:14px 16px;background:var(--surface2);border-radius:12px;margin-bottom:10px;cursor:pointer;transition:background .15s}.profile-book:hover{background:var(--surface3)}.pb-cover{width:48px;height:72px;border-radius:6px;overflow:hidden;flex-shrink:0;background:var(--surface3)}.pb-cover img{width:100%;height:100%;object-fit:cover}.pb-info{flex:1;min-width:0}.pb-title{font-size:.9rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pb-author{font-size:.78rem;color:var(--muted);margin-top:2px}.pb-bar-wrap{background:var(--surface3);border-radius:3px;height:4px;margin-top:8px;overflow:hidden}.pb-bar-fill{height:100%;background:var(--accent);border-radius:3px}.pb-pct{font-size:.72rem;color:var(--accent2);margin-top:4px}.pb-completed-badge{font-size:.75rem;color:var(--green);font-weight:600}.empty-profile{text-align:center;padding:40px 20px;color:var(--muted);font-size:.9rem}.badges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:14px;margin-top:4px}.badge-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 12px;border-radius:14px;background:var(--surface2);border:1.5px solid rgba(255,255,255,.06);transition:transform .15s,border-color .15s}.badge-card.earned{border-color:rgba(124,106,247,.45);background:rgba(124,106,247,.08)}.badge-card.earned:hover{transform:translateY(-2px);border-color:rgba(124,106,247,.7)}.badge-card.locked{opacity:.35;filter:grayscale(1)}.badge-emoji{font-size:2.2rem;line-height:1}.badge-label{font-size:.75rem;font-weight:600;color:var(--text2);text-align:center;line-height:1.3}.badge-card.earned .badge-label{color:var(--text)}.badge-lock{font-size:.75rem;color:var(--muted);margin-top:2px}.profile-stats{display:flex;gap:24px;flex-wrap:wrap;margin-bottom:8px}.stat-pill{background:var(--surface2);border-radius:10px;padding:10px 18px;display:flex;flex-direction:column;align-items:center;gap:2px}.stat-value{font-size:1.3rem;font-weight:700;color:var(--accent)}.stat-label{font-size:.72rem;color:var(--muted)}.pub-preview-card{text-align:center;padding:8px 0 4px}.pub-preview-header{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:20px}.pub-avatar-lg{width:80px;height:80px;font-size:1.8rem;border:3px solid transparent;background-origin:border-box;background-clip:content-box,border-box;background-image:linear-gradient(var(--surface),var(--surface)),linear-gradient(135deg,var(--accent),#a78bfa,#f0c040)}.pub-preview-name{font-size:1.2rem;font-weight:800;letter-spacing:-.01em}.pub-preview-stats{display:flex;justify-content:center;gap:32px;margin-bottom:20px;padding:16px 0;border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06)}.pub-preview-stat{text-align:center}.pub-preview-stat-val{display:block;font-size:1.2rem;font-weight:800;color:#fff}.pub-preview-stat-lbl{display:block;font-size:.68rem;color:var(--muted);margin-top:2px;text-transform:uppercase;letter-spacing:.05em}.pub-preview-action{margin-bottom:16px}.pub-action-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 28px;border-radius:10px;font-size:.85rem;font-weight:700;cursor:pointer;border:none;font-family:inherit;transition:background .2s,transform .1s,box-shadow .2s}.pub-action-btn:active{transform:scale(.96)}.pub-action-request{background:var(--accent);color:#fff;box-shadow:0 4px 16px rgba(124,106,247,.4)}.pub-action-request:hover{background:#6a59e0;box-shadow:0 6px 24px rgba(124,106,247,.5)}.pub-action-pending{background:var(--surface3);color:var(--muted);cursor:default}.pub-action-friends{background:rgba(34,197,94,.15);color:var(--green);cursor:default}.pub-preview-badges{display:flex;justify-content:center;gap:8px;margin-bottom:16px;flex-wrap:wrap}.pub-preview-badge{font-size:1.4rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--surface2);border-radius:50%}.pub-preview-badge-more{font-size:.7rem;font-weight:700;color:var(--muted);width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--surface2);border-radius:50%}.pub-preview-section-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:12px 0 8px}.pub-preview-books{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.pub-preview-book{font-size:.82rem;color:var(--text2);padding:6px 12px;background:var(--surface2);border-radius:8px}.pub-preview-private{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;color:var(--muted);font-size:.78rem;background:rgba(255,255,255,.03);border-radius:10px;margin-top:8px}.stats-dashboard{padding:0 0 8px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin-bottom:16px}.stats-card{background:var(--surface2);border-radius:12px;padding:14px;text-align:center}.stats-card-value{font-size:1.4rem;font-weight:800;color:var(--accent)}.stats-card-label{font-size:.72rem;color:var(--muted);margin-top:2px}.stats-chart{margin-top:12px}.stats-chart-title{font-size:.82rem;font-weight:600;margin-bottom:8px}.stats-bars{display:flex;align-items:flex-end;gap:6px;height:80px}.stats-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}.stats-bar{width:100%;border-radius:4px 4px 0 0;min-height:4px;background:linear-gradient(to top,var(--accent),var(--accent2));transition:height .3s ease}.stats-bar-day{font-size:.6rem;color:var(--muted)}.goals-section{margin-top:16px}.goal-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}.goal-ring{width:48px;height:48px;position:relative;flex-shrink:0}.goal-ring svg{width:48px;height:48px;transform:rotate(-90deg)}.goal-ring-bg{stroke:var(--surface2)}.goal-ring-fill{stroke:var(--accent);transition:stroke-dashoffset .5s ease}.goal-ring-pct{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;color:var(--text)}.goal-info{flex:1}.goal-type{font-weight:600;font-size:.85rem;text-transform:capitalize}.goal-detail{font-size:.72rem;color:var(--muted)}.goal-set-form{display:flex;gap:8px;align-items:center;margin-top:8px;flex-wrap:wrap}.goal-set-form select,.goal-set-form input{padding:6px 10px;border-radius:8px;border:1px solid var(--border);background:var(--surface2);color:var(--text);font-size:.82rem;font-family:inherit}.goal-set-form input{width:80px}.ac-dropdown{position:absolute;top:calc(100%+4px);left:0;right:0;background:var(--surface2);border:1px solid rgba(124,106,247,.3);border-radius:12px;box-shadow:0 12px 36px rgba(0,0,0,.55);z-index:500;overflow:hidden;animation:fadeZoom .15s ease}.ac-item{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;cursor:pointer;transition:background .12s;border-bottom:1px solid rgba(255,255,255,.04)}.ac-item:last-child{border-bottom:none}.ac-item:hover,.ac-item.active{background:rgba(124,106,247,.15)}.ac-item-icon{font-size:1.2rem;flex-shrink:0;margin-top:1px}.ac-item-info{flex:1;min-width:0}.ac-item-title{font-size:.88rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ac-item-author{font-size:.75rem;color:var(--muted);margin-top:1px}.ac-item-id{font-size:.7rem;color:rgba(124,106,247,.6);font-family:monospace;margin-top:1px}.ac-spinner{display:flex;align-items:center;gap:8px;padding:12px 14px;color:var(--muted);font-size:.85rem}.ac-spinner-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:acPulse .8s ease-in-out infinite}.ac-spinner-dot:nth-child(2){animation-delay:.15s}.ac-spinner-dot:nth-child(3){animation-delay:.3s}@keyframes acPulse{0%,80%,100%{opacity:.2;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.ac-empty{padding:12px 14px;color:var(--muted);font-size:.85rem;text-align:center}.toast{display:none;position:fixed;bottom:28px;left:50%;transform:translateX(-50%);z-index:400;background:rgba(30,30,46,.85);backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);border:1px solid rgba(124,106,247,.2);color:var(--text);padding:14px 24px 14px 48px;border-radius:40px;font-size:.88rem;font-weight:500;box-shadow:0 12px 40px rgba(0,0,0,.45),0 4px 12px rgba(0,0,0,.2);animation:toastSpringIn .45s cubic-bezier(.175,.885,.32,1.275);white-space:nowrap;max-width:92vw;min-width:260px;overflow:hidden}.toast::before{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:0 0 40px 40px;animation:toastProgress 3s linear forwards}@media(max-width:600px){.toast{white-space:normal;word-break:break-word;text-align:center;min-width:auto}}@keyframes fadeUp{from{transform:translateX(-50%) translateY(10px);opacity:0}to{transform:translateX(-50%) translateY(0);opacity:1}}@keyframes toastSpringIn{0%{transform:translateX(-50%) translateY(40px) scale(0.9);opacity:0}60%{transform:translateX(-50%) translateY(-4px) scale(1.02);opacity:1}100%{transform:translateX(-50%) translateY(0) scale(1);opacity:1}}@keyframes toastIn{from{transform:translateX(-50%) translateY(20px) scale(0.95);opacity:0}to{transform:translateX(-50%) translateY(0) scale(1);opacity:1}}@keyframes toastProgress{from{width:100%}to{width:0%}}.drag-handle{width:36px;height:4px;background:rgba(255,255,255,.12);border-radius:2px;margin:12px auto 0}.empty-state{text-align:center;padding:80px 20px;color:var(--muted)}.empty-state .big-emoji{font-size:4rem;margin-bottom:16px}.empty-state p{font-size:1rem;line-height:1.6}.fab-btn{display:flex;position:fixed;bottom:28px;right:20px;width:52px;height:52px;border-radius:50%;background:var(--accent);color:#fff;border:none;cursor:pointer;box-shadow:0 4px 20px rgba(124,106,247,0.5);align-items:center;justify-content:center;z-index:250;transition:transform 0.15s ease,box-shadow 0.15s ease,bottom 0.3s ease}.fab-btn:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(124,106,247,0.6)}.fab-btn:active{transform:scale(0.92);box-shadow:0 2px 10px rgba(124,106,247,0.4)}body.has-miniplayer .fab-btn{bottom:80px}@keyframes heartPop{0%{transform:scale(1)}40%{transform:scale(1.5)}70%{transform:scale(0.85)}100%{transform:scale(1)}}.card-fav.popping{animation:heartPop 0.4s ease forwards}.offline-badge{position:absolute;bottom:6px;left:6px;background:rgba(34,197,94,.9);color:#fff;font-size:.6rem;font-weight:700;padding:2px 6px;border-radius:4px;z-index:4;pointer-events:none;line-height:1.4;letter-spacing:.3px}#pwa-install-banner{font-family:inherit}.notif-bell{position:relative;background:none;border:none;color:var(--text);cursor:pointer;padding:6px;border-radius:50%;transition:background .15s}.notif-bell:hover{background:var(--surface2)}.notif-badge{position:absolute;top:0;right:0;background:#ef4444;color:#fff;font-size:.6rem;font-weight:700;min-width:16px;height:16px;border-radius:99px;display:flex;align-items:center;justify-content:center;line-height:1;padding:0 4px}.notif-panel{position:absolute;top:42px;right:0;width:320px;max-height:400px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.25);z-index:1000;overflow:hidden}.notif-panel-header{padding:12px 16px;font-weight:700;font-size:.9rem;border-bottom:1px solid var(--border)}.notif-panel-list{max-height:340px;overflow-y:auto}.notif-item{padding:10px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s}.notif-item:hover{background:var(--surface2)}.notif-item.unread{background:rgba(124,106,247,.08)}.notif-item-title{font-weight:600;font-size:.82rem}.notif-item-msg{font-size:.75rem;color:var(--muted);margin-top:2px}.notif-item-time{font-size:.68rem;color:var(--muted);margin-top:4px}.notif-empty{text-align:center;padding:24px;color:var(--muted);font-size:.85rem}.collections-section{margin-top:8px}.collection-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);cursor:pointer}.collection-row:hover{background:var(--surface2);border-radius:8px;padding:10px 8px;margin:0 -8px}.collection-icon{width:36px;height:36px;border-radius:8px;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}.collection-info{flex:1;min-width:0}.collection-name{font-weight:600;font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.collection-count{font-size:.72rem;color:var(--muted)}.collection-del{background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;font-size:.85rem}.collection-del:hover{color:#ef4444}.collection-create-form{display:flex;gap:8px;margin-top:8px}.collection-create-form input{flex:1;padding:8px 12px;border-radius:8px;border:1px solid var(--border);background:var(--surface2);color:var(--text);font-size:.82rem;font-family:inherit}.detail-skeleton-cover{width:130px;aspect-ratio:2/3;border-radius:10px;background:linear-gradient(90deg,var(--surface2) 25%,var(--surface3) 50%,var(--surface2) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.detail-skeleton-title{height:22px;width:70%;border-radius:6px;background:linear-gradient(90deg,var(--surface2) 25%,var(--surface3) 50%,var(--surface2) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;margin-bottom:10px}.detail-skeleton-meta{height:14px;width:45%;border-radius:4px;background:linear-gradient(90deg,var(--surface2) 25%,var(--surface3) 50%,var(--surface2) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;margin-bottom:8px}.detail-skeleton-synopsis{height:12px;width:90%;border-radius:4px;background:linear-gradient(90deg,var(--surface2) 25%,var(--surface3) 50%,var(--surface2) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;margin-bottom:6px}.detail-skeleton-btn{height:32px;width:80px;border-radius:20px;background:linear-gradient(90deg,var(--surface2) 25%,var(--surface3) 50%,var(--surface2) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;display:inline-block;margin-right:8px}.chapter-loading-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.5);border-radius:10px;z-index:5}.chapter-spinner{width:32px;height:32px;border:3px solid rgba(124,106,247,.3);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.search-loading-dots{display:inline-flex;gap:4px;align-items:center;padding:4px 0}.search-loading-dots span{width:5px;height:5px;border-radius:50%;background:var(--accent);animation:searchDotPulse .8s ease-in-out infinite}.search-loading-dots span:nth-child(2){animation-delay:.15s}.search-loading-dots span:nth-child(3){animation-delay:.3s}@keyframes searchDotPulse{0%,80%,100%{opacity:.25;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.modal-loading{display:flex;align-items:center;justify-content:center;padding:40px 0}.modal-spinner{width:28px;height:28px;border:3px solid rgba(124,106,247,.2);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.offline-banner{display:none;position:fixed;top:0;left:0;right:0;z-index:9999;background:linear-gradient(90deg,#ef4444,#dc2626);color:#fff;text-align:center;padding:8px 16px;font-size:.82rem;font-weight:600;transform:translateY(-100%);transition:transform .3s ease;box-shadow:0 2px 12px rgba(239,68,68,.4)}.offline-banner.visible{display:block;transform:translateY(0)}.audio-retry-overlay{position:fixed;inset:0;z-index:950;background:rgba(0,0,0,.85);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:#fff;font-size:1rem;cursor:pointer;backdrop-filter:blur(4px)}.audio-retry-overlay .retry-icon{font-size:2.5rem}.audio-retry-overlay .retry-text{font-size:.9rem;color:rgba(255,255,255,.8)}.ptr-indicator{position:fixed;top:0;left:50%;transform:translateX(-50%) translateY(-60px);z-index:9998;background:var(--surface2);border:1px solid rgba(124,106,247,.2);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,.3);transition:transform .2s ease,opacity .2s ease;opacity:0}.ptr-indicator.pulling{opacity:1}.ptr-indicator.refreshing .ptr-spinner{animation:spin .7s linear infinite}.ptr-spinner{width:20px;height:20px;border:2px solid rgba(124,106,247,.3);border-top-color:var(--accent);border-radius:50%}.book-card.long-pressing .cover-wrap{transform:scale(.95);transition:transform .2s ease}.book-card.long-pressing .cover-wrap::after{content:'';position:absolute;inset:0;border:2px solid var(--accent);border-radius:var(--radius);animation:longPressRing .6s ease forwards;pointer-events:none}@keyframes longPressRing{from{opacity:0;transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.fp-heart-anim{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);font-size:4rem;z-index:1100;pointer-events:none;animation:heartBurst .8s ease forwards;opacity:0}@keyframes heartBurst{0%{opacity:0;transform:translate(-50%,-50%) scale(0)}20%{opacity:1;transform:translate(-50%,-50%) scale(1.4)}50%{opacity:1;transform:translate(-50%,-50%) scale(1)}100%{opacity:0;transform:translate(-50%,-50%) scale(1.6)}}.ptr-indicator{position:fixed;top:0;left:50%;transform:translateX(-50%) translateY(-100%);z-index:9990;transition:transform .3s ease;padding:12px}.ptr-indicator.visible{transform:translateX(-50%) translateY(8px)}.ptr-spinner{width:24px;height:24px;border:3px solid rgba(124,106,247,.3);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.confirm-dialog-overlay{position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease;pointer-events:none}.confirm-dialog-overlay.visible{opacity:1;pointer-events:auto}.confirm-dialog{background:var(--surface);border:1px solid rgba(124,106,247,.2);border-radius:var(--radius);padding:24px 28px;max-width:380px;width:90%;box-shadow:0 16px 48px rgba(0,0,0,.5);transform:scale(.92);transition:transform .2s ease}.confirm-dialog-overlay.visible .confirm-dialog{transform:scale(1)}.confirm-dialog-msg{color:var(--text);font-size:.95rem;line-height:1.5;margin-bottom:20px;text-align:center}.confirm-dialog-actions{display:flex;gap:10px;justify-content:center}.confirm-dialog-actions .btn{min-width:90px;justify-content:center}.shortcuts-help-modal{position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s ease}.shortcuts-help-modal.visible{opacity:1;pointer-events:auto}.shortcuts-help-inner{background:var(--surface);border:1px solid rgba(124,106,247,.2);border-radius:var(--radius);padding:24px 28px;max-width:420px;width:90%;box-shadow:0 16px 48px rgba(0,0,0,.5);transform:scale(.92);transition:transform .2s ease}.shortcuts-help-modal.visible .shortcuts-help-inner{transform:scale(1)}.shortcuts-help-title{font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:16px;text-align:center}.shortcuts-help-list{list-style:none;padding:0;margin:0}.shortcuts-help-list li{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.06);font-size:.88rem;color:var(--text2)}.shortcuts-help-list li:last-child{border-bottom:none}.shortcuts-help-list kbd{background:var(--surface2);border:1px solid rgba(255,255,255,.12);border-radius:4px;padding:2px 8px;font-family:inherit;font-size:.8rem;color:var(--text);min-width:28px;text-align:center}.shortcuts-help-close{margin-top:16px;width:100%;text-align:center}.empty-state-enhanced{text-align:center;padding:40px 20px}.empty-state-icon{font-size:2.5rem;margin-bottom:12px;opacity:.6}.empty-state-msg{color:var(--muted);font-size:.88rem;margin-bottom:16px;line-height:1.5}.empty-state-cta{display:inline-flex}.btn-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;vertical-align:middle}.toast{position:relative;overflow:hidden}.toast-content{display:inline-flex;align-items:center}.toast-progress{position:absolute;bottom:0;left:0;height:2px;width:100%;background:currentColor;opacity:.3;transform-origin:left}@keyframes toastProgress{from{width:100%}to{width:0%}}.toast-success{border-left:3px solid #34c759}.toast-error{border-left:3px solid #ff453a}.toast-info{border-left:3px solid var(--accent,#6c63ff)}@media(max-width:600px){:root{--card-w:140px}header{padding:14px 16px}.grid-section,.page{padding:20px 16px 60px}.nav-tabs{padding:14px 16px 0}.detail-hero{flex-direction:column;align-items:center;text-align:center;gap:16px}.detail-cover{width:110px}.detail-player,.detail-chapters,.detail-progress{padding-left:16px;padding-right:16px}.chapter-row audio{width:100%}.modal{padding:24px 18px;max-height:85vh;overflow-y:auto}.mp-btn{padding:10px;font-size:1.1rem;min-width:40px;min-height:40px;display:flex;align-items:center;justify-content:center}.mp-btn.mp-play{font-size:1.4rem}.mp-btn.mp-speed{font-size:.75rem;min-width:36px}.mp-close{padding:10px;min-width:40px;min-height:40px}.mp-progress-wrap{height:6px}.sleep-timer-btn{padding:8px 10px;min-height:40px}.mini-player{gap:8px;padding:0 10px;height:68px}.cp-play{min-width:40px;min-height:40px}.btn{padding:10px 16px;font-size:.88rem}.close-btn{width:36px;height:36px;font-size:1.1rem}}@media(min-width:768px){.overlay{align-items:center;padding:24px}.detail-panel{border-radius:24px;border:1px solid rgba(124,106,247,.2);animation:fadeZoom .25s ease}.grid{grid-template-columns:repeat(4,1fr)}}@media(max-width:600px){.continue-card{padding:12px 14px}.continue-cover{width:44px;height:66px}}@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.01ms!important;animation-iteration-count:1!important;transition-duration:0.01ms!important;scroll-behavior:auto!important}html{scroll-behavior:auto}.book-card:hover{transform:none;box-shadow:none}.btn:hover:not(:disabled){transform:none}.full-player.entering,.full-player.leaving{animation:none}.skeleton-cover,.skeleton-title,.skeleton-meta{animation:none;background:var(--surface2)}.fp-cover{transition:none}.fp-cover.playing{transform:none}.fp-waveform span,.mp-wave span,.now-playing-bars span{animation:none}.streak-wrap{animation:none}.page.active{animation:none}}@media(min-width:768px) and (max-width:1023px){.grid{grid-template-columns:repeat(3,1fr);gap:24px}.btn{min-height:44px}.nav-tab{padding:10px 20px;font-size:.92rem}.filter-trigger{padding:8px 14px;font-size:.84rem}.chapter-row{padding:12px 10px}.ch-play-btn{width:36px;height:36px}}@media(max-width:480px){.grid{grid-template-columns:repeat(2,1fr);gap:14px}:root{--card-w:130px}.filter-bar{gap:5px}.filter-trigger{padding:5px 8px;font-size:.72rem}.nav-tabs{padding:12px 12px 0;gap:4px}.nav-tab{padding:7px 12px;font-size:.82rem}.grid-section,.page{padding:16px 12px 60px}header{padding:12px 12px}}@media(orientation:landscape) and (max-height:500px){.fp-audio-view{flex-direction:row;align-items:center;gap:16px;padding:0 16px}.fp-cover-wrap{padding:8px 0;flex-shrink:0}.fp-cover{width:min(35vw,160px)}.fp-seek-wrap{flex:1;padding:4px 0 0}.fp-controls{padding:4px 0;justify-content:center;gap:8px}.fp-waveform{display:none}.fp-meta{padding:4px 16px}}@media(min-width:1025px){.overlay{align-items:stretch;justify-content:flex-end;padding:0}.detail-panel{border-radius:24px 0 0 24px;max-width:480px;height:100vh;max-height:100vh;animation:slideInRight .3s cubic-bezier(.25,.46,.45,.94);border:1px solid rgba(124,106,247,.15);border-right:none}@keyframes slideInRight{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}.grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}}@media(max-width:360px){.mini-player .sleep-timer-wrap{display:none}.mp-btn.mp-speed{display:none}.mp-time{display:none}.mini-player{gap:6px;padding:0 8px}}@keyframes cardFadeIn{from{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.book-card{animation:cardFadeIn .4s ease backwards}.book-card:nth-child(1){animation-delay:.02s}.book-card:nth-child(2){animation-delay:.06s}.book-card:nth-child(3){animation-delay:.10s}.book-card:nth-child(4){animation-delay:.14s}.book-card:nth-child(5){animation-delay:.18s}.book-card:nth-child(6){animation-delay:.22s}.book-card:nth-child(7){animation-delay:.26s}.book-card:nth-child(8){animation-delay:.30s}.book-card:nth-child(n+9){animation-delay:.34s}.page-leaving{opacity:0;transform:translateY(4px);transition:opacity .15s ease,transform .15s ease}.page-entering{animation:pageEnter .3s ease both}@keyframes pageEnter{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.skeleton-card{animation:skeletonFadeIn .4s ease both}@keyframes skeletonFadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}