.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:var(--color-on-accent);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:var(--color-warning);color:var(--color-on-accent);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)}@media(prefers-reduced-motion:reduce){.offline-indicator{animation:none}}.welcome-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-xxl) var(--space-xl);background:var(--color-background)}.welcome-screen__content{max-width:480px;width:100%;text-align:center}.welcome-screen__illustration{margin:0 auto var(--space-xl);display:flex;justify-content:center;animation:illustrationFloat 5s ease-in-out infinite}@keyframes illustrationFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@media(prefers-reduced-motion:reduce){.welcome-screen__illustration{animation:none}}.welcome-screen__title{font-size:clamp(1.6rem,5vw,2.2rem);font-weight:700;color:var(--color-text-primary);margin:0 0 var(--space-md);line-height:1.15;letter-spacing:-.02em}.welcome-screen__description{font-size:var(--font-size-lg);color:var(--color-text-secondary);line-height:1.7;margin:0 auto var(--space-xxl);max-width:38ch}.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-xl);font-size:var(--font-size-md);font-weight:700;border:none;border-radius:var(--radius-full);cursor:pointer;transition:background var(--transition-base),transform var(--transition-fast),box-shadow var(--transition-base);font-family:var(--font-family);min-height:54px;letter-spacing:.01em}.welcome-screen__button:disabled{opacity:.6;cursor:not-allowed}.welcome-screen__button--primary{background:var(--color-accent);color:var(--color-on-accent);box-shadow:0 3px 14px var(--color-accent-glow),var(--shadow-warm-sm)}.welcome-screen__button--primary:hover:not(:disabled){background:var(--color-accent-hover);transform:translateY(-2px);box-shadow:0 8px 24px var(--color-accent-glow),var(--shadow-warm-sm-hover)}.welcome-screen__button--primary:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 6px var(--color-accent-glow)}.welcome-screen__button--secondary{background:var(--color-surface);color:var(--color-text-primary);border:1.5px solid var(--color-border);box-shadow:var(--shadow-sm)}.welcome-screen__button--secondary:hover:not(:disabled){background:var(--color-surface-raised);border-color:var(--color-accent);transform:translateY(-2px);box-shadow:var(--shadow-md)}.welcome-screen__button--secondary:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}.welcome-screen__button-icon{flex-shrink:0}.welcome-screen__spinner{display:inline-block;width:18px;height:18px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@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;font-weight:700;letter-spacing:.04em}.welcome-screen__format-tags{display:flex;gap:var(--space-sm)}.welcome-screen__format-tag{padding:4px 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:700;font-family:var(--font-family);letter-spacing:.04em}@media(max-width:640px){.welcome-screen{padding:var(--space-xl) var(--space-lg);align-items:flex-start;padding-top:var(--space-xxl)}.welcome-screen__title{font-size:var(--font-size-xl)}.welcome-screen__description{font-size:var(--font-size-md);margin-bottom:var(--space-xl)}.welcome-screen__button{font-size:var(--font-size-md)}}@media(prefers-reduced-motion:reduce){.welcome-screen__spinner{animation:none;border-top-color:var(--color-text-secondary)}.welcome-screen__button{transition:background var(--transition-base)}.welcome-screen__button:hover:not(:disabled),.welcome-screen__button:active:not(:disabled){transform:none}}.library{max-width:620px;margin:0 auto;padding:var(--space-lg) var(--space-lg) var(--space-xxl);min-height:100vh}.library__header{padding:var(--space-xxl) 0 var(--space-xl)}.library__header-main{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-md)}.library__title{font-size:clamp(1.6rem,4vw,2.25rem);font-weight:700;letter-spacing:-.025em;line-height:1.1;color:var(--color-text-primary);margin-bottom:var(--space-xs)}.library__title:before{content:"";display:inline-block;width:.55em;height:.55em;margin-right:.3em;background:var(--color-accent);border-radius:50% 0;transform:rotate(-15deg) translateY(.02em);opacity:.75;vertical-align:baseline}.library__tagline{color:var(--color-text-secondary);font-size:var(--font-size-md);letter-spacing:.01em;line-height:1.5}.library__header-actions{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap;flex-shrink:0;padding-top:4px}.library__streak{display:flex;align-items:center;gap:var(--space-xs);padding:6px var(--space-md);background:var(--color-accent);border-radius:var(--radius-full);color:var(--color-on-accent);font-weight:700;font-size:var(--font-size-sm);box-shadow:var(--shadow-colored);letter-spacing:.01em}.library__streak-emoji{font-size:1.1rem;animation:flameFlicker 1.2s ease-in-out infinite alternate}.library__streak-text{white-space:nowrap}@keyframes flameFlicker{0%{transform:scale(1) rotate(-3deg)}to{transform:scale(1.12) rotate(3deg)}}@media(prefers-reduced-motion:reduce){.library__streak-emoji{animation:none}}.library__whats-new-btn{position:relative;display:inline-flex;align-items:center;gap:var(--space-xs);padding:6px var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.library__whats-new-btn:hover{background:var(--color-border);color:var(--color-text-primary)}.library__whats-new-dot{width:7px;height:7px;border-radius:var(--radius-full);background:var(--color-accent);flex-shrink:0}.library__whats-new-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--scrim-bg);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-lg);animation:fadeIn .2s ease}.library__whats-new-modal{background:var(--color-background);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:480px;width:100%;max-height:80vh;overflow-y:auto;animation:onboardingSlideUp .25s cubic-bezier(.2,0,0,1)}.library__whats-new-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg) var(--space-lg) var(--space-md);border-bottom:1px solid var(--color-border)}.library__whats-new-title{font-size:var(--font-size-lg);font-weight:700;margin:0}.library__whats-new-close{width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--color-text-secondary);border-radius:var(--radius-full);transition:background var(--transition-fast)}.library__whats-new-close:hover{background:var(--color-border);color:var(--color-text-primary)}.library__whats-new-release{padding:var(--space-lg)}.library__whats-new-version{font-size:var(--font-size-sm);color:var(--color-accent);margin:0 0 var(--space-md);font-weight:700;letter-spacing:.04em}.library__whats-new-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-sm)}.library__whats-new-item{display:flex;align-items:flex-start;gap:var(--space-sm);font-size:var(--font-size-md);color:var(--color-text-primary);line-height:1.55}.library__whats-new-icon{font-size:1.1rem;flex-shrink:0;margin-top:1px}@media(prefers-reduced-motion:reduce){.library__whats-new-overlay,.library__whats-new-modal{animation:none}}.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-on-accent);font-size:var(--font-size-md);font-weight:700;border-radius:var(--radius-full);min-height:52px;min-width:200px;letter-spacing:.01em;transition:background var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-base);box-shadow:0 3px 12px var(--color-accent-glow),var(--shadow-warm-sm)}.library__upload-btn:hover:not(:disabled){background:var(--color-accent-hover);transform:translateY(-2px);box-shadow:0 8px 24px var(--color-accent-glow),var(--shadow-warm-sm-hover)}.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);letter-spacing:.01em}.library__file-input{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}.library__error{background:var(--color-error-bg);color:var(--color-error);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 var(--color-error);line-height:1.6}.library__search{margin-bottom:var(--space-md)}.library__search-input{width:100%;min-height:44px;padding:var(--space-sm) var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-primary);font-size:var(--font-size-md);font-family:inherit;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast)}.library__search-input::placeholder{color:var(--color-text-secondary)}.library__search-input:hover{border-color:var(--color-border);background:var(--color-surface-raised)}.library__search-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-glow)}.library__search-input:disabled{opacity:.6;cursor:not-allowed}.library__list-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);margin-bottom:var(--space-md)}.library__list-header .library__list-heading{margin-bottom:0;padding-bottom:0;border-bottom:none}.library__list-heading{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:700;letter-spacing:.04em;margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border)}.library__sort{font-size:var(--font-size-sm);font-family:inherit;color:var(--color-text-secondary);background:transparent;border:none;cursor:pointer;padding:2px var(--space-xs);border-radius:var(--radius-sm);transition:color var(--transition-fast);flex-shrink:0}.library__sort:hover{color:var(--color-text-primary)}.library__sort:focus{outline:2px solid var(--color-accent);outline-offset:2px}.library__no-results{text-align:center;color:var(--color-text-secondary);font-size:var(--font-size-md);padding:var(--space-lg) 0;margin:0}.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__cover{width:48px;height:68px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0;box-shadow:var(--shadow-cover)}.library__book{flex:1;display:flex;flex-direction:row;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--color-surface);border-radius:var(--radius-lg);text-align:left;min-height:64px;border:1px solid var(--color-border);transition:box-shadow var(--transition-base),transform var(--transition-fast),background var(--transition-fast),border-color var(--transition-fast);box-shadow:var(--shadow-warm-xs);position:relative;overflow:hidden}.library__book:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent 0%,var(--color-border) 20%,var(--color-border) 80%,transparent 100%);opacity:0;transition:opacity var(--transition-fast)}.library__book:hover{box-shadow:var(--shadow-md),var(--shadow-colored);transform:translateY(-2px);border-color:transparent;background:var(--color-surface-raised)}.library__book:hover:before{opacity:1}.library__book:active{transform:translateY(0);box-shadow:var(--shadow-warm-xs)}.library__book--recent{border-left:3px solid var(--color-accent);background:var(--color-surface-raised);padding-left:calc(var(--space-lg) - 2px);box-shadow:var(--shadow-colored)}.library__book--recent:after{content:"";position:absolute;top:0;bottom:0;left:0;width:3px;background:linear-gradient(180deg,var(--color-accent-hover) 0%,var(--color-accent) 50%,var(--color-accent-hover) 100%)}.library__book--completed{opacity:.75}.library__book-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.library__book-title{font-size:var(--font-size-md);font-weight:700;color:var(--color-text-primary);line-height:1.35}.library__book-author{font-size:var(--font-size-sm);color:var(--color-text-secondary);display:flex;align-items:center;gap:var(--space-xs);flex-wrap:wrap}.library__reading-time{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:400;opacity:.8}.library__reading-time:before{content:"·";margin-right:var(--space-xs);opacity:.6}.library__continue{font-size:var(--font-size-sm);color:var(--color-accent);font-weight:700;letter-spacing:.01em;margin-top:2px}.library__completed-badge{font-size:var(--font-size-sm);color:var(--color-accent);font-weight:700;display:inline-flex;align-items:center;gap:4px;margin-top:2px}.library__progress{height:5px;background:var(--color-border);border-radius:var(--radius-full);overflow:hidden;margin-top:var(--space-sm)}.library__progress-bar{height:100%;background:linear-gradient(90deg,var(--color-accent) 0%,var(--color-accent-hover) 100%);border-radius:var(--radius-full);transition:width .3s ease}.library__reread{width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--color-text-secondary);border-radius:var(--radius-full);flex-shrink:0;opacity:.5;transition:opacity var(--transition-fast),background var(--transition-fast)}.library__item:hover .library__reread,.library__item:focus-within .library__reread{opacity:.8}.library__reread:hover{background:var(--color-surface);opacity:1;color:var(--color-accent)}.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:0;transition:opacity var(--transition-fast),background var(--transition-fast),color var(--transition-fast)}.library__item:hover .library__delete,.library__item:focus-within .library__delete{opacity:.5}.library__delete:hover{background:var(--color-surface);color:var(--color-text-primary);opacity:1}.library__delete-confirm{display:flex;gap:var(--space-xs);align-items:center;flex-shrink:0}.library__delete-confirm-yes,.library__delete-confirm-no{padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:600;min-height:44px;min-width:44px;cursor:pointer;transition:background var(--transition-fast),opacity var(--transition-fast)}.library__delete-confirm-yes{background:var(--color-error);color:var(--color-on-accent);border:none}.library__delete-confirm-yes:hover{opacity:.88}.library__delete-confirm-no{background:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border)}.library__delete-confirm-no:hover{background:var(--color-border)}@media(max-width:600px){.library__header-main{flex-direction:column}.library__streak{align-self:flex-start}.library__delete{opacity:.45}}@keyframes streakPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.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 0 var(--color-border),var(--shadow-header);position:relative;z-index:1}.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),color 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.06)}.reader__back:active,.reader__settings-btn:active,.reader__theme-btn:active{transform:scale(.94)}.reader__title{position:absolute;left:50%;transform:translate(-50%);max-width:calc(100% - 240px);font-size:var(--font-size-sm);font-weight:700;letter-spacing:.01em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center;pointer-events:none;color:var(--color-text-primary)}.reader__header-spacer{flex:1}.reader__streak{font-size:.875rem;font-weight:700;padding:3px var(--space-sm);background:var(--color-accent);color:var(--color-on-accent);border-radius:var(--radius-full);white-space:nowrap;flex-shrink:0;letter-spacing:.01em}.reader__shortcuts-btn{width:36px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);flex-shrink:0;color:var(--color-text-secondary);transition:background var(--transition-fast),color var(--transition-fast)}.reader__shortcuts-btn:hover{background:var(--color-border);color:var(--color-text-primary)}.reader__shortcuts-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--scrim-bg);display:flex;align-items:center;justify-content:center;z-index:200;padding:var(--space-lg);animation:fadeIn .15s ease}.reader__shortcuts{background:var(--color-background);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:340px;overflow:hidden;animation:completionSlideUp .2s cubic-bezier(.2,0,0,1)}.reader__shortcuts-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg) var(--space-lg) var(--space-md);border-bottom:1px solid var(--color-border)}.reader__shortcuts-title{font-size:var(--font-size-md);font-weight:700;margin:0}.reader__shortcuts-close{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);color:var(--color-text-secondary);font-size:1rem;transition:background var(--transition-fast)}.reader__shortcuts-close:hover{background:var(--color-border)}.reader__shortcuts-list{padding:var(--space-md) var(--space-lg);display:flex;flex-direction:column;gap:var(--space-xs)}.reader__shortcut{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-xs) 0}.reader__kbd{display:inline-flex;align-items:center;justify-content:center;min-width:80px;padding:3px var(--space-sm);background:var(--color-surface);border:1px solid var(--color-border);border-bottom-width:2px;border-radius:var(--radius-sm);font-family:inherit;font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);text-align:center;white-space:nowrap}.reader__shortcut-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.reader__font-btn{width:36px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);flex-shrink:0;color:var(--color-text-secondary);transition:background var(--transition-fast),color var(--transition-fast)}.reader__font-btn:hover:not(:disabled){background:var(--color-border);color:var(--color-text-primary)}.reader__font-btn:disabled{opacity:.3;cursor:not-allowed}.reader__theme-picker{position:relative}.reader__theme-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9}.reader__theme-dropdown,.reader__chapter-list-inner{border:none;padding:0;margin:0;min-inline-size:0}.reader__theme-dropdown{position:fixed;top:58px;right:var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:10;min-width:188px;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(-6px)}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-md);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-primary);text-align:left;min-height:44px;cursor:pointer;transition:background var(--transition-fast)}.reader__theme-option:hover{background:var(--color-border)}.reader__theme-option:focus-within{outline:2px solid var(--color-accent);outline-offset:2px;box-shadow:0 0 0 4px var(--color-accent-glow)}.reader__theme-option--active{font-weight:700;background:var(--color-accent-glow)}.reader__theme-swatch{width:22px;height:22px;border-radius:var(--radius-full);border:2px solid var(--color-border-neutral);flex-shrink:0;box-shadow:var(--shadow-inset);transition:transform var(--transition-fast)}.reader__theme-option:hover .reader__theme-swatch{transform:scale(1.12)}.text-display{flex:1;overflow-y:auto;padding:var(--space-xl) var(--space-lg);scroll-behavior:smooth;-webkit-overflow-scrolling:touch;background:var(--color-background)}.text-display__content{margin:0 auto;padding:var(--space-xl) var(--space-xxl) calc(var(--space-xxl) * 1.5);max-width:calc(var(--max-line-width) + var(--space-xxl) * 2);background:var(--color-surface-raised);border-radius:var(--radius-xl);box-shadow:0 2px 0 var(--color-border),var(--shadow-text-area);border:1px solid var(--color-border);min-height:40vh;position:relative}.text-display__content:before{content:"";position:absolute;top:0;left:var(--space-xxl);right:var(--space-xxl);height:2px;background:linear-gradient(90deg,transparent 0%,var(--color-accent) 20%,var(--color-accent) 80%,transparent 100%);opacity:.18;border-radius:var(--radius-full)}.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-on-accent);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:700;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(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.player{flex-shrink:0;padding:var(--space-md) var(--space-lg) var(--space-lg);padding-bottom:max(var(--space-lg),env(safe-area-inset-bottom));background:var(--color-surface);border-top:1px solid var(--color-border);box-shadow:0 -1px 0 var(--color-border),var(--shadow-player);position:relative}.player:before{content:"";position:absolute;top:-1px;left:var(--space-xxl);right:var(--space-xxl);height:2px;background:linear-gradient(90deg,transparent 0%,var(--color-accent) 30%,var(--color-accent) 70%,transparent 100%);opacity:.22;border-radius:var(--radius-full)}.player__progress{height:4px;background:var(--color-border);margin-bottom:var(--space-md);border-radius:var(--radius-full);overflow:hidden}.player__progress-fill{height:100%;background:linear-gradient(90deg,var(--color-accent) 0%,var(--color-accent-hover) 100%);border-radius:var(--radius-full);transition:width .3s ease}@media(prefers-reduced-motion:reduce){.player__progress-fill{transition:none}}.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:60px;height:60px;background:var(--color-accent);color:var(--color-on-accent);box-shadow:0 3px 12px var(--color-accent-glow),var(--shadow-button-warm);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.07);box-shadow:0 6px 20px var(--color-accent-glow),0 0 0 5px var(--color-accent-glow)}.player__btn--play:active{transform:scale(.94);box-shadow:0 1px 4px var(--color-accent-glow)}.player__btn--secondary{width:48px;height:48px;transition:background var(--transition-fast),color var(--transition-fast),transform var(--transition-fast);color:var(--color-text-secondary)}.player__btn--secondary:hover{background:var(--color-border);color:var(--color-accent);transform:scale(1.08)}.player__btn--secondary:active{transform:scale(.92)}.player__buffering-hint{text-align:center;font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-sm);animation:fadeIn .4s ease}.player__info{display:flex;justify-content:center;align-items:center;gap:var(--space-lg)}.player__speed,.player__chapter{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);padding:5px var(--space-sm);border-radius:var(--radius-md);transition:background var(--transition-fast),color var(--transition-fast);letter-spacing:.02em;min-height:44px;display:flex;align-items:center}.player__speed:hover,.player__chapter:hover{background:var(--color-border);color:var(--color-text-primary)}.player__spinner{animation:player-spin .9s linear infinite}@keyframes player-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){.player__spinner{animation:none;opacity:.5}}.player__rewind-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center}.player__rewind-label{position:absolute;font-size:9px;font-weight:700;line-height:1;letter-spacing:-.02em;margin-top:3px}.reader__chapter-list{position:fixed;bottom:140px;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-xl);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(14px) 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-xs)}.reader__chapter-item{display:flex;align-items:center;width:100%;padding:var(--space-sm) var(--space-md);text-align:left;font-size:var(--font-size-md);font-weight:500;border-radius:var(--radius-md);color:var(--color-text-primary);cursor:pointer;transition:background var(--transition-fast);min-height:44px;line-height:1.4}.reader__chapter-item:focus-within{outline:2px solid var(--color-accent);outline-offset:2px;box-shadow:0 0 0 4px var(--color-accent-glow)}.reader__chapter-item:hover{background:var(--color-border)}.reader__chapter-item--active{background:var(--color-accent);color:var(--color-on-accent);font-weight:700}.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-xl) var(--radius-xl) 0 0;overflow-y:auto;animation:drawer-slide-up .35s cubic-bezier(.2,0,0,1);box-shadow:var(--shadow-drawer)}@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:700;letter-spacing:-.01em}.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:700;color:var(--color-text-secondary);letter-spacing:.04em;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-weight:600}.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-on-accent);box-shadow:0 2px 8px var(--color-accent-glow)}.settings-chip--active:hover{transform:translateY(-1px);box-shadow:0 4px 14px 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:var(--shadow-inset-md);transition:border-color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.settings-swatch:hover{transform:scale(1.12);box-shadow:var(--shadow-inset-md),var(--shadow-neutral-sm)}.settings-swatch--active{border-color:var(--color-accent);box-shadow:var(--shadow-inset-md),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:700;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:700;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-chip--primary{background:var(--color-accent);color:var(--color-on-accent);font-weight:600}.settings-chip--danger{background:var(--color-error);color:var(--color-on-accent);font-weight:600}.settings-field__description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-sm);margin-bottom:0;line-height:1.55}.settings-field__description--center{text-align:center}.settings-field__confirm{display:flex;gap:var(--space-sm);align-items:center;justify-content:center}.settings-field__confirm-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.settings-button{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.settings-button:hover:not(:disabled){background:var(--color-border)}.settings-button:disabled{opacity:.5;cursor:not-allowed}.settings-button--secondary{background:var(--color-surface);border-color:var(--color-border)}.settings-field__error{margin-top:var(--space-xs);font-size:var(--font-size-sm);color:var(--color-error)}.settings-field__invite-link{display:inline;margin-top:var(--space-xs);padding:0;border:none;background:none;color:var(--color-text-secondary);font-size:var(--font-size-sm);text-decoration:underline;cursor:pointer}.settings-field__invite-link:hover{color:var(--color-text-primary)}.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:700}.settings-badge--success{background:var(--color-accent-glow);color:var(--color-success)}.swipe-indicator{position:fixed;top:50%;transform:translateY(-50%);font-size:4rem;color:var(--color-accent);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,var(--color-accent-glow) 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;right:0;bottom:0;left:0;background:var(--scrim-bg-heavy);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-xl);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-primary);margin-bottom:var(--space-lg);letter-spacing:-.02em}.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-primary)}.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:var(--color-on-accent);font-size:var(--font-size-lg);font-weight:700;border-radius:var(--radius-full);box-shadow:var(--shadow-md);transition:transform var(--transition-fast),box-shadow var(--transition-base),background var(--transition-fast)}.gesture-hint__dismiss:hover{background:var(--color-accent-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.06)}.reader__bookmark-btn:active{transform:scale(.94)}.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:64px;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-xl);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);color:var(--color-text-secondary);font-weight:700;letter-spacing:.04em}.reader__bookmark-add-btn{font-size:var(--font-size-sm);color:var(--color-accent);font-weight:600;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);line-height:1.5}.reader__bookmark-item{display:flex;align-items:stretch;border-radius:var(--radius-md);overflow:hidden;margin-bottom:2px}.reader__bookmark-item--current{background:var(--color-accent-glow);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);text-align:left;border-radius:var(--radius-md) 0 0 var(--radius-md);transition:background var(--transition-fast)}.reader__bookmark-item-body:hover{background:var(--color-border)}.reader__bookmark-item-chapter{font-size:.875rem;font-weight:700;color:var(--color-text-secondary);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{min-width:44px;min-height:44px;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)}@keyframes completionSlideUp{0%{opacity:0;transform:translateY(28px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.reader__completion-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--scrim-bg-heavy);display:flex;align-items:center;justify-content:center;z-index:200;padding:var(--space-lg);animation:fadeIn .3s ease}.reader__completion{background:var(--color-background);border-radius:var(--radius-xl);padding:var(--space-xxl) var(--space-xl);max-width:360px;width:100%;text-align:center;box-shadow:var(--shadow-xl);animation:completionSlideUp .35s cubic-bezier(.2,0,0,1);border:1px solid var(--color-border);position:relative;overflow:hidden}.reader__completion:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--color-accent) 0%,var(--color-accent-hover) 50%,var(--color-accent) 100%)}.reader__completion-emoji{font-size:3rem;margin-bottom:var(--space-md);display:block}.reader__completion-title{font-size:var(--font-size-xxl);font-weight:700;margin-bottom:var(--space-xs);letter-spacing:-.02em}.reader__completion-book{color:var(--color-text-secondary);font-size:var(--font-size-md);margin-bottom:var(--space-lg);line-height:1.4}.reader__completion-stats{display:flex;justify-content:center;gap:var(--space-xl);margin-bottom:var(--space-xl)}.reader__completion-stat{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs)}.reader__completion-stat-value{font-size:var(--font-size-xl);font-weight:700}.reader__completion-stat-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.reader__completion-btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-md) var(--space-xl);background:var(--color-accent);color:var(--color-on-accent);font-size:var(--font-size-md);font-weight:700;border-radius:var(--radius-full);min-height:50px;box-shadow:0 3px 12px var(--color-accent-glow);transition:background var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-base)}.reader__completion-btn:hover{background:var(--color-accent-hover);transform:translateY(-2px);box-shadow:0 6px 20px var(--color-accent-glow)}@media(prefers-reduced-motion:reduce){.gesture-hint,.swipe-indicator{animation:none}.settings-overlay{animation:none;background:var(--scrim-bg)}.settings-drawer,.reader__theme-dropdown,.reader__chapter-list,.reader__bookmark-list,.text-display__resync{animation:none}.reader__back:hover,.reader__settings-btn:hover,.reader__theme-btn:hover,.reader__back:active,.reader__settings-btn:active,.reader__theme-btn:active,.player__btn--play:hover,.player__btn--play:active,.player__btn--secondary:hover,.player__btn--secondary:active,.settings-chip:hover,.settings-chip--active:hover,.settings-swatch:hover,.settings-stepper-btn:hover,.settings-stepper-btn:active,.reader__bookmark-btn:hover,.reader__bookmark-btn:active,.gesture-hint__dismiss:hover{transform:none}.text-display__resync:hover,.text-display__resync:active{transform:translate(-50%)}.reader__completion-overlay,.reader__completion{animation:none}.reader__completion-btn:hover{transform:none}}.feedback-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--scrim-bg);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.feedback-modal{background:var(--color-background);border-radius:12px;box-shadow:var(--shadow-dialog);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(--color-border)}.feedback-modal__header h2{margin:0;font-size:1.5rem;color:var(--color-text-primary)}.feedback-modal__close{background:none;border:none;font-size:2rem;line-height:1;color:var(--color-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(--color-border)}.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(--color-text-primary);margin-bottom:.75rem;font-size:.95rem}.feedback-sentiments{display:flex;gap:.75rem}.feedback-sentiment{flex:1;background:var(--color-surface);border:2px solid transparent;border-radius:8px;padding:1rem .5rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;cursor:pointer;transition:background var(--transition-base),transform var(--transition-fast)}.feedback-sentiment:hover{background:var(--color-border);transform:translateY(-2px)}.feedback-sentiment--active{border-color:var(--color-accent);background:var(--color-accent-glow)}.feedback-sentiment__emoji{font-size:2rem;line-height:1}.feedback-sentiment__label{font-size:.85rem;color:var(--color-text-secondary);font-weight:500}.feedback-sentiment--active .feedback-sentiment__label{color:var(--color-accent)}.feedback-modal__textarea{width:100%;padding:.75rem;border:1px solid var(--color-border);border-radius:6px;background:var(--color-background);color:var(--color-text-primary);font-family:inherit;font-size:.95rem;line-height:1.5;resize:vertical;transition:border-color var(--transition-base)}.feedback-modal__textarea:focus{outline:none;border-color:var(--color-accent)}.feedback-modal__textarea::placeholder{color:var(--color-text-secondary)}.feedback-modal__checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem;color:var(--color-text-primary)}.feedback-modal__checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.feedback-modal__error{padding:.75rem;background:var(--color-error-bg);border:1px solid var(--color-error);border-radius:6px;color:var(--color-error);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:background var(--transition-base),transform var(--transition-fast);border:none}.feedback-modal__button:disabled{opacity:.5;cursor:not-allowed}.feedback-modal__button--secondary{background:var(--color-surface);color:var(--color-text-primary)}.feedback-modal__button--secondary:hover:not(:disabled){background:var(--color-border)}.feedback-modal__button--primary{background:var(--color-accent);color:var(--color-on-accent)}.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:var(--color-success);color:var(--color-on-accent);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(--color-text-primary);font-size:1.1rem;font-weight:500;margin:0 0 .5rem}.feedback-modal__success-subtext{color:var(--color-text-secondary);font-size:.9rem;font-weight:400}@media(prefers-reduced-motion:reduce){.feedback-modal,.feedback-modal__success-icon{animation:none}}@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:var(--scrim-bg-heavy)}@supports (backdrop-filter: blur(4px)){.onboarding-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:var(--scrim-bg-heavy)}}display: flex; align-items: center; justify-content: center; z-index: 10000; padding: 1rem; animation: overlayFadeIn .3s ease-out; } @keyframes overlayFadeIn{from{opacity:0}to{opacity:1}}.onboarding{background:var(--color-background);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:var(--color-text-secondary);font-size:var(--font-size-sm);cursor:pointer;padding:.5rem;border-radius:4px;transition:background var(--transition-fast),color var(--transition-fast)}.onboarding__skip:hover{background:var(--color-border);color:var(--color-text-primary)}.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:var(--color-text-primary);margin:0 0 .5rem}.onboarding__description{font-size:1rem;color:var(--color-text-secondary);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:var(--color-surface);border-radius:var(--radius-md);font-size:.95rem;color:var(--color-text-primary)}.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:background var(--transition-base),transform var(--transition-fast),box-shadow var(--transition-base),opacity var(--transition-fast)}.onboarding__btn--primary{background:var(--color-accent);color:var(--color-on-accent)}.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}}@media(prefers-reduced-motion:reduce){.onboarding__emoji{animation:none}.onboarding{animation-duration:.01ms;animation-name:overlayFadeIn}.onboarding-overlay{animation-duration:.01ms}.onboarding__btn{transition:none}.onboarding__btn--primary:hover{transform:none}}:root{--space-xs: 4px;--shadow-xl: 0 20px 25px rgba(0, 0, 0, .15);--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: 14px;--radius-xl: 20px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(46, 36, 24, .07);--shadow-md: 0 4px 10px rgba(46, 36, 24, .09), 0 1px 3px rgba(46, 36, 24, .05);--shadow-lg: 0 12px 28px rgba(46, 36, 24, .11), 0 4px 8px rgba(46, 36, 24, .05);--shadow-warm-xs: 0 1px 3px rgba(46, 36, 24, .05);--shadow-warm-sm: 0 1px 3px rgba(46, 36, 24, .1);--shadow-warm-sm-hover: 0 2px 6px rgba(46, 36, 24, .1);--shadow-cover: 0 2px 6px rgba(46, 36, 24, .18);--shadow-header: 0 2px 8px rgba(46, 36, 24, .04);--shadow-text-area: 0 4px 16px rgba(46, 36, 24, .07), 0 12px 40px rgba(46, 36, 24, .05);--shadow-player: 0 -4px 20px rgba(46, 36, 24, .06);--shadow-button-warm: 0 1px 4px rgba(46, 36, 24, .12);--shadow-drawer: 0 -6px 32px rgba(46, 36, 24, .14);--shadow-inset: inset 0 1px 3px rgba(0, 0, 0, .15);--shadow-inset-md: inset 0 2px 4px rgba(0, 0, 0, .12);--shadow-neutral-sm: 0 2px 8px rgba(0, 0, 0, .1);--shadow-dialog: 0 4px 20px rgba(0, 0, 0, .15);--color-border-neutral: rgba(0, 0, 0, .12);--scrim-bg-light: rgba(0, 0, 0, .15);--scrim-bg: rgba(0, 0, 0, .5);--scrim-bg-heavy: rgba(0, 0, 0, .7);--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;--color-on-accent: #FFFFFF;--color-error: #9B1C1C;--color-error-bg: #FDE8E8;--color-success: #276A3A;--color-warning: #B45309;--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;--color-on-accent: #FFFFFF;--color-error: #9B1C1C;--color-error-bg: #FDE8E8;--color-success: #276A3A;--color-warning: #B45309;--highlight-bg: #B8CF82;--highlight-glow: rgba(184, 207, 130, .3);--shadow-colored: 0 4px 12px rgba(46, 36, 24, .08);--scrim-bg-light: rgba(0, 0, 0, .15);--scrim-bg: rgba(0, 0, 0, .5);--scrim-bg-heavy: rgba(0, 0, 0, .7)}[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;--color-on-accent: #FFFFFF;--color-error: #8B1A1A;--color-error-bg: #F9E0E0;--color-success: #235E32;--color-warning: #A04E08;--highlight-bg: #AECF78;--highlight-glow: rgba(174, 207, 120, .3);--shadow-colored: 0 4px 12px rgba(39, 35, 24, .08);--scrim-bg-light: rgba(0, 0, 0, .15);--scrim-bg: rgba(0, 0, 0, .5);--scrim-bg-heavy: rgba(0, 0, 0, .7)}[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;--color-on-accent: #0F1209;--color-error: #F8A0A0;--color-error-bg: #3B1C1C;--color-success: #86C98A;--color-warning: #F5A623;--highlight-bg: #3A4E1E;--highlight-glow: rgba(58, 78, 30, .5);--shadow-colored: 0 4px 12px rgba(0, 0, 0, .3);--scrim-bg-light: rgba(0, 0, 0, .15);--scrim-bg: rgba(0, 0, 0, .5);--scrim-bg-heavy: rgba(0, 0, 0, .7)}[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;--color-on-accent: #0D0A14;--color-error: #F0AAAA;--color-error-bg: #2E1828;--color-success: #90C8A0;--color-warning: #F5B942;--highlight-bg: #352C54;--highlight-glow: rgba(53, 44, 84, .5);--shadow-colored: 0 4px 12px rgba(0, 0, 0, .3);--scrim-bg-light: rgba(0, 0, 0, .15);--scrim-bg: rgba(0, 0, 0, .5);--scrim-bg-heavy: rgba(0, 0, 0, .7)}.skip-link{position:absolute;top:-40px;left:0;padding:8px 16px;background:var(--color-accent);color:var(--color-on-accent);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}.app__install-banner{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-accent);color:var(--color-on-accent);font-size:var(--font-size-sm);flex-wrap:wrap}.app__install-text{flex:1;min-width:0}.app__install-btn{padding:var(--space-xs) var(--space-md);background:var(--color-on-accent);color:var(--color-accent);border-radius:var(--radius-full);font-weight:700;font-size:var(--font-size-sm);flex-shrink:0}.app__install-dismiss{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);opacity:.7;flex-shrink:0;font-size:1rem}.app__install-dismiss:hover{opacity:1;background:var(--scrim-bg-light)}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}input,select,textarea{font-size:max(16px,1em)}@media(prefers-reduced-motion:reduce){*{transition-duration:.01ms!important;animation-duration:.01ms!important;scroll-behavior:auto!important}}
