.error-boundary{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-xl);background:var(--color-background)}.error-boundary__content{max-width:500px;text-align:center}.error-boundary__title{font-size:var(--font-size-xxl);font-weight:700;color:var(--color-text);margin-bottom:var(--space-md)}.error-boundary__message{font-size:var(--font-size-lg);color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--space-xl)}.error-boundary__details{text-align:left;margin-bottom:var(--space-xl);background:var(--color-surface);padding:var(--space-md);border-radius:var(--radius-md);border:1px solid var(--color-border)}.error-boundary__details summary{cursor:pointer;font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--space-sm)}.error-boundary__error{font-size:var(--font-size-sm);color:var(--color-text);overflow-x:auto;white-space:pre-wrap;word-break:break-word}.error-boundary__actions{display:flex;gap:var(--space-md);justify-content:center}.error-boundary__button{padding:var(--space-md) var(--space-xl);font-size:var(--font-size-md);font-weight:600;border-radius:var(--radius-full);background:var(--color-surface);color:var(--color-text);border:2px solid var(--color-border);transition:transform var(--transition-fast),box-shadow var(--transition-base)}.error-boundary__button:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-accent)}.error-boundary__button:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.error-boundary__button--primary{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.error-boundary__button--primary:hover{border-color:var(--color-accent)}.offline-indicator{position:fixed;top:var(--space-md);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);background:#ff9800;color:#fff;font-size:var(--font-size-sm);font-weight:600;border-radius:var(--radius-full);box-shadow:var(--shadow-lg);z-index:10000;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.offline-indicator__icon{font-size:var(--font-size-lg)}.welcome-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-xl);background:var(--color-background)}.welcome-screen__content{max-width:500px;text-align:center}.welcome-screen__illustration{margin:0 auto var(--space-xl);display:flex;justify-content:center}.welcome-screen__title{font-size:var(--font-size-xxl);font-weight:600;color:var(--color-text-primary);margin:0 0 var(--space-md);line-height:1.2}.welcome-screen__description{font-size:var(--font-size-lg);color:var(--color-text-secondary);line-height:1.6;margin:0 0 var(--space-xl)}.welcome-screen__actions{display:flex;flex-direction:column;gap:var(--space-md);margin-bottom:var(--space-xl)}.welcome-screen__button{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);font-size:var(--font-size-md);font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);font-family:var(--font-family);min-height:52px}.welcome-screen__button:disabled{opacity:.6;cursor:not-allowed}.welcome-screen__button--primary{background:var(--color-accent);color:#fff}.welcome-screen__button--primary:hover:not(:disabled){background:var(--color-accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px var(--color-accent-glow)}.welcome-screen__button--primary:active:not(:disabled){transform:translateY(0)}.welcome-screen__button--secondary{background:var(--color-surface);color:var(--color-text-primary);border:2px solid var(--color-border)}.welcome-screen__button--secondary:hover:not(:disabled){background:var(--color-surface-raised);border-color:var(--color-accent);transform:translateY(-1px)}.welcome-screen__button--secondary:active:not(:disabled){transform:translateY(0)}.welcome-screen__button-icon{font-size:1.25em;line-height:1}.welcome-screen__spinner{display:inline-block;width:16px;height:16px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.welcome-screen__formats{display:flex;flex-direction:column;gap:var(--space-sm);align-items:center}.welcome-screen__formats-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.welcome-screen__format-tags{display:flex;gap:var(--space-sm)}.welcome-screen__format-tag{padding:var(--space-xs) var(--space-md);background:var(--color-surface);color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600;font-family:Courier New,monospace}@media(max-width:640px){.welcome-screen{padding:var(--space-lg)}.welcome-screen__title{font-size:var(--font-size-xl)}.welcome-screen__description,.welcome-screen__button{font-size:var(--font-size-md)}}@media(prefers-reduced-motion:reduce){.welcome-screen__button{transition:none}.welcome-screen__button:hover:not(:disabled){transform:none}.welcome-screen__spinner{animation:none;border-top-color:var(--color-text-secondary)}}.library{max-width:600px;margin:0 auto;padding:var(--space-lg);min-height:100vh}.library__header{text-align:center;padding:var(--space-xxl) 0 var(--space-xl)}.library__title{font-size:var(--font-size-xxl);font-weight:600;margin-bottom:var(--space-sm);letter-spacing:-.01em}.library__tagline{color:var(--color-text-secondary);font-size:var(--font-size-md);letter-spacing:.02em}.library__upload{text-align:center;margin-bottom:var(--space-xl)}.library__upload-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);background:var(--color-accent);color:var(--color-background);font-size:var(--font-size-lg);font-weight:600;border-radius:var(--radius-lg);min-height:56px;min-width:200px;transition:background var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-base);box-shadow:0 2px 8px var(--color-accent-glow)}.library__upload-btn:hover:not(:disabled){background:var(--color-accent-hover);transform:translateY(-2px);box-shadow:0 6px 20px var(--color-accent-glow)}.library__upload-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 4px var(--color-accent-glow)}.library__upload-btn:disabled{opacity:.6;cursor:not-allowed}.library__upload-hint{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-top:var(--space-sm)}.library__file-input{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}.library__error{background:#fde8e8;color:#9b1c1c;padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);margin-bottom:var(--space-lg);font-size:var(--font-size-md);border-left:4px solid #9b1c1c;line-height:1.6}[data-theme=undergrowth] .library__error,[data-theme=nightshade] .library__error{background:#3b1c1c;color:#f8b4b4;border-left-color:#f8b4b4}.library__empty-state{text-align:center;padding:var(--space-xxl) var(--space-lg);border:2px dashed var(--color-border);border-radius:var(--radius-lg);margin-top:var(--space-lg)}.library__empty{color:var(--color-text-secondary);font-size:var(--font-size-lg);line-height:1.8;margin-bottom:var(--space-md)}.library__demo-btn{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-md) var(--space-xl);background:var(--color-accent);color:#fff;font-size:var(--font-size-lg);font-weight:600;border-radius:var(--radius-full);transition:transform var(--transition-fast),box-shadow var(--transition-base);box-shadow:var(--shadow-md);margin-bottom:var(--space-sm)}.library__demo-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.library__demo-btn:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.library__demo-hint{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-xs)}.library__list{list-style:none;display:flex;flex-direction:column;gap:var(--space-sm)}.library__item{display:flex;align-items:center;gap:var(--space-sm)}.library__book{flex:1;display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-md) var(--space-lg);background:var(--color-surface);border-radius:var(--radius-md);text-align:left;min-height:56px;transition:box-shadow var(--transition-base),transform var(--transition-fast),background var(--transition-fast);border:1px solid transparent}.library__book:hover{box-shadow:var(--shadow-colored);transform:translateY(-1px);border-color:var(--color-border)}.library__book:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.library__book--recent{border-left:4px solid var(--color-accent);background:var(--color-surface-raised)}.library__book-info{display:flex;flex-direction:column;gap:2px}.library__book-title{font-size:var(--font-size-md);font-weight:600}.library__book-author{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.library__continue{font-size:var(--font-size-sm);color:var(--color-accent);font-weight:600}.library__progress{height:4px;background:var(--color-border);border-radius:var(--radius-full);overflow:hidden;margin-top:var(--space-xs)}.library__progress-bar{height:100%;background:linear-gradient(90deg,var(--color-accent),var(--color-accent-hover));border-radius:var(--radius-full);transition:width .3s ease}.library__delete{width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl);color:var(--color-text-secondary);border-radius:var(--radius-full);flex-shrink:0;opacity:.4;transition:opacity var(--transition-fast),background var(--transition-fast),color var(--transition-fast)}.library__item:hover .library__delete{opacity:.7}.library__delete:hover{background:var(--color-surface);color:var(--color-text-primary);opacity:1}.library__header-main{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.library__streak{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:linear-gradient(135deg,#ff6b6b,#ff8e53);border-radius:var(--radius-full);color:#fff;font-weight:600;font-size:.9rem;box-shadow:0 2px 8px #ff6b6b4d;animation:streakPulse 2s ease-in-out infinite}.library__streak-emoji{font-size:1.2rem;animation:flameFlicker 1s ease-in-out infinite alternate}.library__streak-text{white-space:nowrap}@keyframes streakPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes flameFlicker{0%,to{transform:scale(1) rotate(-2deg)}50%{transform:scale(1.1) rotate(2deg)}}@media(max-width:600px){.library__header-main{flex-direction:column}.library__streak{align-self:flex-start}}.reader{display:flex;flex-direction:column;height:100vh;overflow:hidden}.reader__header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-surface);border-bottom:1px solid var(--color-border);flex-shrink:0;min-height:56px;box-shadow:0 1px 3px #0000000a}.reader__back,.reader__settings-btn,.reader__theme-btn,.reader__bookmark-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);flex-shrink:0;color:var(--color-text-primary);transition:background var(--transition-fast),transform var(--transition-fast)}.reader__back:hover,.reader__settings-btn:hover,.reader__theme-btn:hover{background:var(--color-border);transform:scale(1.05)}.reader__back:active,.reader__settings-btn:active,.reader__theme-btn:active{transform:scale(.95)}.reader__theme-picker{position:relative}.reader__theme-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9}.reader__theme-dropdown{position:absolute;top:100%;right:0;margin-top:var(--space-xs);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:10;min-width:180px;padding:var(--space-xs);animation:dropdown-in .2s cubic-bezier(.2,0,0,1);transform-origin:top right}@keyframes dropdown-in{0%{opacity:0;transform:scale(.95) translateY(-4px)}to{opacity:1;transform:scale(1) translateY(0)}}.reader__theme-option{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-size:var(--font-size-md);color:var(--color-text-primary);text-align:left;min-height:44px;transition:background var(--transition-fast)}.reader__theme-option:hover{background:var(--color-border)}.reader__theme-option--active{font-weight:600;background:var(--color-accent-glow)}.reader__theme-swatch{width:24px;height:24px;border-radius:var(--radius-full);border:2px solid var(--color-border);flex-shrink:0;box-shadow:inset 0 1px 3px #00000026;transition:transform var(--transition-fast)}.reader__theme-option:hover .reader__theme-swatch{transform:scale(1.1)}.reader__title{flex:1;font-size:var(--font-size-md);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}.text-display{flex:1;overflow-y:auto;padding:var(--space-xl) var(--space-md);scroll-behavior:smooth;-webkit-overflow-scrolling:touch;background:var(--color-background)}.text-display__content{margin:0 auto;padding:var(--space-lg) var(--space-lg) var(--space-xxl);max-width:calc(var(--max-line-width) + var(--space-xl) * 2);background:var(--color-surface-raised);border-radius:var(--radius-lg);box-shadow:var(--shadow-colored);min-height:40vh}.word{transition:background var(--highlight-transition),opacity var(--highlight-transition),box-shadow var(--highlight-transition);border-radius:3px;padding:1px 2px;margin:0 -1px}.word--active{background:var(--highlight-bg);box-shadow:0 0 0 2px var(--highlight-glow),0 1px 4px var(--highlight-glow)}.word--spoken{opacity:var(--text-spoken-opacity)}.text-display__resync{position:fixed;bottom:120px;left:50%;transform:translate(-50%);padding:var(--space-sm) var(--space-lg);background:var(--color-accent);color:var(--color-background);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600;box-shadow:var(--shadow-md),0 0 0 4px var(--color-accent-glow);z-index:10;animation:resync-in .3s cubic-bezier(.2,0,0,1);transition:background var(--transition-fast),transform var(--transition-fast)}.text-display__resync:hover{background:var(--color-accent-hover);transform:translate(-50%) scale(1.04)}.text-display__resync:active{transform:translate(-50%) scale(.97)}@keyframes resync-in{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.player{flex-shrink:0;padding:var(--space-md) var(--space-md) var(--space-lg);background:var(--color-surface);border-top:1px solid var(--color-border);box-shadow:0 -2px 8px #0000000a}.player__row{display:flex;align-items:center;justify-content:center;gap:var(--space-lg);margin-bottom:var(--space-sm)}.player__btn{display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);color:var(--color-text-primary)}.player__btn--play{width:56px;height:56px;background:var(--color-accent);color:var(--color-background);box-shadow:0 2px 8px var(--color-accent-glow);transition:background var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-base)}.player__btn--play:hover{background:var(--color-accent-hover);transform:scale(1.06);box-shadow:0 4px 14px var(--color-accent-glow),0 0 0 4px var(--color-accent-glow)}.player__btn--play:active{transform:scale(.95)}.player__btn--secondary{width:48px;height:48px;transition:background var(--transition-fast),transform var(--transition-fast),color var(--transition-fast)}.player__btn--secondary:hover{background:var(--color-border);color:var(--color-accent);transform:scale(1.08)}.player__btn--secondary:active{transform:scale(.93)}.player__info{display:flex;justify-content:center;align-items:center;gap:var(--space-lg)}.player__speed,.player__chapter{font-size:var(--font-size-sm);color:var(--color-text-secondary);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);transition:background var(--transition-fast),color var(--transition-fast);letter-spacing:.02em}.player__speed:hover,.player__chapter:hover{background:var(--color-border);color:var(--color-text-primary)}.reader__chapter-list{position:fixed;bottom:130px;left:50%;transform:translate(-50%);width:90%;max-width:400px;max-height:300px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:20;overflow:hidden;animation:chapter-list-in .25s cubic-bezier(.2,0,0,1)}@keyframes chapter-list-in{0%{opacity:0;transform:translate(-50%) translateY(12px) scale(.97)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.reader__chapter-list-inner{overflow-y:auto;max-height:300px;padding:var(--space-sm)}.reader__chapter-item{display:block;width:100%;padding:var(--space-sm) var(--space-md);text-align:left;font-size:var(--font-size-md);border-radius:var(--radius-sm);color:var(--color-text-primary);transition:background var(--transition-fast)}.reader__chapter-item:hover{background:var(--color-border)}.reader__chapter-item--active{background:var(--color-accent);color:var(--color-background);font-weight:600}.reader__chapter-item--active:hover{background:var(--color-accent-hover)}.settings-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000;z-index:100;display:flex;align-items:flex-end;animation:overlay-in .3s ease forwards}@keyframes overlay-in{to{background:#0006}}.settings-drawer{width:100%;max-height:80vh;background:var(--color-background);border-radius:var(--radius-lg) var(--radius-lg) 0 0;overflow-y:auto;animation:drawer-slide-up .35s cubic-bezier(.2,0,0,1);box-shadow:0 -4px 24px #0000001f}@keyframes drawer-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.settings-drawer__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);padding-top:var(--space-lg);border-bottom:1px solid var(--color-border);position:relative}.settings-drawer__header:before{content:"";position:absolute;top:var(--space-sm);left:50%;transform:translate(-50%);width:36px;height:4px;background:var(--color-border);border-radius:var(--radius-full)}.settings-drawer__header h2{font-size:var(--font-size-lg);font-weight:600}.settings-drawer__close{width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl);color:var(--color-text-secondary);border-radius:var(--radius-full);transition:background var(--transition-fast),color var(--transition-fast),transform var(--transition-fast)}.settings-drawer__close:hover{background:var(--color-surface);color:var(--color-text-primary);transform:scale(1.1)}.settings-drawer__close:active{transform:scale(.9)}.settings-drawer__body{padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-lg)}.settings-field{border:none}.settings-field legend{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);letter-spacing:.05em;text-transform:uppercase;margin-bottom:var(--space-sm)}.settings-field__options{display:flex;flex-wrap:wrap;gap:var(--space-sm);align-items:center}.settings-field__hint{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-style:italic}.settings-chip{padding:var(--space-sm) var(--space-md);background:var(--color-surface);border:2px solid transparent;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);transition:border-color var(--transition-fast),background var(--transition-fast),color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.settings-chip:hover{border-color:var(--color-border);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.settings-chip--active{border-color:var(--color-accent);background:var(--color-accent);color:var(--color-background);box-shadow:0 2px 8px var(--color-accent-glow)}.settings-chip--active:hover{transform:translateY(-1px);box-shadow:0 4px 12px var(--color-accent-glow)}.settings-swatch{width:44px;height:44px;border-radius:var(--radius-full);border:3px solid transparent;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 2px 4px #0000001f;transition:border-color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.settings-swatch:hover{transform:scale(1.12);box-shadow:inset 0 2px 4px #0000001f,0 2px 8px #0000001a}.settings-swatch--active{border-color:var(--color-accent);box-shadow:inset 0 2px 4px #0000001f,0 0 0 3px var(--color-accent-glow)}.settings-field__stepper{display:flex;align-items:center;gap:var(--space-md)}.settings-stepper-btn{width:44px;height:44px;background:var(--color-surface);border-radius:var(--radius-full);font-size:var(--font-size-md);font-weight:600;display:flex;align-items:center;justify-content:center;color:var(--color-text-primary);transition:background var(--transition-fast),transform var(--transition-fast)}.settings-stepper-btn:hover{background:var(--color-border);transform:scale(1.08)}.settings-stepper-btn:active{transform:scale(.92)}.settings-stepper-value{font-size:var(--font-size-md);font-weight:600;min-width:60px;text-align:center}.settings-select{width:100%;padding:var(--space-sm) var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-md);color:var(--color-text-primary);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='%236B5C48'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.settings-select:hover{border-color:var(--color-accent)}.settings-select:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-glow);outline:none}.settings-input{flex:1;padding:var(--space-sm) var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-md);color:var(--color-text-primary);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);min-width:0}.settings-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-glow);outline:none}.settings-input:disabled{opacity:.6}.settings-field__activate{display:flex;gap:var(--space-sm);align-items:center}.settings-chip--action{white-space:nowrap;flex-shrink:0}.settings-chip--action:disabled{opacity:.5;cursor:not-allowed}.settings-field__error{margin-top:var(--space-xs);font-size:var(--font-size-sm);color:#c0392b}.settings-field__invite-link{display:inline;margin-top:var(--space-xs);padding:0;border:none;background:none;color:var(--text-secondary, #888);font-size:var(--font-size-sm);text-decoration:underline;cursor:pointer}.settings-field__invite-link:hover{color:var(--text-primary, #555)}.settings-field__status{display:flex;align-items:center;gap:var(--space-sm)}.settings-badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600}.settings-badge--success{background:#27ae6026;color:#27ae60}.swipe-indicator{position:fixed;top:50%;transform:translateY(-50%);font-size:4rem;color:var(--accent-color);opacity:.6;pointer-events:none;animation:swipeFade .3s ease-out;z-index:100}.swipe-indicator--left{right:2rem}.swipe-indicator--right{left:2rem}@keyframes swipeFade{0%{opacity:0;transform:translateY(-50%) scale(.8)}to{opacity:.6;transform:translateY(-50%) scale(1)}}.tap-ripple{position:fixed;width:100px;height:100px;margin-left:-50px;margin-top:-50px;border-radius:50%;background:radial-gradient(circle,rgba(var(--accent-rgb),.3) 0%,transparent 70%);pointer-events:none;animation:rippleEffect .6s ease-out;z-index:100}@keyframes rippleEffect{0%{transform:scale(0);opacity:1}to{transform:scale(2);opacity:0}}@media(max-width:768px){.swipe-indicator{font-size:3rem}.swipe-indicator--left{right:1rem}.swipe-indicator--right{left:1rem}}.gesture-hint{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:9999;padding:var(--space-xl);animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.gesture-hint__content{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-xl);max-width:400px;text-align:center;box-shadow:var(--shadow-xl)}.gesture-hint__title{font-size:var(--font-size-xxl);font-weight:700;color:var(--color-text);margin-bottom:var(--space-lg)}.gesture-hint__tips{display:flex;flex-direction:column;gap:var(--space-md);margin-bottom:var(--space-xl)}.gesture-hint__tip{display:flex;align-items:center;gap:var(--space-md);font-size:var(--font-size-lg);color:var(--color-text)}.gesture-hint__icon{font-size:var(--font-size-xxl);min-width:50px}.gesture-hint__dismiss{padding:var(--space-md) var(--space-xl);background:var(--color-accent);color:#fff;font-size:var(--font-size-lg);font-weight:600;border-radius:var(--radius-full);box-shadow:var(--shadow-md)}.gesture-hint__dismiss:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.reader__bookmark-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);flex-shrink:0;color:var(--color-text-secondary);transition:background var(--transition-fast),color var(--transition-fast),transform var(--transition-fast)}.reader__bookmark-btn:hover{background:var(--color-border);transform:scale(1.05)}.reader__bookmark-btn:active{transform:scale(.95)}.reader__bookmark-btn--active{color:var(--color-accent)}.reader__bookmark-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:19}.reader__bookmark-list{position:fixed;top:60px;right:var(--space-md);width:300px;max-width:calc(100vw - var(--space-lg));max-height:380px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:20;overflow:hidden;display:flex;flex-direction:column;animation:chapter-list-in .2s cubic-bezier(.2,0,0,1)}.reader__bookmark-list-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border);flex-shrink:0}.reader__bookmark-list-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.reader__bookmark-add-btn{font-size:var(--font-size-sm);color:var(--color-accent);font-weight:500;padding:2px 8px;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.reader__bookmark-add-btn:hover{background:var(--color-border)}.reader__bookmark-list-inner{overflow-y:auto;flex:1;padding:var(--space-xs)}.reader__bookmark-empty{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:center;padding:var(--space-md)}.reader__bookmark-item{display:flex;align-items:stretch;border-radius:var(--radius-sm);overflow:hidden;margin-bottom:2px}.reader__bookmark-item--current{background:color-mix(in srgb,var(--color-accent) 12%,transparent)}.reader__bookmark-item-body{flex:1;display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:var(--space-sm) var(--space-sm);text-align:left;border-radius:var(--radius-sm) 0 0 var(--radius-sm);transition:background var(--transition-fast)}.reader__bookmark-item-body:hover{background:var(--color-border)}.reader__bookmark-item-chapter{font-size:11px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em}.reader__bookmark-item-preview{font-size:var(--font-size-sm);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}.reader__bookmark-item-delete{width:36px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--color-text-secondary);transition:background var(--transition-fast),color var(--transition-fast)}.reader__bookmark-item-delete:hover{background:var(--color-border);color:var(--color-text-primary)}.feedback-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.feedback-modal{background:var(--bg-primary);border-radius:12px;box-shadow:0 4px 20px #00000026;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;animation:feedbackModalSlideIn .2s ease-out}@keyframes feedbackModalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.feedback-modal__header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-color)}.feedback-modal__header h2{margin:0;font-size:1.5rem;color:var(--text-primary)}.feedback-modal__close{background:none;border:none;font-size:2rem;line-height:1;color:var(--text-secondary);cursor:pointer;padding:0;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.feedback-modal__close:hover{background:var(--hover-bg)}.feedback-modal__form{padding:1.5rem}.feedback-modal__section{margin-bottom:1.5rem}.feedback-modal__section:last-of-type{margin-bottom:0}.feedback-modal__label{display:block;font-weight:500;color:var(--text-primary);margin-bottom:.75rem;font-size:.95rem}.feedback-sentiments{display:flex;gap:.75rem}.feedback-sentiment{flex:1;background:var(--bg-secondary);border:2px solid transparent;border-radius:8px;padding:1rem .5rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;cursor:pointer;transition:all .2s}.feedback-sentiment:hover{background:var(--hover-bg);transform:translateY(-2px)}.feedback-sentiment--active{border-color:var(--accent-color);background:var(--accent-bg)}.feedback-sentiment__emoji{font-size:2rem;line-height:1}.feedback-sentiment__label{font-size:.85rem;color:var(--text-secondary);font-weight:500}.feedback-sentiment--active .feedback-sentiment__label{color:var(--accent-color)}.feedback-modal__textarea{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-family:inherit;font-size:.95rem;line-height:1.5;resize:vertical;transition:border-color .2s}.feedback-modal__textarea:focus{outline:none;border-color:var(--accent-color)}.feedback-modal__textarea::placeholder{color:var(--text-tertiary)}.feedback-modal__checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem;color:var(--text-primary)}.feedback-modal__checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.feedback-modal__error{padding:.75rem;background:#fee;border:1px solid #fcc;border-radius:6px;color:#c33;font-size:.9rem;margin-bottom:1rem}.feedback-modal__actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.feedback-modal__button{padding:.75rem 1.5rem;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.feedback-modal__button:disabled{opacity:.5;cursor:not-allowed}.feedback-modal__button--secondary{background:var(--bg-secondary);color:var(--text-primary)}.feedback-modal__button--secondary:hover:not(:disabled){background:var(--hover-bg)}.feedback-modal__button--primary{background:var(--accent-color);color:#fff}.feedback-modal__button--primary:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.feedback-modal__success{padding:3rem 1.5rem;text-align:center}.feedback-modal__success-icon{width:64px;height:64px;border-radius:50%;background:#4caf50;color:#fff;font-size:2.5rem;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;animation:successPop .4s ease-out}@keyframes successPop{0%{transform:scale(0)}50%{transform:scale(1.1)}to{transform:scale(1)}}.feedback-modal__success p{color:var(--text-primary);font-size:1.1rem;font-weight:500;margin:0 0 .5rem}.feedback-modal__success-subtext{color:var(--text-secondary);font-size:.9rem;font-weight:400}@media(max-width:600px){.feedback-modal{max-width:100%;max-height:100vh;border-radius:0}.feedback-sentiments{flex-direction:column}.feedback-sentiment{flex-direction:row;justify-content:flex-start;padding:.75rem 1rem}.feedback-sentiment__emoji{font-size:1.5rem}}.onboarding-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem;animation:overlayFadeIn .3s ease-out}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.onboarding{background:#f8f1e4;border-radius:16px;max-width:500px;width:100%;padding:2rem;box-shadow:0 8px 32px #0000004d;position:relative;animation:onboardingSlideUp .4s ease-out}@keyframes onboardingSlideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.onboarding__skip{position:absolute;top:1rem;right:1rem;background:transparent;border:none;color:#6b6456;font-size:.9rem;cursor:pointer;padding:.5rem;border-radius:4px;transition:all .2s}.onboarding__skip:hover{background:#0000000d;color:#2c2416}.onboarding__content{text-align:center;padding:1rem 0 1.5rem}.onboarding__emoji{font-size:4rem;margin-bottom:1rem;animation:emojiFloat 2s ease-in-out infinite}@keyframes emojiFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.onboarding__title{font-size:1.75rem;font-weight:700;color:#2c2416;margin:0 0 .5rem}.onboarding__description{font-size:1rem;color:#6b6456;margin:0 0 1.5rem;line-height:1.5}.onboarding__quick-tips{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem;text-align:left}.onboarding__tip{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#efe8d9;border-radius:8px;font-size:.95rem;color:#2c2416}.onboarding__tip-icon{font-size:1.5rem;flex-shrink:0}.onboarding__tip-text{line-height:1.4}.onboarding__btn{width:100%;padding:.875rem 2rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.onboarding__btn--primary{background:#8b7355;color:#fff}.onboarding__btn--primary:hover{opacity:.9;transform:translateY(-2px);box-shadow:0 4px 12px #0003}@media(max-width:600px){.onboarding{padding:1.5rem;max-height:90vh;overflow-y:auto}.onboarding__emoji{font-size:3rem}.onboarding__title{font-size:1.5rem}.onboarding__options{grid-template-columns:1fr}}:root{--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-xxl: 48px;--font-family: Lexend, Verdana, Tahoma, sans-serif;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.25rem;--font-size-xl: 1.5rem;--font-size-xxl: 2rem;--font-reading: Lexend, Verdana, Tahoma, sans-serif;--font-reading-dyslexic: OpenDyslexic, Verdana, sans-serif;--font-size-reading: 1.25rem;--line-height-reading: 1.8;--letter-spacing-reading: .07em;--word-spacing-reading: .18em;--max-line-width: 60ch;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--highlight-transition: 80ms ease-out;--text-spoken-opacity: .8;--transition-fast: .12s ease;--transition-base: .2s ease;--transition-slow: .35s cubic-bezier(.2, 0, 0, 1);--color-background: #F8F1E4;--color-surface: #EFE6D5;--color-surface-raised: #F4EDE0;--color-text-primary: #2E2418;--color-text-secondary: #4D4030;--color-accent: #4A6B2A;--color-accent-hover: #5A7D36;--color-accent-glow: rgba(74, 107, 42, .15);--color-border: #DDD3BE;--highlight-bg: #B8CF82;--highlight-glow: rgba(184, 207, 130, .3);--shadow-colored: 0 4px 12px rgba(46, 36, 24, .08)}[data-theme=parchment]{--color-background: #F8F1E4;--color-surface: #EFE6D5;--color-surface-raised: #F4EDE0;--color-text-primary: #2E2418;--color-text-secondary: #4D4030;--color-accent: #4A6B2A;--color-accent-hover: #5A7D36;--color-accent-glow: rgba(74, 107, 42, .15);--color-border: #DDD3BE;--highlight-bg: #B8CF82;--highlight-glow: rgba(184, 207, 130, .3);--shadow-colored: 0 4px 12px rgba(46, 36, 24, .08)}[data-theme=moss]{--color-background: #F0EDE4;--color-surface: #E4DFD2;--color-surface-raised: #EAE5D8;--color-text-primary: #272318;--color-text-secondary: #524A39;--color-accent: #4D6E2D;--color-accent-hover: #5D8038;--color-accent-glow: rgba(77, 110, 45, .15);--color-border: #D4CDB8;--highlight-bg: #AECF78;--highlight-glow: rgba(174, 207, 120, .3);--shadow-colored: 0 4px 12px rgba(39, 35, 24, .08)}[data-theme=undergrowth]{--color-background: #1A1E14;--color-surface: #252A1E;--color-surface-raised: #2D3326;--color-text-primary: #E0DBC8;--color-text-secondary: #B5AA88;--color-accent: #8DB34A;--color-accent-hover: #9EC45A;--color-accent-glow: rgba(141, 179, 74, .12);--color-border: #3A4030;--highlight-bg: #3A4E1E;--highlight-glow: rgba(58, 78, 30, .5);--shadow-colored: 0 4px 12px rgba(0, 0, 0, .3)}[data-theme=nightshade]{--color-background: #181420;--color-surface: #221E2C;--color-surface-raised: #2A2536;--color-text-primary: #DCD6E8;--color-text-secondary: #A89FBC;--color-accent: #A688D4;--color-accent-hover: #B99CE0;--color-accent-glow: rgba(166, 136, 212, .12);--color-border: #342E44;--highlight-bg: #352C54;--highlight-glow: rgba(53, 44, 84, .5);--shadow-colored: 0 4px 12px rgba(0, 0, 0, .3)}.skip-link{position:absolute;top:-40px;left:0;padding:8px 16px;background:var(--color-accent);color:#fff;text-decoration:none;font-weight:600;z-index:9999;border-radius:0 0 4px}.skip-link:focus{top:0}*{margin:0;padding:0;box-sizing:border-box}html{height:100%}body{font-family:var(--font-family);background:var(--color-background);color:var(--color-text-primary);line-height:1.5;min-height:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}.app{min-height:100vh;display:flex;flex-direction:column}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}button:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;box-shadow:0 0 0 4px var(--color-accent-glow)}input,select{font-family:inherit}.reading-text{font-variant-ligatures:none;font-style:normal;text-align:left;hyphens:none;-webkit-hyphens:none}.reading-text em,.reading-text i{font-style:normal;font-weight:600}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media(prefers-reduced-motion:reduce){*{transition-duration:.01ms!important;animation-duration:.01ms!important;scroll-behavior:auto!important}}
