.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{text-align:center;color:var(--color-text-secondary);font-size:var(--font-size-lg);padding:var(--space-xxl) var(--space-lg);line-height:1.8;border:2px dashed var(--color-border);border-radius:var(--radius-lg);margin-top:var(--space-lg)}.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}.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{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}: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: #6B5C48;--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: #6B5C48;--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: #635B4A;--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: #A09878;--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: #9088A8;--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)}*{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}}
