:root{--primary: #6c2bd9;--primary-dark: #4a1a9e;--primary-light: #8b5cf6;--primary-glow: rgba(108, 43, 217, .4);--accent: #ff2d78;--accent-light: #ff5e9e;--accent-glow: rgba(255, 45, 120, .4);--accent-orange: #ff8c42;--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-card: #1a1a28;--bg-card-hover: #222236;--bg-elevated: #1e1e30;--bg-overlay: rgba(0, 0, 0, .7);--bg-blur: rgba(10, 10, 15, .85);--text-primary: #f0f0f5;--text-secondary: #a0a0b8;--text-muted: #6b6b80;--text-accent: var(--accent);--border-subtle: rgba(255, 255, 255, .06);--border-light: rgba(255, 255, 255, .1);--border-active: var(--primary-light);--gradient-primary: linear-gradient(135deg, #6c2bd9, #ff2d78);--gradient-dark: linear-gradient(180deg, transparent, var(--bg-primary));--gradient-card: linear-gradient(145deg, #1a1a28, #12121a);--gradient-hero: linear-gradient(180deg, transparent 0%, rgba(10,10,15,.6) 50%, var(--bg-primary) 100%);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px var(--primary-glow);--shadow-accent: 0 0 20px var(--accent-glow);--font-ui: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-reading: "Playfair Display", Georgia, serif;--fs-xs: .6875rem;--fs-sm: .8125rem;--fs-base: .9375rem;--fs-md: 1.0625rem;--fs-lg: 1.25rem;--fs-xl: 1.5rem;--fs-2xl: 1.875rem;--fs-3xl: 2.25rem;--fs-4xl: 3rem;--fw-light: 300;--fw-regular: 400;--fw-medium: 500;--fw-semibold: 600;--fw-bold: 700;--fw-extrabold: 800;--lh-tight: 1.2;--lh-normal: 1.5;--lh-relaxed: 1.75;--lh-reading: 1.9;--space-xs: .25rem;--space-sm: .5rem;--space-md: .75rem;--space-base: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 50%;--radius-pill: 100px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--transition-spring: .5s cubic-bezier(.34, 1.56, .64, 1);--z-base: 1;--z-dropdown: 10;--z-sticky: 20;--z-nav: 50;--z-modal: 100;--z-toast: 150;--z-overlay: 200;--nav-height: 60px;--topbar-height: 56px;--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-top: env(safe-area-inset-top, 0px)}@import "./variables.css";*,*:before,*:after{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%;overscroll-behavior-y:auto}body{font-family:var(--font-ui);background:var(--bg-primary);color:var(--text-primary);line-height:var(--lh-normal);min-height:100dvh;overflow-x:hidden;-webkit-overflow-scrolling:touch;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{min-height:100dvh;position:relative;overflow-x:hidden;max-width:100vw;-webkit-overflow-scrolling:touch}@media(min-width:900px){#app{display:flex;flex-direction:row;max-width:100vw}#page-root{flex:1 1 auto;min-width:0;margin-left:240px}.page{padding-bottom:32px;max-width:1200px;margin:0 auto}.page-no-nav{padding-bottom:0}}#page-root{-webkit-overflow-scrolling:touch}::-webkit-scrollbar{width:0;height:0}*{scrollbar-width:none}a{color:inherit;text-decoration:none}img{display:block;max-width:100%;height:auto;object-fit:cover}button{font-family:inherit;font-size:inherit;border:none;outline:none;cursor:pointer;background:none;color:inherit}input,textarea,select{font-family:inherit;font-size:inherit;border:none;outline:none;background:none;color:inherit}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}.page{padding-bottom:calc(var(--nav-height) + var(--safe-bottom) + 16px);min-height:100dvh;animation:fadeIn .3s ease}.page-no-nav{padding-bottom:0;min-height:100dvh;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes glow{0%,to{box-shadow:0 0 5px var(--primary-glow)}50%{box-shadow:0 0 20px var(--primary-glow),0 0 40px var(--primary-glow)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes coinSpin{0%{transform:rotateY(0)}to{transform:rotateY(360deg)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:14px 28px;border-radius:var(--radius-pill);font-weight:var(--fw-semibold);font-size:var(--fs-base);transition:all var(--transition-base);position:relative;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;max-width:100%;min-width:0}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-glow)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 30px var(--primary-glow)}.btn-primary:active{transform:scale(.97)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-light)}.btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--primary-light)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{color:var(--text-primary);background:#ffffff0d}.btn-sm{padding:8px 16px;font-size:var(--fs-sm)}.btn-lg{padding:16px 32px;font-size:var(--fs-md)}.btn-block{width:100%}.btn-icon{width:44px;height:44px;padding:0;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center}.btn-primary:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at var(--x, 50%) var(--y, 50%),rgba(255,255,255,.2),transparent 60%);opacity:0;transition:opacity var(--transition-fast)}.btn-primary:active:after{opacity:1}.chip{display:inline-flex;align-items:center;gap:var(--space-xs);padding:8px 18px;border-radius:var(--radius-pill);background:var(--bg-card);color:var(--text-secondary);font-size:var(--fs-sm);font-weight:var(--fw-medium);border:1px solid var(--border-subtle);cursor:pointer;transition:all var(--transition-base);user-select:none}.chip:hover{background:var(--bg-card-hover);border-color:var(--border-light)}.chip.active{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:var(--shadow-glow)}.chip-emoji{font-size:1.1em}.book-card{display:flex;flex-direction:column;width:120px;flex-shrink:0;cursor:pointer;transition:transform var(--transition-base)}.book-card:active{transform:scale(.96)}.book-card__cover{position:relative;width:120px;aspect-ratio:3 / 4;border-radius:var(--radius-md);overflow:hidden;margin-bottom:var(--space-sm);box-shadow:var(--shadow-md)}.book-card__cover img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.book-card:hover .book-card__cover img{transform:scale(1.05)}.book-card__genre,.book-card__fallback{position:absolute;top:8px;left:8px;padding:3px 8px;background:linear-gradient(135deg,var(--primary-light),var(--primary));backdrop-filter:blur(8px);border-radius:var(--radius-sm);font-size:.625rem;font-weight:var(--fw-semibold);color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px}.book-card__progress{position:absolute;bottom:0;left:0;right:0;height:3px;background:#ffffff1a}.book-card__progress-bar{height:100%;background:var(--gradient-primary);border-radius:0 2px 0 0;transition:width var(--transition-base)}.book-card__title{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text-primary);line-height:var(--lh-tight);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:2px}.book-card__hook{font-size:var(--fs-xs);color:var(--text-muted);display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:4px}.book-card__meta{display:flex;align-items:center;gap:var(--space-xs);font-size:.625rem;color:var(--text-muted)}.book-card__rating{color:#fbbf24}.book-card__continue{display:inline-flex;align-items:center;gap:4px;margin-top:4px;padding:4px 10px;background:var(--primary);color:#fff;border-radius:var(--radius-pill);font-size:.625rem;font-weight:var(--fw-semibold)}.book-card--compact{width:96px}.book-card--compact .book-card__cover{width:96px;margin-bottom:6px}.book-card--compact .book-card__title{font-size:.75rem;-webkit-line-clamp:1}.book-card--compact .book-card__hook{font-size:.625rem;-webkit-line-clamp:1;margin-bottom:3px}.book-card--compact .book-card__meta{font-size:.5625rem}.book-card--compact .book-card__genre,.book-card--compact .book-card__fallback{font-size:.55rem;padding:2px 6px}.book-card--mini{width:84px}.book-card--mini .book-card__cover{width:84px;margin-bottom:5px}.book-card--mini .book-card__title{font-size:.6875rem;-webkit-line-clamp:1}.book-card--mini .book-card__hook{font-size:.5625rem;-webkit-line-clamp:1;margin-bottom:2px}.book-card--mini .book-card__meta{font-size:.5rem}.book-card--mini .book-card__genre,.book-card--mini .book-card__fallback{font-size:.5625rem;padding:2px 6px}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--nav-height) + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:var(--bg-blur);backdrop-filter:blur(20px) saturate(1.5);border-top:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-around;z-index:var(--z-nav)}.bottom-nav--hidden,.sidebar-nav{display:none}@media(min-width:900px){.bottom-nav{display:none!important}.sidebar-nav{display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;width:240px;background:var(--bg-blur);backdrop-filter:blur(20px) saturate(1.5);border-right:1px solid var(--border-subtle);z-index:var(--z-nav);padding:28px 16px 24px;gap:4px}.sidebar-nav__logo{font-family:var(--font-reading);font-size:var(--fs-xl);font-weight:var(--fw-bold);background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:32px;padding-left:12px}.sidebar-nav__item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:var(--radius-lg);color:var(--text-muted);font-size:var(--fs-sm);font-weight:var(--fw-medium);cursor:pointer;transition:all var(--transition-base);text-decoration:none;border:none;background:none;width:100%;text-align:left}.sidebar-nav__item:hover{color:var(--text-primary);background:#ffffff0f}.sidebar-nav__item.active{color:var(--primary-light);background:#8b5cf626;border:1px solid rgba(139,92,246,.18)}.sidebar-nav__item svg{width:22px;height:22px;stroke-width:1.8;flex-shrink:0}.sidebar-nav__spacer{flex:1}.sidebar-nav__divider{height:1px;background:var(--border-subtle);margin:8px 0}.top-bar{left:240px}}.nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px 12px;color:var(--text-muted);font-size:.625rem;font-weight:var(--fw-medium);transition:color var(--transition-fast);cursor:pointer;position:relative;min-width:0;flex:1 1 0;overflow:hidden;text-align:center}.nav-item span{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-item.active{color:var(--primary-light)}.nav-item.active:before{content:"";position:absolute;top:-1px;left:50%;transform:translate(-50%);width:20px;height:2px;background:var(--primary-light);border-radius:2px}.nav-item svg{width:24px;height:24px;stroke-width:1.8}.top-bar{position:sticky;top:0;left:0;right:0;height:calc(var(--topbar-height) + var(--safe-top));padding:var(--safe-top) var(--space-base) 0;display:flex;align-items:center;justify-content:space-between;background:var(--bg-blur);backdrop-filter:blur(20px);z-index:var(--z-sticky);border-bottom:1px solid var(--border-subtle)}.top-bar__logo{font-family:var(--font-reading);font-size:var(--fs-lg);font-weight:var(--fw-bold);background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.top-bar__actions{display:flex;align-items:center;gap:var(--space-sm)}.top-bar__coins{display:flex;align-items:center;gap:4px;padding:6px 12px;background:var(--bg-card);border-radius:var(--radius-pill);font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:#fbbf24}.top-bar__coins svg{width:16px;height:16px}.top-bar__pro{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--radius-pill);font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:#f8f4ff;background:linear-gradient(135deg,var(--primary-light),var(--primary));border:1px solid rgba(139,92,246,.9)}.top-bar__pro .icon{color:#ede4ff}.pro-screen{position:fixed;inset:0;z-index:calc(var(--z-overlay) + 10);background:radial-gradient(120% 70% at 15% -10%,rgba(139,92,246,.24),transparent 60%),radial-gradient(100% 65% at 95% 0%,rgba(255,45,120,.16),transparent 62%),var(--bg-primary);display:flex;flex-direction:column}.pro-screen:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,#0a0a0f1f,#0a0a0fe0);pointer-events:none}.pro-screen__art{position:absolute;top:72px;left:50%;transform:translate(-50%);width:min(460px,92vw);height:240px;border-radius:999px;background:radial-gradient(circle at center,#8b5cf638,#8b5cf600);filter:blur(12px);pointer-events:none}.pro-screen__top{display:flex;justify-content:flex-end;padding:calc(var(--safe-top) + 8px) 12px 0;position:relative;z-index:1}.pro-screen__close{width:22px;height:22px;border-radius:var(--radius-full);border:1px solid var(--border-light);background:#ffffff0a;color:var(--text-muted);font-size:11px;line-height:1}.pro-screen__body{flex:1;overflow-y:auto;padding:6px var(--space-base) calc(var(--space-xl) + var(--safe-bottom));position:relative;z-index:1}.pro-modal--fullscreen{max-width:430px;margin:8px auto 0;text-align:center;padding:18px 16px 16px;border-radius:24px;background:linear-gradient(180deg,#ffffff0f,#ffffff05);border:1px solid rgba(255,255,255,.1);box-shadow:0 16px 48px #00000061}.pro-modal{text-align:center}.pro-modal__hero{font-size:2.3rem;margin-bottom:10px}.pro-modal__subtitle{color:var(--text-secondary);font-size:.92rem;margin-bottom:14px}.pro-modal__benefits{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;font-size:.84rem;color:var(--text-primary)}.pro-modal__plans{display:flex;flex-direction:column;gap:10px;text-align:left}.pro-plan{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:14px;border:1px solid var(--border-light);background:linear-gradient(180deg,#ffffff0b,#ffffff04);color:var(--text-primary);min-width:0;overflow:hidden}.pro-plan__name{font-weight:var(--fw-semibold);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.pro-plan__price{flex-shrink:0}.pro-plan--popular{border-color:#8b5cf6d9;box-shadow:0 0 0 1px #8b5cf652 inset}.pro-plan--disabled{opacity:.55}.token-bonus{color:#fbbf24}.pro-plan__meta{font-size:.74rem;color:var(--text-muted);margin-top:2px}.pro-plan__price{font-weight:var(--fw-bold);color:var(--primary-light)}.pro-modal__legal{margin-top:12px;font-size:.72rem;line-height:1.4;color:var(--text-muted);text-align:left}.pro-modal__legal a{color:var(--primary-light)}.pro-modal__status{margin-top:10px;font-size:.75rem;color:#fca5a5;text-align:left}.pro-modal__status--ok{color:#86efac}.section{margin-bottom:var(--space-xl)}.section__header{display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-base);margin-bottom:var(--space-md)}.section__title{font-size:var(--fs-lg);font-weight:var(--fw-bold);color:var(--text-primary)}.section__see-all{font-size:var(--fs-sm);color:var(--primary-light);font-weight:var(--fw-medium)}.section__scroll{display:flex;gap:var(--space-md);padding:0 var(--space-base);overflow-x:auto;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch}.section__scroll--tight{gap:var(--space-sm)}.section__scroll>*{scroll-snap-align:start}.modal-overlay{position:fixed;inset:0;background:#0009;backdrop-filter:blur(8px);z-index:var(--z-modal);display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s ease}.modal{background:var(--bg-elevated);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:480px;max-height:85vh;overflow-y:auto;padding:var(--space-xl);animation:slideUp .35s cubic-bezier(.34,1.56,.64,1);touch-action:pan-y;will-change:transform}.modal--dragging{transition:none!important}.modal__handle{width:36px;height:4px;background:var(--border-light);border-radius:2px;margin:0 auto var(--space-lg);touch-action:none}.modal__title{font-size:var(--fs-xl);font-weight:var(--fw-bold);text-align:center;margin-bottom:var(--space-base)}.toast-container{position:fixed;top:calc(var(--safe-top) + 16px);left:50%;transform:translate(-50%);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-sm);pointer-events:none;width:90%;max-width:400px}.toast{background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:var(--space-md) var(--space-base);display:flex;align-items:center;gap:var(--space-md);box-shadow:var(--shadow-lg);animation:none;pointer-events:auto;will-change:transform,opacity;touch-action:none}.toast--dragging{transition:none!important}.toast--success{border-left:3px solid #22c55e}.toast--coin{border-left:3px solid #fbbf24}.toast--achievement{border-left:3px solid var(--primary-light)}.toast__icon{font-size:1.5rem;flex-shrink:0}.toast__text{font-size:var(--fs-sm);color:var(--text-primary)}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-pill);font-size:.625rem;font-weight:var(--fw-bold);text-transform:uppercase;letter-spacing:.5px}.badge--vip{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#1a1a28}.badge--new{background:var(--accent);color:#fff}.badge--hot{background:#ef4444;color:#fff}.stars{display:inline-flex;gap:1px;color:#fbbf24;font-size:.75rem}.skeleton{background:linear-gradient(90deg,var(--bg-card) 25%,var(--bg-card-hover) 50%,var(--bg-card) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-md)}.progress-bar{width:100%;height:4px;background:#ffffff14;border-radius:2px;overflow:hidden}.progress-bar__fill{height:100%;background:var(--gradient-primary);border-radius:2px;transition:width var(--transition-base)}.tabs{display:flex;gap:var(--space-xs);padding:0 var(--space-base);overflow-x:auto;margin-bottom:var(--space-lg)}.tab{padding:10px 14px;border-radius:var(--radius-pill);font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--text-muted);background:transparent;border:1px solid var(--border-subtle);white-space:nowrap;cursor:pointer;transition:all var(--transition-base);flex-shrink:0}.tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.search-bar{display:flex;align-items:center;gap:var(--space-sm);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-pill);padding:10px 16px;margin:0 var(--space-base);transition:border-color var(--transition-base)}.search-bar:focus-within{border-color:var(--primary-light)}.search-bar svg{width:20px;height:20px;color:var(--text-muted);flex-shrink:0}.search-bar input{flex:1;font-size:var(--fs-base);color:var(--text-primary)}.search-bar input::placeholder{color:var(--text-muted)}.achievement{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-base);background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-subtle)}.achievement__icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:var(--bg-elevated);border-radius:var(--radius-full)}.achievement--locked{opacity:.4;filter:grayscale(1)}.achievement__info{flex:1}.achievement__name{font-size:var(--fs-sm);font-weight:var(--fw-semibold)}.achievement__desc{font-size:var(--fs-xs);color:var(--text-muted)}.onboarding{min-height:100dvh;display:flex;flex-direction:column;position:relative;overflow:hidden}.onboarding__bg{position:fixed;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(108,43,217,.3) 0%,transparent 60%),radial-gradient(ellipse at 80% 100%,rgba(255,45,120,.15) 0%,transparent 50%),var(--bg-primary);z-index:-1}.onboarding__step{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-xl);text-align:center;animation:fadeIn .5s ease}.onboarding__tagline{font-family:var(--font-reading);font-size:var(--fs-3xl);font-weight:var(--fw-bold);line-height:var(--lh-tight);margin-bottom:var(--space-sm);background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.onboarding__subtitle{font-size:var(--fs-base);color:var(--text-secondary);margin-bottom:var(--space-2xl);max-width:280px}.onboarding__label{font-size:var(--fs-xl);font-weight:var(--fw-bold);margin-bottom:var(--space-sm)}.onboarding__sublabel{font-size:var(--fs-sm);color:var(--text-secondary);margin-bottom:var(--space-xl)}.onboarding__chips{display:flex;flex-wrap:wrap;gap:var(--space-sm);justify-content:center;max-width:360px;margin-bottom:var(--space-2xl)}.onboarding__footer{padding:var(--space-lg) var(--space-xl);display:flex;flex-direction:column;gap:var(--space-md);width:100%;max-width:360px}.onboarding__dots{display:flex;gap:var(--space-sm);justify-content:center;margin-bottom:var(--space-lg)}.onboarding__dot{width:8px;height:8px;border-radius:var(--radius-full);background:var(--border-light);transition:all var(--transition-base)}.onboarding__dot.active{width:24px;background:var(--primary-light)}.onboarding__skip{font-size:var(--fs-sm);color:var(--text-muted);text-align:center;padding:var(--space-sm);cursor:pointer}.onboarding__social-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:14px;border-radius:var(--radius-lg);font-weight:var(--fw-semibold);font-size:var(--fs-base);width:100%;border:1px solid var(--border-light);background:var(--bg-card);transition:all var(--transition-base)}.onboarding__social-btn:hover{background:var(--bg-card-hover)}.onboarding__social-btn svg{width:20px;height:20px}.onboarding__login-cta{background:linear-gradient(135deg,#38bdf852,#6366f147);color:var(--text-primary);border:1px solid rgba(125,211,252,.5);font-weight:var(--fw-bold)}.auth-modal{display:flex;flex-direction:column;gap:var(--space-sm)}.auth-modal__subtitle{color:var(--text-secondary);font-size:var(--fs-sm);margin-bottom:var(--space-sm)}.auth-modal__form{display:flex;flex-direction:column;gap:var(--space-sm)}.auth-input{width:100%;border:1px solid var(--border-light);border-radius:var(--radius-md);background:var(--bg-card);color:var(--text-primary);padding:12px 14px;font-size:var(--fs-sm)}.auth-input:focus{outline:none;border-color:var(--primary-light);box-shadow:0 0 0 2px #a855f733}.auth-modal__close{margin-top:var(--space-xs);color:var(--text-muted);font-size:var(--fs-sm);text-align:center;padding:var(--space-xs)}.home{padding-top:0}.home,.search-page,.library-page{width:100%;max-width:430px;margin:0 auto}@media(min-width:900px){.home,.search-page,.library-page{max-width:100%}.library__grid,.search-page__results{display:grid!important;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:24px;padding:0 24px 32px}.library__grid .book-card,.search-page__results .book-card,.library__grid .book-card__cover,.search-page__results .book-card__cover{width:100%!important}.search-bar{margin:0 24px;max-width:none}.tabs{padding:0 24px}.top-bar{padding:var(--safe-top) 24px 0}.section__scroll{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));overflow-x:visible;padding:0 24px;gap:20px}.section__scroll .book-card,.section__scroll .book-card__cover{width:100%!important}.section__header{padding:0 24px}.hero-banner{height:420px}}@media(min-width:1400px){.library__grid,.search-page__results{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}.search-page__header{padding:10px 16px 8px;position:sticky;top:0;background:var(--bg-primary);z-index:10;border-bottom:1px solid var(--border-subtle)}.search-page__genres{display:flex;gap:8px;padding:10px 16px 12px;overflow-x:auto;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;scrollbar-width:none}.search-page__genres::-webkit-scrollbar{display:none}.search-genre-chip{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:var(--radius-pill);background:var(--bg-card);color:var(--text-secondary);font-size:var(--fs-sm);font-weight:var(--fw-medium);border:1px solid var(--border-subtle);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;flex-shrink:0;scroll-snap-align:start}.search-genre-chip:hover{background:var(--bg-card-hover);border-color:var(--border-light);color:var(--text-primary)}.search-genre-chip--active{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:var(--shadow-glow)}.search-page__toolbar{display:flex;align-items:center;justify-content:space-between;padding:0 16px 12px;gap:8px}.search-page__count{font-size:var(--fs-sm);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.search-sort-wrap{position:relative;display:flex;align-items:center;flex-shrink:0}.search-sort-select{appearance:none;-webkit-appearance:none;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-pill);color:var(--text-primary);font-size:var(--fs-xs);font-weight:var(--fw-medium);padding:6px 30px 6px 12px;cursor:pointer;transition:all var(--transition-base);outline:none}.search-sort-select:focus{border-color:var(--primary-light);box-shadow:0 0 0 2px #a855f733}.search-sort-icon{position:absolute;right:10px;pointer-events:none;color:var(--text-muted);display:flex;align-items:center}.search-page__results{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:0 16px 32px}.search-page__results .book-card,.search-page__results .book-card__cover{width:100%}@media(min-width:480px){.search-page__results{grid-template-columns:repeat(4,1fr)}}@media(min-width:900px){.search-page__header{padding:14px 24px 10px;top:0}.search-page__genres{padding:10px 24px 14px;flex-wrap:nowrap}.search-page__toolbar{padding:0 24px 14px}.search-page__results{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:20px;padding:0 24px 40px}}.hero-banner{position:relative;height:320px;margin-bottom:var(--space-xl);overflow:hidden}.hero-banner__bg{position:absolute;inset:0}.hero-banner__bg img{width:100%;height:100%;object-fit:cover;filter:blur(2px) brightness(.4)}.hero-banner__overlay{position:absolute;inset:0;background:var(--gradient-hero)}.hero-banner__content{position:absolute;bottom:0;left:0;right:0;padding:var(--space-xl) var(--space-base)}.hero-banner__genre{display:inline-block;padding:3px 10px;background:var(--accent);border-radius:var(--radius-pill);font-size:var(--fs-xs);font-weight:var(--fw-bold);color:#fff;text-transform:uppercase;margin-bottom:var(--space-sm)}.hero-banner__title{font-family:var(--font-reading);font-size:var(--fs-2xl);font-weight:var(--fw-bold);margin-bottom:var(--space-xs)}.hero-banner__hook{font-size:var(--fs-sm);color:var(--text-secondary);margin-bottom:var(--space-base)}.hero-banner__actions{display:flex;gap:var(--space-sm);flex-wrap:wrap}.hero-banner__actions .btn{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;flex-shrink:1;min-width:0}.hero-dots{display:flex;gap:6px;justify-content:center;margin-top:calc(-1 * var(--space-lg));margin-bottom:var(--space-xl);position:relative;z-index:2}.hero-dot{width:6px;height:6px;border-radius:50%;background:var(--text-muted);transition:all var(--transition-base)}.hero-dot.active{width:18px;border-radius:3px;background:var(--primary-light)}.stacked-rail{display:flex;gap:var(--space-md);padding:0 var(--space-base);overflow-x:auto;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch}.stacked-rail__column{display:flex;flex-direction:column;gap:var(--space-sm);min-width:min(85vw,340px);scroll-snap-align:start}.side-info-card{display:flex;align-items:stretch;gap:var(--space-sm);padding:0;border-radius:0;background:transparent;border:none;cursor:pointer}.side-info-card__cover-wrap{position:relative;width:64px;flex-shrink:0}.side-info-card__cover{width:100%;aspect-ratio:3 / 4;border-radius:var(--radius-sm);object-fit:cover}.side-info-card__lang{position:absolute;top:4px;left:4px;padding:2px 6px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--primary-light),var(--primary));color:var(--text-primary);font-size:.5rem;font-weight:var(--fw-semibold);letter-spacing:.4px;text-transform:uppercase}.side-info-card__body{min-width:0;display:flex;flex-direction:column;justify-content:center}.side-info-card__title{font-size:var(--fs-sm);font-weight:var(--fw-bold);line-height:var(--lh-tight);margin:0 0 2px;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.side-info-card__author{font-size:var(--fs-xs);color:var(--text-secondary);margin:0 0 4px;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.side-info-card__hook{font-size:var(--fs-xs);color:var(--text-muted);line-height:var(--lh-normal);margin:0 0 4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.side-info-card__meta{font-size:.625rem;color:var(--text-muted);margin:0}.rating-star{color:#fbbf24;font-weight:var(--fw-bold)}.promo-banner{margin:0 var(--space-base) var(--space-xl);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-xl);display:flex;align-items:center;gap:var(--space-md);border:1px solid var(--border-light)}.promo-banner--fire{background:linear-gradient(135deg,#fb718547,#f973162e,#eab30826)}.promo-banner--royal{background:linear-gradient(135deg,#a855f747,#3b82f629,#06b6d41f)}.promo-banner--aurora{background:linear-gradient(135deg,#2dd4bf3d,#10b9812e,#6366f11f)}.promo-banner__emoji{width:44px;height:44px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:#ffffff1f;font-size:1.4rem}.promo-banner__copy{min-width:0}.promo-banner__title{font-size:var(--fs-md);font-weight:var(--fw-bold);color:var(--text-primary);margin-bottom:2px}.promo-banner__subtitle{font-size:var(--fs-xs);color:var(--text-secondary)}.featured-grid{display:grid;gap:var(--space-md);padding:0 var(--space-base);margin-bottom:var(--space-md)}.featured-grid--trending{grid-template-columns:repeat(3,minmax(0,1fr))}.featured-grid--editors{grid-template-columns:repeat(2,minmax(0,1fr))}.featured-card{position:relative;min-height:160px;border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;border:1px solid var(--border-light)}.featured-card__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1.05)}.featured-card__overlay{position:absolute;inset:0;background:linear-gradient(180deg,#0a0a1426,#080810c7)}.featured-card--hot .featured-card__overlay{background:linear-gradient(180deg,#ff525226,#180707cc)}.featured-card--gold .featured-card__overlay{background:linear-gradient(180deg,#facc1524,#141005d1)}.featured-card--violet .featured-card__overlay{background:linear-gradient(180deg,#a855f71f,#0a0616d1)}.featured-card__content{position:relative;z-index:2;display:flex;flex-direction:column;justify-content:space-between;height:100%;padding:var(--space-sm)}.featured-card__top{display:flex;justify-content:space-between;align-items:center;gap:var(--space-xs)}.featured-card__rank,.featured-card__badge{font-size:.625rem;font-weight:var(--fw-bold);letter-spacing:.4px;border-radius:999px;padding:3px 8px;background:#ffffff24;color:#fff}.featured-card__title{font-size:var(--fs-sm);font-weight:var(--fw-bold);line-height:var(--lh-tight);margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.featured-card__meta{margin:4px 0 0;font-size:.6875rem;color:#ffffffd9}.home-rails{display:flex;flex-direction:column;gap:var(--space-sm)}.rail-section{margin-bottom:var(--space-lg)}.rail-section__rows{display:flex;flex-direction:column;gap:var(--space-sm)}.rail-section .section__header{margin-bottom:var(--space-sm)}.web-podium{display:none}@media(min-width:1024px){.home{max-width:1180px;margin:0 auto}.home-rails{display:none}.web-podium{display:block}.web-podium__stage{margin:0 var(--space-base);border:1px solid var(--border-light);border-radius:var(--radius-xl);background:linear-gradient(180deg,#6c2bd914,#ff2d780d);display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:var(--space-base);align-items:end;padding:var(--space-xl) var(--space-lg) var(--space-lg)}.web-podium__slot{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:flex-end}.web-podium__cover{width:170px;aspect-ratio:9 / 13;border-radius:var(--radius-md);border:1px solid var(--border-light);box-shadow:var(--shadow-md);cursor:pointer}.web-podium__rank{width:100%;margin-top:var(--space-sm);text-align:center;border-radius:var(--radius-md);background:#ff2d781f;color:var(--accent-light);font-size:2.25rem;font-weight:var(--fw-extrabold);line-height:1;padding:14px 0}.web-podium__slot--1 .web-podium__rank{padding:24px 0}.web-podium__slot--2 .web-podium__rank,.web-podium__slot--3 .web-podium__rank{padding:18px 0}.web-podium__list{margin:var(--space-md) var(--space-base) 0;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--space-md)}.web-podium__item{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-md);cursor:pointer;min-height:150px}.web-podium__item-title{font-size:var(--fs-md);margin-bottom:6px;color:var(--text-primary)}.web-podium__item-author{font-size:var(--fs-base);color:var(--text-secondary);margin-bottom:var(--space-sm)}.web-podium__item-hook{font-size:var(--fs-sm);color:var(--text-muted);line-height:var(--lh-normal);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}}.detail{padding-top:0;overflow-x:hidden}.detail__back-btn{position:absolute;top:calc(var(--safe-top) + 10px);left:12px;z-index:5;background:#0006;backdrop-filter:blur(8px)}.detail__hero{position:relative;padding:var(--space-xl) var(--space-base);padding-top:60px;display:flex;gap:var(--space-lg);min-width:0;align-items:flex-end}.detail__hero-bg{position:absolute;inset:0;overflow:hidden}.detail__hero-bg img{width:100%;height:100%;object-fit:cover;filter:blur(30px) saturate(1.5) brightness(.3);transform:scale(1.2)}.detail__hero-bg:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,15,.5),var(--bg-primary))}.detail__cover{width:130px;height:174px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);flex-shrink:0;position:relative;z-index:1}.detail__cover img{width:100%;height:100%;object-fit:cover}.detail__fallback{position:absolute;top:8px;right:8px;padding:4px 9px;border-radius:var(--radius-sm);background:var(--bg-blur);backdrop-filter:blur(8px);font-size:.625rem;font-weight:var(--fw-semibold);color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px}.detail__info{flex:1;min-width:0;position:relative;z-index:1;display:flex;flex-direction:column;justify-content:flex-end}.detail__title{font-family:var(--font-reading);font-size:var(--fs-xl);font-weight:var(--fw-bold);margin-bottom:4px;overflow-wrap:anywhere}.detail__author{font-size:var(--fs-sm);color:var(--text-secondary);margin-bottom:var(--space-sm);overflow-wrap:anywhere}.detail__stats{display:flex;gap:var(--space-base);flex-wrap:wrap;font-size:var(--fs-xs);color:var(--text-muted);margin-bottom:var(--space-sm)}.detail__stat{display:flex;align-items:center;gap:4px}.detail__actions{display:flex;gap:var(--space-sm);flex-wrap:wrap;margin-top:var(--space-sm)}.detail__actions .btn{flex:1 1 calc(50% - var(--space-sm));min-width:0;white-space:normal;padding-inline:12px}.detail__body{padding:var(--space-lg) var(--space-base)}.detail__section-title{font-size:var(--fs-md);font-weight:var(--fw-bold);margin-bottom:var(--space-md)}.detail__synopsis{font-size:var(--fs-base);color:var(--text-secondary);line-height:var(--lh-relaxed);margin-bottom:var(--space-lg);overflow-wrap:anywhere}.detail__tags{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-xl)}.detail__tags .chip{max-width:100%;overflow-wrap:anywhere}.detail__chapter-list{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-xl)}.chapter-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);min-width:0;padding:var(--space-md) var(--space-base);background:var(--bg-card);border-radius:var(--radius-md);transition:background var(--transition-fast);cursor:pointer}.chapter-item:hover{background:var(--bg-card-hover)}.chapter-item__left{display:flex;align-items:center;gap:var(--space-md);min-width:0;flex:1}.chapter-item__num{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);border-radius:var(--radius-sm);font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text-muted)}.chapter-item__title{font-size:var(--fs-sm);font-weight:var(--fw-medium);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chapter-item__lock{color:var(--text-muted);font-size:var(--fs-sm);flex-shrink:0;white-space:nowrap}.chapter-item__lock--coin{color:#fbbf24}.detail__sticky-cta{position:fixed;bottom:calc(var(--nav-height) + var(--safe-bottom) + 12px);left:var(--space-base);right:var(--space-base);z-index:var(--z-sticky)}.reader{min-height:100dvh;background:var(--bg-primary);padding:0;position:relative;user-select:none}.reader--sepia{background:#f4e8c1;color:#3d2b1f}.reader--light{background:#fafafa;color:#1a1a1a}.reader__topbar{position:fixed;top:0;left:0;right:0;height:calc(var(--topbar-height) + var(--safe-top));padding:var(--safe-top) var(--space-base) 0;display:flex;align-items:center;justify-content:space-between;background:#080a12eb;backdrop-filter:blur(20px);z-index:var(--z-sticky);transform:translateY(-100%);transition:transform var(--transition-base);color:#f5f7ff;border-bottom:1px solid rgba(255,255,255,.14)}.reader__topbar.visible{transform:translateY(0)}.reader__topbar-left{display:flex;align-items:center;gap:var(--space-sm)}.reader__chapter-title{font-size:var(--fs-sm);font-weight:var(--fw-semibold);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:inherit}.reader__topbar-right{display:flex;align-items:center;gap:var(--space-xs)}.reader__topbar .btn-icon{color:#f5f7ff;background:#ffffff1f;border:1px solid rgba(255,255,255,.2)}.reader__content{padding:calc(var(--topbar-height) + var(--safe-top) + 4px) var(--space-xl) 80px;width:100%;max-width:none;margin:0;box-sizing:border-box;min-height:100dvh;display:flex;flex-direction:column;justify-content:flex-start}.reader__text{font-family:var(--font-reading);color:inherit}.reader__text p{margin-bottom:1.5em;text-indent:1.5em}.reader__text img,.reader__text video,.reader__text iframe,.reader__text table{max-width:100%;height:auto}.reader__progress{position:fixed;top:0;left:0;height:2px;background:var(--gradient-primary);transition:width var(--transition-fast);z-index:calc(var(--z-sticky) + 1)}.reader__nav-zones{position:fixed;inset:0;z-index:var(--z-base);display:grid;grid-template-columns:1fr 1fr 1fr}.reader__zone{cursor:pointer}.reader__bottom-bar{position:fixed;bottom:0;left:0;right:0;padding:var(--space-base) var(--space-xl) calc(var(--space-base) + var(--safe-bottom));background:#080a12f0;backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.14);transform:translateY(100%);transition:transform var(--transition-base);z-index:var(--z-sticky)}.reader__bottom-bar.visible{transform:translateY(0)}.reader__settings{display:flex;flex-direction:column;gap:var(--space-base)}.reader__setting-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);min-width:0;overflow:hidden}.reader__setting-label{font-size:.75rem;color:#f5f7ffc7;letter-spacing:.3px;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex-shrink:1}.reader__theme-options{display:flex;gap:6px;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px;max-width:220px}.reader__theme-btn{width:30px;height:30px;border-radius:var(--radius-full);border:2px solid var(--border-subtle);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.reader__theme-btn.active{border-color:var(--primary-light);box-shadow:var(--shadow-glow)}.reader__control{display:inline-flex;align-items:center;gap:10px;padding:4px 8px;border-radius:var(--radius-pill);background:#ffffff14;border:1px solid rgba(255,255,255,.16)}.reader__control-btn{width:30px;height:30px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;background:#ffffff1f;color:#f5f7ff;font-weight:var(--fw-bold);transition:background var(--transition-fast),transform var(--transition-fast)}.reader__mode-options{display:inline-flex;gap:8px;padding:4px;border-radius:var(--radius-pill);background:#ffffff14;border:1px solid rgba(255,255,255,.16)}.reader__mode-btn{height:30px;min-width:0;padding:0 10px;border-radius:var(--radius-pill);font-size:var(--fs-xs);font-weight:var(--fw-semibold);color:#f5f7ffc7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1 1 auto}.reader__mode-btn.active{background:#8b5cf647;color:#fff;border:1px solid rgba(139,92,246,.45)}.reader__mode-btn--locked,.reader__mode-btn:disabled{opacity:.55;cursor:not-allowed}.reader__mode-options--compact{gap:4px;padding:3px}.reader__mode-options--compact .reader__mode-btn{min-width:58px;height:28px;padding:0 10px}.reader__control-btn:active{transform:scale(.96)}.reader__control-btn:hover{background:#fff3}.reader__control-value{min-width:34px;text-align:center;font-size:.8125rem;font-weight:var(--fw-semibold);color:#f5f7ff}.reader__theme-btn--dark{background:#0a0a0f}.reader__theme-btn--sepia{background:#f4e8c1}.reader__theme-btn--light{background:#fafafa}.reader__theme-btn--green{background:#c8e6c9}.reader__theme-btn--blue{background:#e3f2fd}.reader__theme-btn--rose{background:#fce4ec}.reader__theme-btn--gray{background:#2a2a2a}.reader--green{background:#c8e6c9;color:#1b5e20}.reader--blue{background:#e3f2fd;color:#0d47a1}.reader--rose{background:#fce4ec;color:#880e4f}.reader--gray{background:#2a2a2a;color:#c8c8c8}.reader__lock-overlay{position:fixed;bottom:0;left:0;right:0;height:72%;background:linear-gradient(180deg,transparent 0%,var(--bg-primary) 30%);z-index:var(--z-dropdown);display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding:var(--space-xl);padding-bottom:calc(var(--space-2xl) + var(--safe-bottom))}.reader__lock-icon{font-size:3rem;margin-bottom:var(--space-base);animation:float 3s ease-in-out infinite}.reader__lock-title{font-size:var(--fs-lg);font-weight:var(--fw-bold);margin-bottom:var(--space-sm)}.reader__lock-subtitle{font-size:var(--fs-sm);color:var(--text-secondary);margin-bottom:var(--space-xl);text-align:center}.reader__lock-options{display:flex;flex-direction:column;gap:var(--space-sm);width:100%;max-width:300px}.library__grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-sm);padding:0 var(--space-sm)}.library__grid .book-card{width:100%;min-width:0}.library__grid .book-card__cover{width:100%;margin-inline:auto}.library__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl);text-align:center;color:var(--text-muted)}.library__empty-icon{font-size:3rem;margin-bottom:var(--space-base)}.library__empty-text{font-size:var(--fs-base)}.profile__header{display:flex;flex-direction:column;align-items:center;padding:var(--space-2xl) var(--space-base);text-align:center}.profile__avatar{width:88px;height:88px;border-radius:var(--radius-full);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;font-size:2rem;margin-bottom:var(--space-base);box-shadow:var(--shadow-glow)}.profile__name{font-size:var(--fs-xl);font-weight:var(--fw-bold);margin-bottom:4px;overflow-wrap:anywhere}.profile__stats{display:flex;gap:var(--space-sm);margin-top:var(--space-lg);width:100%;max-width:340px}.profile__stat{display:flex;flex-direction:column;align-items:center;min-width:0;flex:1}.profile__stat-num{font-size:var(--fs-xl);font-weight:var(--fw-bold);color:var(--primary-light)}.profile__stat-label{font-size:var(--fs-xs);color:var(--text-muted);text-align:center;line-height:1.25;overflow-wrap:anywhere}.profile__section{padding:0 var(--space-base);margin-bottom:var(--space-xl)}.profile__language-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:var(--radius-pill);border:1px solid var(--border-light);background:var(--bg-card);color:var(--text-primary);font-size:var(--fs-xs);font-weight:var(--fw-semibold);max-width:42vw;white-space:normal;text-align:left}.profile__menu-item{display:flex;align-items:center;justify-content:space-between;width:100%;box-sizing:border-box;padding:var(--space-base);margin:0;border:0;border-bottom:1px solid var(--border-subtle);background:transparent;color:var(--text-primary);text-align:left;cursor:pointer;transition:background var(--transition-fast)}.profile__menu-item:hover{background:var(--bg-card)}.profile__menu-left{display:flex;align-items:center;gap:var(--space-md);min-width:0;flex:1}.profile__menu-left span{overflow-wrap:anywhere}.profile__menu-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border-radius:var(--radius-md);font-size:1.1rem}.search-page__search-wrap{padding-top:calc(var(--safe-top) + var(--space-base));padding-bottom:var(--space-xs)}.search-page__filters{padding-top:var(--space-sm)}.search-page__results{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-sm);padding:var(--space-sm)}.search-page__results .book-card{width:100%;min-width:0}.search-page__results .book-card__cover{width:100%;margin-inline:auto}.search-page__trending{padding:var(--space-base)}.search-page__trending-title{font-size:var(--fs-md);font-weight:var(--fw-bold);margin-bottom:var(--space-md)}.search-page__trending-list{display:flex;flex-direction:column;gap:var(--space-sm)}.trending-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-card);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.trending-item:hover{background:var(--bg-card-hover)}.trending-item__rank{font-size:var(--fs-lg);font-weight:var(--fw-extrabold);color:var(--primary-light);width:28px}.trending-item__cover{width:44px;height:60px;border-radius:var(--radius-sm);overflow:hidden}.trending-item__cover img{width:100%;height:100%;object-fit:cover}.trending-item__info{flex:1}.trending-item__title{font-size:var(--fs-sm);font-weight:var(--fw-semibold)}.trending-item__genre{font-size:var(--fs-xs);color:var(--text-muted)}.admin-panel{display:flex;min-height:100dvh;background:#0a0a0f;color:#e0e0e0}.admin-sidebar{width:240px;background:#0f0f14;border-right:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.admin-sidebar__logo{display:flex;align-items:center;gap:12px;padding:24px 20px;border-bottom:1px solid rgba(255,255,255,.06)}.admin-sidebar__logo-icon{font-size:1.8rem}.admin-sidebar__logo-text{font-size:1rem;font-weight:700;line-height:1.3}.admin-sidebar__logo-text small{font-size:.65rem;font-weight:400;color:#ffffff59;text-transform:uppercase;letter-spacing:1.5px}.admin-sidebar__nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:4px}.admin-nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:10px;font-size:.875rem;font-weight:500;color:#ffffff80;cursor:pointer;transition:all .2s ease;border:none;background:none;width:100%;text-align:left;text-decoration:none}.admin-nav-item:hover{color:#fffc;background:#ffffff0d}.admin-nav-item.active{color:#fff;background:#6c2bd933;border:1px solid rgba(108,43,217,.3)}.admin-nav-icon{font-size:1.1rem;width:24px;text-align:center}.admin-sidebar__footer{padding:12px;border-top:1px solid rgba(255,255,255,.06)}.admin-main{flex:1;margin-left:240px;min-height:100dvh;display:flex;flex-direction:column}.admin-topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:20px 32px;background:#0a0a0fd9;backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.06)}.admin-topbar__title{font-size:1.3rem;font-weight:700}.admin-content{flex:1;padding:24px 32px 60px}.admin-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:10px;font-size:.8125rem;font-weight:600;cursor:pointer;border:1px solid transparent;transition:all .2s ease;white-space:nowrap}.admin-btn--primary{background:linear-gradient(135deg,#6c2bd9,#8b5cf6);color:#fff;border-color:#6c2bd980}.admin-btn--primary:hover{background:linear-gradient(135deg,#7c3aed,#a78bfa);box-shadow:0 4px 20px #6c2bd966}.admin-btn--ghost{background:#ffffff0d;color:#ffffffb3;border-color:#ffffff1a}.admin-btn--ghost:hover{background:#ffffff1a;color:#fff}.admin-btn--danger{background:#ef444426;color:#ef4444;border-color:#ef444433}.admin-btn--danger:hover{background:#ef444440}.admin-btn--sm{padding:6px 12px;font-size:.75rem}.admin-btn--lg{padding:14px 28px;font-size:.9375rem}.admin-btn--icon{padding:6px;width:32px;height:32px;justify-content:center}.admin-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.admin-stat-card{display:flex;align-items:center;gap:16px;padding:20px;background:#ffffff08;border-radius:14px;border:1px solid rgba(255,255,255,.06);transition:border-color .3s ease}.admin-stat-card:hover{border-color:#ffffff1f}.admin-stat-card__icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem}.admin-stat-card__value{font-size:1.5rem;font-weight:800}.admin-stat-card__label{font-size:.75rem;color:#fff6;margin-top:2px}.admin-card{background:#ffffff08;border-radius:14px;border:1px solid rgba(255,255,255,.06);padding:24px;margin-bottom:24px}.admin-card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.admin-card__header h3{font-size:.9375rem;font-weight:700}.admin-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:.6875rem;font-weight:600;background:#ffffff14;color:#fff9}.admin-badge--green{background:#22c55e26;color:#22c55e}.admin-badge--blue{background:#3b82f626;color:#3b82f6}.admin-badge--purple{background:#a855f726;color:#a855f7}.admin-charts-row{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}.admin-genre-bars{display:flex;flex-direction:column;gap:12px}.admin-genre-bar__label{display:flex;justify-content:space-between;font-size:.8125rem;margin-bottom:6px;color:#fff9}.admin-genre-bar__track{height:6px;border-radius:3px;background:#ffffff0f;overflow:hidden}.admin-genre-bar__fill{height:100%;border-radius:3px;transition:width .8s ease}.admin-engagement-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.admin-engagement-item{padding:14px;background:#ffffff05;border-radius:10px;border:1px solid rgba(255,255,255,.04)}.admin-engagement-item__header{display:flex;justify-content:space-between;font-size:.8125rem;margin-bottom:10px;color:#ffffff80}.admin-top-books{display:flex;flex-direction:column;gap:8px}.admin-top-book{display:flex;align-items:center;gap:14px;padding:12px;border-radius:10px;transition:background .2s ease}.admin-top-book:hover{background:#ffffff0a}.admin-top-book__rank{font-size:1rem;font-weight:800;color:#a78bfa;width:28px;text-align:center}.admin-top-book__cover{width:40px;height:54px;border-radius:6px;overflow:hidden}.admin-top-book__cover img{width:100%;height:100%;object-fit:cover}.admin-top-book__info{flex:1}.admin-top-book__title{font-size:.875rem;font-weight:600}.admin-top-book__meta{font-size:.75rem;color:#fff6;margin-top:2px}.admin-filters{display:flex;gap:12px;margin-bottom:16px}.admin-search{flex:1;display:flex;align-items:center;gap:10px;padding:0 16px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:10px;transition:border-color .2s}.admin-search:focus-within{border-color:#6c2bd980;box-shadow:0 0 0 3px #6c2bd91a}.admin-search__icon{font-size:.9rem;opacity:.4}.admin-search__input{flex:1;background:none;border:none;outline:none;color:#fff;font-size:.875rem;padding:12px 0}.admin-search__input::placeholder{color:#ffffff4d}.admin-select{padding:10px 16px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:10px;color:#fff;font-size:.875rem;cursor:pointer;outline:none}.admin-select:focus{border-color:#6c2bd980}.admin-books-count{font-size:.8125rem;color:#ffffff59;margin-bottom:16px}.admin-books-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px}.admin-book-card{background:#ffffff08;border-radius:14px;border:1px solid rgba(255,255,255,.06);overflow:hidden;transition:all .3s ease}.admin-book-card:hover{border-color:#6c2bd94d;transform:translateY(-4px);box-shadow:0 12px 40px #0006}.admin-book-card__cover{position:relative;aspect-ratio:9 / 16;overflow:hidden}.admin-book-card__cover img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.admin-book-card:hover .admin-book-card__cover img{transform:scale(1.05)}.admin-book-card__overlay{position:absolute;inset:0;background:#000000b3;backdrop-filter:blur(4px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;opacity:0;transition:opacity .3s ease}.admin-book-card:hover .admin-book-card__overlay{opacity:1}.admin-book-card__body{padding:14px}.admin-book-card__title{font-size:.875rem;font-weight:600;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-book-card__author{font-size:.75rem;color:#fff6;margin-bottom:8px}.admin-book-card__meta{display:flex;align-items:center;gap:8px;font-size:.6875rem;color:#ffffff80;margin-bottom:8px}.admin-book-card__status{display:flex;gap:6px;flex-wrap:wrap}.admin-form{max-width:1000px}.admin-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}.admin-form-col{display:flex;flex-direction:column;gap:0}.admin-form-group{margin-bottom:16px}.admin-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.admin-label{display:block;font-size:.8125rem;font-weight:600;color:#fff9;margin-bottom:8px}.admin-label small{font-weight:400;color:#ffffff4d}.admin-input{width:100%;padding:11px 14px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:10px;color:#fff;font-size:.875rem;outline:none;transition:all .2s ease}.admin-input:focus{border-color:#6c2bd999;box-shadow:0 0 0 3px #6c2bd926;background:#ffffff0f}.admin-input::placeholder{color:#fff3}.admin-textarea{min-height:120px;resize:vertical;font-family:inherit;line-height:1.6}.admin-form-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:16px;border-top:1px solid rgba(255,255,255,.06)}.admin-chapters-list{display:flex;flex-direction:column;gap:6px;max-height:500px;overflow-y:auto}.admin-chapter-row{display:flex;align-items:center;gap:8px;padding:8px 10px;background:#ffffff08;border-radius:8px;border:1px solid rgba(255,255,255,.04);transition:border-color .2s}.admin-chapter-row:hover{border-color:#ffffff1a}.admin-chapter-row__drag{color:#fff3;cursor:grab;font-size:.875rem;user-select:none;width:16px}.admin-chapter-row__num{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#6c2bd926;color:#a78bfa;border-radius:6px;font-size:.75rem;font-weight:700;flex-shrink:0}.admin-chapter-row__title{flex:1;padding:6px 10px!important;font-size:.8125rem!important;min-width:0}.admin-chapter-row__lock{display:flex;align-items:center;cursor:pointer;opacity:.5;transition:opacity .2s}.admin-chapter-row__lock:has(input:checked){opacity:1}.admin-chapter-row__lock input{display:none}.admin-chapter-row__price{width:60px!important;padding:6px 8px!important;font-size:.75rem!important;text-align:center}.admin-chapter-row__price:disabled{opacity:.25}.admin-editor-overlay{position:fixed;inset:0;z-index:200;background:#000000b3;backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s ease}.admin-editor-overlay.open{opacity:1;pointer-events:all}.admin-editor-panel{width:90%;max-width:800px;height:80vh;background:#111118;border-radius:16px;border:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;box-shadow:0 24px 80px #0009;transform:translateY(20px) scale(.97);transition:transform .3s ease}.admin-editor-overlay.open .admin-editor-panel{transform:translateY(0) scale(1)}.admin-editor-panel__header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}.admin-editor-panel__header h3{font-size:1rem;font-weight:700}.admin-editor-panel__actions{display:flex;align-items:center;gap:12px}.admin-editor-panel__wordcount{font-size:.75rem;color:#ffffff59}.admin-editor-panel__textarea{flex:1;margin:16px 24px 24px;padding:20px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:12px;color:#fff;font-size:.9375rem;line-height:1.8;font-family:inherit;resize:none;outline:none;transition:border-color .2s}.admin-editor-panel__textarea:focus{border-color:#6c2bd980;box-shadow:0 0 0 3px #6c2bd91a}.admin-editor-panel__textarea::placeholder{color:#fff3}.admin-empty-chapters{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;color:#ffffff4d;font-size:.8125rem}.admin-mini-stat{padding:12px;background:#ffffff08;border-radius:10px;text-align:center}.admin-mini-stat__label{font-size:.6875rem;color:#ffffff59;margin-bottom:4px}.admin-mini-stat__value{font-size:1.1rem;font-weight:700}@media(max-width:768px){.admin-sidebar{display:none}.admin-main{margin-left:0}.admin-stats-grid{grid-template-columns:repeat(2,1fr)}.admin-charts-row,.admin-engagement-grid,.admin-form-grid{grid-template-columns:1fr}.admin-books-grid{grid-template-columns:repeat(2,1fr)}.admin-content,.admin-topbar{padding:16px}}
