@import"https://fonts.googleapis.com/css2?family=Rubik:wght@400;700&display=swap";*{margin:0;padding:0;box-sizing:border-box}:root{--apple-blue: #007AFF;--apple-red: #FF3B30;--apple-green: #34C759;--apple-orange: #FF9500;--apple-purple: #AF52DE;--apple-pink: #FF2D92;--apple-teal: #5AC8FA;--apple-indigo: #5856D6;--bg-primary: #FFFFFF;--bg-secondary: #FFFFFF;--bg-tertiary: rgba(118, 118, 128, .12);--bg-quaternary: rgba(116, 116, 128, .08);--text-primary: #000000;--text-secondary: rgba(60, 60, 67, .6);--text-tertiary: rgba(60, 60, 67, .3);--shadow-light: 0 2px 16px rgba(0, 0, 0, .1);--shadow-medium: 0 8px 32px rgba(0, 0, 0, .15);--shadow-heavy: 0 16px 64px rgba(0, 0, 0, .2);--radius-small: 8px;--radius-medium: 12px;--radius-large: 20px;--radius-xl: 24px;--transition-fast: .2s ease-out;--transition-medium: .3s ease-out;--transition-slow: .4s ease-out}html,body,#root{height:100%}@supports (-webkit-touch-callout: none){html,body,#root{height:-webkit-fill-available}}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,SF Pro Icons,Helvetica Neue,Helvetica,Arial,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden}::-webkit-scrollbar{display:none}*{-ms-overflow-style:none;scrollbar-width:none}.touch-feedback{transition:transform var(--transition-fast)}.touch-feedback:active{transform:scale(.98)}.glass{background:#ffffff40;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.18)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.pulse{animation:pulse 2s ease-in-out infinite}.app{height:100vh;height:calc(var(--vh, 1vh) * 100);background:#fff;display:flex;align-items:center;justify-content:center;padding:0}.container{max-width:100%;width:100%;height:100%;max-height:100%;background:var(--bg-secondary);border-radius:0;box-shadow:none;overflow:visible;position:relative;display:flex;flex-direction:column;padding:0 10px 4px}.main-content{flex:1;display:flex;flex-direction:column;overflow:visible;position:relative;animation:slideIn .5s ease-out}.scrollable-content{flex-grow:1;overflow-x:visible;overflow-y:auto;display:flex;flex-direction:column;position:relative;padding:0 24px;min-height:0;-webkit-overflow-scrolling:touch}.scrollable-content>.image-viewer-container{flex:1;min-height:0;transition:all .4s ease-in-out}.scrollable-content>.image-viewer-container.chapter-info-collapsed{flex-basis:100%}.scrollable-content>.chapter-info-container{margin-bottom:24px;margin-top:auto}.scrollable-content>.player-loading-container,.scrollable-content>.player-error-container{flex:1;min-height:0;margin-bottom:0}.scrollable-content::-webkit-scrollbar{width:5px}.scrollable-content::-webkit-scrollbar-track{background:transparent}.scrollable-content::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.scrollable-content::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.fixed-controls{position:relative;width:100%;flex-shrink:0;z-index:10;padding:0 16px 8px;box-sizing:border-box;display:flex;flex-direction:column;gap:8px;transition:transform .3s ease-in-out}.info-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0003;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:0;pointer-events:none;transition:opacity var(--transition-medium);z-index:15;align-items:center;gap:8px;padding:4px 0 8px}.info-overlay.visible{opacity:1;pointer-events:auto}@keyframes slideIn{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}.image-container{position:relative;margin-bottom:24px;cursor:pointer;transition:all var(--transition-medium);border-radius:var(--radius-large);overflow:hidden;box-shadow:var(--shadow-medium)}.image-container:hover{transform:translateY(-2px);box-shadow:var(--shadow-heavy)}.image-container.expanded{transform:scale(1.1);z-index:10}.chapter-image{width:100%;height:100%;object-fit:cover;display:block;transition:all var(--transition-medium)}.image-container.expanded .chapter-image{height:400px}.image-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,rgba(0,0,0,.1) 0%,transparent 50%,rgba(255,255,255,.1) 100%);display:flex;align-items:flex-end;justify-content:flex-end;padding:16px;opacity:0;transition:opacity var(--transition-medium)}.image-container:hover .image-overlay{opacity:1}.expand-button{background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:none;border-radius:50%;width:40px;height:40px;font-size:20px;font-weight:700;color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast)}.expand-button:hover{background:#fff;transform:scale(1.1)}.chapter-dots{display:flex;justify-content:center;align-items:center;gap:8px;padding:4px 0;flex-wrap:wrap}.dot{width:8px;height:8px;border-radius:4px;background-color:var(--dot-color);border:none;cursor:pointer;transition:all .4s cubic-bezier(.175,.885,.32,1.275)}.dot:hover:not(.active){background-color:var(--accent-color);opacity:.6}.dot.active{width:24px;background:linear-gradient(135deg,var(--apple-blue),var(--apple-purple))}@media (min-width: 481px){.app{background:var(--desktop-bg);padding:20px;display:flex;align-items:center;justify-content:center;min-height:100vh}.container{height:95vh;aspect-ratio:4 / 4;width:auto;border-radius:var(--radius-xl);box-shadow:var(--shadow-heavy);padding:0 20px 4px;margin:0 auto;display:flex;flex-direction:column}.scrollable-content{padding:0 4px}.fixed-controls{padding:4px 4px 2px}.image-viewer{flex:0 0 auto;width:100%;height:70%;min-height:0;min-width:0;margin-bottom:14px}.image-viewer-container{width:100%;height:100%;max-width:100%;margin:0 auto;box-sizing:border-box;min-height:0;min-width:0}.timed-image-wrapper,.chapter-image-slide{width:100%;height:100%;max-width:100%;max-height:100%;object-fit:cover}.player{min-height:30%;height:30%;max-height:200px}}@media (max-width: 480px){.header{padding:16px 20px 12px;flex-shrink:0}.app-title{font-size:20px}.main-content{padding:0}.scrollable-content{padding:0 4px;overflow:visible}.fixed-controls{padding:16px 4px 4px}.image-viewer{flex:0 0 auto}.chapter-image{height:280px}.image-container.expanded .chapter-image{height:350px}.chapter-dots{flex:0 0 auto;margin-bottom:0;gap:8px}.controls{gap:16px}.control-button{width:40px;height:40px;font-size:20px;padding:8px}.play-button{width:56px;height:56px;font-size:20px}.dot{width:8px;height:8px}}@media (max-width: 360px){.main-content{padding:12px;gap:12px}.scrollable-content{overflow:visible}.chapter-image{height:240px}.image-container.expanded .chapter-image{height:280px}.controls{gap:12px}.control-button{width:36px;height:36px;font-size:18px}.play-button{width:48px;height:48px;font-size:18px}}.player{width:100%;background-color:var(--player-bg);border-radius:12px;padding-top:4px;box-shadow:0 4px 12px #0000001a;overflow:hidden;position:relative;color:var(--text-color);height:130px;transition:height .3s ease;display:flex;flex-direction:column}.player.description-mode{cursor:default;flex-grow:1}.player.description-mode .player-background-fill{opacity:0}.player-content{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:center}.player-controls-group{display:flex;align-items:center;gap:16px}.time-display{font-size:12px;color:var(--text-secondary-color);min-width:40px;text-align:center}.control-button{background:transparent;border:none;border-radius:50%;width:44px;height:44px;font-size:20px;color:var(--control-icon-color);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);position:relative;-webkit-tap-highlight-color:transparent}.control-button svg{font-size:30px!important}.control-button:disabled{opacity:.3;cursor:not-allowed}.play-button{background:linear-gradient(135deg,var(--apple-blue),var(--apple-purple));border:none;border-radius:50%;width:55px;height:55px;font-size:25px;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px #007aff4d}.play-button svg{font-size:44px!important;color:var(--play-icon-color)!important}.play-button:hover:not(:disabled){transform:scale(1.05);box-shadow:0 8px 25px #007aff66}.play-button:active:not(:disabled){transform:scale(.95)}.play-button:disabled{opacity:.7;cursor:not-allowed}.loading-spinner-small{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.processing-status{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}.processing-spinner{width:16px;height:16px;border:2px solid transparent;border-top:2px solid #fff;border-radius:50%;animation:spin 1s linear infinite}.processing-text{font-size:10px;color:#fff;font-weight:500;line-height:1}.time-info-vertical,.time-info,.time-separator{display:none}.progress-bar-container{position:absolute;top:0;left:0;width:100%;height:4px;background-color:var(--progress-bg);transition:background-color .3s ease}.progress-bar{height:100%;background:var(--progress-gradient)}.progress-interaction-area{position:absolute;top:0;left:0;width:100%;height:20px;margin-top:-8px;z-index:5;cursor:pointer}.progress-handle-wrapper{position:absolute;top:50%;transform:translateY(-50%);width:20px;height:20px;margin-left:-10px}.progress-handle{width:12px;height:12px;background:#fff;border-radius:50%;border:1px solid rgba(0,0,0,.1);box-shadow:0 1px 3px #0000001a;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);opacity:0;transition:transform .2s ease,opacity .2s ease}.progress-interaction-area:hover .progress-handle,.player-wrapper.seeking .progress-handle{transform:translate(-50%,-50%) scale(1.2);opacity:1}.progress-ticks-container{position:absolute;top:-50px;left:0;right:0;height:100px;pointer-events:none;overflow:visible}.progress-bar-container,.player-wrapper,.fixed-controls{overflow:visible!important}.progress-tick-wrapper{position:absolute;top:51.5%;transform:translate(-50%,-50%);width:16px;height:16px;display:flex;align-items:center;justify-content:center;pointer-events:all;cursor:pointer;z-index:6}.progress-tick{width:4px;height:4px;background-color:var(--tick-color);border-radius:50%;transition:transform .2s ease}.progress-tick-wrapper:hover .progress-tick{transform:scale(2)}.tick-tooltip{position:absolute;left:50%;top:auto;bottom:100%;margin-bottom:8px;background-color:var(--tooltip-bg);color:var(--tooltip-text);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:4px 8px;border-radius:var(--radius-small);font-size:12px;font-weight:600;white-space:nowrap;box-shadow:var(--shadow-medium);opacity:1;pointer-events:auto;z-index:1000;--offset-x: 0px;transform:translate(calc(-50% + var(--offset-x))) translateY(0)}.tick-tooltip.bottom{top:100%;bottom:auto;margin-bottom:0;margin-top:8px;transform:translate(calc(-50% + var(--offset-x))) translateY(0)}.player-background-fill{position:absolute;top:0;left:0;height:100%;background:var(--progress-gradient);opacity:.2;z-index:0;transition:width .1s linear,opacity .3s ease-out}.player-content-wrapper{position:relative;z-index:1;padding:8px 16px 12px;display:flex;flex-direction:column;flex-grow:1}.player-header{display:flex;align-items:center;gap:8px;padding:6px 12px;margin-bottom:6px;transition:all .3s ease;position:relative;z-index:0}.player-header:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:-1;border-radius:var(--radius-medium);background:var(--player-header-bg);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:1px solid var(--player-header-border);transform:translateZ(0)}.player-header-icons{display:grid;justify-items:end;align-items:center;flex-shrink:0}.player-header-icons>*{grid-area:1 / 1}.extra-controls-wrapper{display:flex;align-items:center;gap:2px;overflow:hidden;padding-right:5px}.player-title{font-family:Rubik,sans-serif;font-size:.85rem;font-weight:700;color:var(--player-title-color);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex-grow:1;cursor:pointer;padding:4px 8px;border-radius:6px;transition:all .2s ease;-webkit-user-select:none;user-select:none}.player-title:hover{background:var(--bg-tertiary);color:var(--apple-blue)}.player-title:active{transform:scale(.98)}.info-button{background:none;border:none;padding:0;color:var(--icon-color);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}@media (hover: hover) and (pointer: fine){.info-button:hover{color:var(--icon-hover-color)}}.player-body{flex-grow:1;display:flex;align-items:center;justify-content:space-between}.player-description{width:100%;font-size:13px;line-height:1.4;color:var(--text-secondary-color);overflow-y:auto;max-height:60px;padding-right:8px}.player-description p{margin:0}.container.modal-open{overflow:hidden;transition:transform .25s cubic-bezier(.34,1.56,.64,1)}.info-overlay.image-mode{background:var(--image-overlay-bg);-webkit-backdrop-filter:var(--image-overlay-blur);backdrop-filter:var(--image-overlay-blur)}.info-modal{position:fixed;top:50%;left:50%;width:calc(100% - 48px);max-width:400px;z-index:20;max-height:70vh;opacity:0;transform:translate(-50%,-45%) scale(.95);transform-origin:center center;pointer-events:none;transition:transform .25s cubic-bezier(.34,1.56,.64,1),opacity .2s ease-out;--play-icon-color: #fff;--image-overlay-bg: rgba(247, 247, 247, .5);--image-overlay-blur: blur(20px)}.info-modal.visible{opacity:1;transform:translate(-50%,-50%) scale(1);pointer-events:auto}.info-modal-content{background:var(--bg-secondary);border-radius:var(--radius-large);padding:24px;box-shadow:var(--shadow-heavy);border:1px solid rgba(255,255,255,.1);overflow-y:auto;max-height:70vh}.video-modal{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1001;display:flex;justify-content:center;align-items:center;padding:2.5vh;box-sizing:border-box}.video-modal-content{max-width:100%;max-height:100%;outline:none;border-radius:var(--radius-large);box-shadow:0 25px 50px -12px #00000080}.collapsible-meta{display:flex;flex-direction:column;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;overflow:hidden;transition:max-height .4s ease-in-out,margin-top .4s ease-in-out}.chapter-subtitle{font-size:16px;color:var(--text-secondary);margin:0;font-weight:500;opacity:.9;flex:1}.chapter-duration{display:flex;align-items:center;gap:6px;background:var(--bg-quaternary);padding:6px 10px;border-radius:16px;border:1px solid rgba(255,255,255,.05);flex-shrink:0}.duration-icon{font-size:14px;opacity:.7}.duration-text{font-size:13px;font-weight:600;color:var(--text-secondary);font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace}.chapter-description-container{overflow-y:auto;flex-grow:1}.chapter-description{font-size:16px;line-height:1.6;color:var(--text-secondary-color);padding:0 4px}@font-face{font-family:Neopixel;src:url(/fonts/NEOPIXEL-Regular.otf) format("opentype");font-weight:400;font-style:normal;font-display:swap}:root{--background-color: var(--bg-secondary);--text-color: var(--text-primary);--text-secondary-color: var(--text-secondary);--icon-color: var(--text-secondary);--icon-hover-color: var(--text-primary);--bg-primary: #fff;--bg-secondary: #f7f7f7;--bg-tertiary: #ebebeb;--player-bg: #e9e9e9;--progress-bg: #dcdcdc;--progress-gradient: linear-gradient(90deg, var(--apple-blue), var(--apple-purple));--dot-color: #e0e0e0;--dot-hover-color: #cccccc;--text-primary: #1d1d1f;--text-secondary: #6e6e73;--text-tertiary: #a1a1a6;--accent-color: #007aff;--apple-blue: #007aff;--apple-purple: #af52de;--radius-small: 8px;--radius-medium: 12px;--radius-large: 16px;--radius-xl: 24px;--shadow-light: 0 4px 6px rgba(0, 0, 0, .05);--shadow-medium: 0 8px 16px rgba(0, 0, 0, .1);--shadow-heavy: 0 16px 32px rgba(0, 0, 0, .1);--transition-fast: .2s cubic-bezier(.25, .46, .45, .94);--transition-medium: .4s cubic-bezier(.25, .46, .45, .94);--separator-color: rgba(0, 0, 0, .07);--player-title-color: #525252;--player-header-bg: rgba(255, 255, 255, .3);--player-header-border: rgba(0, 0, 0, .05);--desktop-bg: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--control-icon-color: var(--text-primary);--play-icon-color: #fff;--image-overlay-bg: rgba(255, 255, 255, .6);--image-overlay-blur: blur(30px);--tooltip-bg: rgba(44, 44, 46, .5);--tooltip-text: #fff;--tick-color: rgba(0, 0, 0, .2)}[data-theme=dark]{--bg-primary: #1c1c1e;--bg-secondary: #2c2c2e;--bg-tertiary: #3a3a3c;--player-bg: #212123;--progress-bg: #424244;--text-primary: #ffffff;--text-secondary: #a0a0a5;--text-tertiary: #8e8e93;--separator-color: rgba(255, 255, 255, .1);--dot-color: #4a4a4c;--dot-hover-color: #6a6a6c;--player-title-color: #b1b1b1;--player-header-bg: rgba(0, 0, 0, .2);--player-header-border: rgba(255, 255, 255, .08);--desktop-bg: #202020;--icon-hover-color: #d1d1d6;--control-icon-color: var(--text-secondary);--play-icon-color: var(--text-secondary);--image-overlay-bg: rgba(0, 0, 0, .7);--tooltip-bg: rgba(242, 242, 247, .5);--tooltip-text: #1d1d1f;--tick-color: rgba(255, 255, 255, .4)}body{transition:background-color .3s ease,color .3s ease}.player,.header,.container,.fixed-controls,.info-modal-content{transition:background-color .3s ease,color .3s ease,border-color .3s ease}.player-wrapper{position:relative}.speed-button{font-family:Rubik,sans-serif;font-size:18px;font-weight:500;padding:0 2px;letter-spacing:.5px}.speed-control-popup{position:absolute;bottom:calc(100% - 5px);right:30px;background:var(--player-bg);padding:8px;border-radius:12px;box-shadow:var(--shadow-heavy);z-index:20;display:flex;flex-direction:column;gap:4px}.speed-option{background:none;border:none;color:var(--text-secondary);font-family:Rubik,sans-serif;font-size:15px;font-weight:500;padding:8px 12px;border-radius:8px;cursor:pointer;width:100%;text-align:center;transition:background-color .2s,color .2s}.speed-option:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.speed-option.active{color:var(--accent-color);background-color:transparent;font-weight:700}.quality-control-popup{position:absolute;bottom:calc(100% - 5px);right:30px;background:var(--player-bg);padding:8px;border-radius:12px;box-shadow:var(--shadow-heavy);z-index:20;display:flex;flex-direction:column;gap:4px;min-width:120px}.quality-option{background:none;border:none;color:var(--text-secondary);font-family:Rubik,sans-serif;font-size:15px;font-weight:500;padding:8px 12px;border-radius:8px;cursor:pointer;width:100%;text-align:center;transition:background-color .2s,color .2s;display:flex;flex-direction:column;gap:2px}.quality-option:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.quality-option.active{color:var(--accent-color);background-color:transparent;font-weight:700}.quality-label{font-size:15px;font-weight:500}.quality-description{font-size:12px;opacity:.7;font-weight:400}.quality-button{font-family:Rubik,sans-serif;font-size:14px;font-weight:500;padding:0 2px;letter-spacing:.5px}.volume-control-popup{position:absolute;bottom:calc(100% - 5px);right:16px;background:var(--player-bg);padding:12px;border-radius:12px;box-shadow:var(--shadow-heavy);z-index:20;height:200px;width:50px;display:flex;justify-content:center;align-items:center}.volume-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:190px;height:6px;background:var(--progress-bg);cursor:pointer;transform:rotate(-90deg)}.volume-slider::-webkit-slider-runnable-track{-webkit-appearance:none;height:6px;background:var(--progress-bg);border-radius:3px}.volume-slider::-moz-range-track{height:6px;background:var(--progress-bg);border-radius:3px}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;background:#fff;border-radius:50%;border:1px solid #ddd;box-shadow:0 1px 3px #0003;margin-top:-6px}.volume-slider::-moz-range-thumb{width:18px;height:18px;background:#fff;border-radius:50%;border:1px solid #ddd;box-shadow:0 1px 3px #0003;margin-top:-6px}.quality-loading{display:flex;align-items:center;gap:8px;padding:12px;color:var(--text-secondary);font-size:.875rem}.quality-loading .loading-spinner{width:16px;height:16px;border:2px solid var(--border-color);border-top:2px solid var(--accent-color);border-radius:50%;animation:spin 1s linear infinite}.quality-error{padding:12px;color:var(--error-color, #ef4444);font-size:.875rem;text-align:center}.quality-option.disabled{opacity:.5;cursor:not-allowed;background:var(--bg-tertiary)}.quality-option.disabled:hover{background:var(--bg-tertiary);transform:none}.quality-unavailable{font-size:.7rem;color:var(--text-tertiary);margin-top:2px;font-style:italic}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:var(--bg-secondary);color:var(--text-primary);gap:16px}.loading-container .loading-spinner{width:40px;height:40px;border:3px solid var(--bg-primary);border-top:3px solid var(--accent-color);border-radius:50%;animation:spin 1s linear infinite}.loading-container p{font-size:1.1rem;margin:0;opacity:.8}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:var(--bg-secondary);color:var(--text-primary);gap:16px;padding:24px;text-align:center}.error-container p{font-size:1.1rem;margin:0;opacity:.8;max-width:400px}.error-container button{background:var(--accent-color);color:#fff;border:none;border-radius:var(--radius-medium);padding:12px 24px;font-size:1rem;cursor:pointer;transition:all var(--transition-fast)}.error-container button:hover{background:var(--accent-color-hover);transform:translateY(-1px)}.player-loading-container,.player-error-container{position:relative;cursor:default;transition:all var(--transition-medium);border-radius:var(--radius-large);overflow:hidden;background:var(--bg-secondary);height:100%;min-height:300px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;font-family:Rubik,sans-serif}.player-loading-container:hover,.player-error-container:hover{transform:translateY(-2px)}.player-loading-container:before,.player-error-container:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#007aff0d,#af52de0d,#007aff0d);opacity:1;transition:opacity var(--transition-medium)}.player-loading-spinner{width:60px;height:60px;border:3px solid transparent;border-top:3px solid var(--apple-blue);border-right:3px solid var(--apple-purple);border-radius:50%;animation:spin 1.2s linear infinite;margin-bottom:24px;position:relative;z-index:2}.player-loading-spinner:after{content:"";position:absolute;top:-3px;left:-3px;right:-3px;bottom:-3px;border:3px solid transparent;border-top:3px solid rgba(0,122,255,.3);border-radius:50%;animation:spin 2s linear infinite reverse}.player-loading-container:after{content:"";position:absolute;bottom:20px;left:50%;transform:translate(-50%);width:8px;height:8px;background:var(--apple-blue);border-radius:50%;animation:pulse 1.5s ease-in-out infinite;z-index:2}@keyframes pulse{0%,to{opacity:.3;transform:translate(-50%) scale(.8)}50%{opacity:1;transform:translate(-50%) scale(1.2)}}.player-loading-container p,.player-error-container p{color:var(--text-primary);font-size:1.2rem;font-weight:500;margin:0;line-height:1.5;position:relative;z-index:2;letter-spacing:.5px;font-family:Rubik,sans-serif}.player-error-container button{margin-top:24px;padding:14px 28px;background:linear-gradient(135deg,var(--apple-blue),var(--apple-purple));color:#fff;border:none;border-radius:var(--radius-medium);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-medium);position:relative;z-index:2;letter-spacing:.5px;box-shadow:0 4px 12px #007aff4d;font-family:Rubik,sans-serif}.player-error-container button:hover{transform:translateY(-3px);box-shadow:0 8px 20px #007aff66;background:linear-gradient(135deg,#0056cc,#8a4fd8)}.player-error-container button:active{transform:translateY(-1px);box-shadow:0 4px 12px #007aff4d}.player-loading-container{animation:loadingPulse 3s ease-in-out infinite}@keyframes loadingPulse{0%,to{opacity:1}50%{opacity:.95}}@media (max-width: 480px){.player-loading-container,.player-error-container{min-height:280px;margin-bottom:20px;padding:30px 15px}.player-loading-spinner{width:50px;height:50px}.player-loading-container p,.player-error-container p{font-size:1.1rem}.player-error-container button{padding:12px 24px;font-size:.95rem}}@media (max-width: 360px){.player-loading-container,.player-error-container{min-height:250px;padding:25px 15px}.player-loading-spinner{width:45px;height:45px}.player-loading-container p,.player-error-container p{font-size:1rem}.player-error-container button{padding:10px 20px;font-size:.9rem}}.book-selector-overlay{position:fixed;z-index:1000;top:0;left:0;width:100vw;height:100vh;background:#1e2026eb;display:flex;flex-direction:column;align-items:center;justify-content:center;animation:fadeIn .3s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.close-book-selector{margin-top:24px;padding:12px 32px;font-size:1.1rem;border-radius:12px;background:linear-gradient(90deg,var(--apple-blue),var(--apple-purple));color:#fff;border:none;cursor:pointer;font-family:Rubik,sans-serif;font-weight:600;box-shadow:0 2px 12px #00000014;transition:background .2s,color .2s}.close-book-selector:hover{background:linear-gradient(90deg,var(--apple-purple),var(--apple-blue));color:#fff}.chapter-selector-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.chapter-selector-modal{background:var(--bg-primary);border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:400px;width:100%;max-height:80vh;overflow:hidden;border:1px solid var(--border-color)}.chapter-selector-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.chapter-selector-header h3{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.chapter-selector-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.chapter-selector-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.chapter-selector-content{max-height:60vh;overflow-y:auto;padding:8px}.chapter-selector-item{width:100%;background:none;border:none;padding:12px 16px;border-radius:12px;cursor:pointer;transition:all .2s ease;margin-bottom:4px;text-align:left}.chapter-selector-item:hover{background:var(--bg-tertiary)}.chapter-selector-item.active{background:linear-gradient(135deg,var(--apple-blue),var(--apple-purple));color:#fff;box-shadow:0 4px 16px #007aff4d}.chapter-selector-item-content{display:flex;align-items:center;gap:16px}.chapter-selector-number{font-size:16px;font-weight:600;min-width:24px;text-align:center;color:var(--text-secondary)}.chapter-selector-item.active .chapter-selector-number{color:#fff}.chapter-selector-info{flex:1;display:flex;flex-direction:column;gap:2px}.chapter-selector-title{font-size:14px;font-weight:500;color:var(--text-primary);line-height:1.3}.chapter-selector-item.active .chapter-selector-title{color:#fff}.chapter-selector-duration{font-size:12px;color:var(--text-secondary);font-weight:400}.chapter-selector-item.active .chapter-selector-duration{color:#fffc}.chapter-selector-current-indicator{color:#fff;display:flex;align-items:center;justify-content:center;width:24px;height:24px}.chapter-selector-content::-webkit-scrollbar{width:6px}.chapter-selector-content::-webkit-scrollbar-track{background:transparent}.chapter-selector-content::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.chapter-selector-content::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}@media (max-width: 480px){.chapter-selector-overlay{padding:16px}.chapter-selector-modal{max-width:100%;max-height:85vh}.chapter-selector-header{padding:16px 20px}.chapter-selector-header h3{font-size:16px}.chapter-selector-content{max-height:65vh;padding:6px}.chapter-selector-item{padding:10px 14px}.chapter-selector-item-content{gap:12px}.chapter-selector-number{font-size:14px;min-width:20px}.chapter-selector-title{font-size:13px}.chapter-selector-duration{font-size:11px}}.header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px 12px;flex-shrink:0;position:relative;z-index:10;border:none!important}.app-title{font-size:2rem;font-weight:700;color:var(--text-primary);margin-top:-8px;margin-bottom:-2px;margin-left:-15px;background:linear-gradient(135deg,var(--apple-blue),var(--apple-purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-fill-color:transparent;font-family:Rubik,sans-serif;letter-spacing:0px;text-transform:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}.header-controls{display:flex;align-items:center;gap:16px;margin-top:-8px;margin-bottom:-2px;margin-right:-15px}.chapter-indicator{font-size:.9rem;font-weight:500;color:var(--text-secondary);background-color:var(--bg-tertiary);padding:6px 12px;border-radius:16px}.book-selector-toggle{display:flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--apple-blue),var(--apple-purple));color:#fff;border:none;padding:10px 16px;border-radius:24px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.25,.46,.45,.94);text-decoration:none;box-shadow:0 4px 12px #007aff4d;font-family:Rubik,sans-serif}.book-selector-toggle:hover{transform:translateY(-2px);box-shadow:0 6px 20px #007aff66;background:linear-gradient(135deg,#0056cc,#8a4fd8)}.book-selector-toggle:active{transform:translateY(0);box-shadow:0 2px 8px #007aff4d}.book-selector-toggle svg{font-size:1.1rem}.book-selector-toggle span{font-weight:600;letter-spacing:.5px}.pill-size{width:100px;height:32px;padding:0;border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:.95rem;font-weight:600;box-sizing:border-box;background:linear-gradient(135deg,var(--apple-blue),var(--apple-purple));color:#fff;border:none;box-shadow:0 4px 12px #007aff4d;transition:all .3s cubic-bezier(.25,.46,.45,.94);overflow:hidden}.pill-size span{font-weight:600;letter-spacing:.5px;width:100%;text-align:center;font-size:.92rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pill-size:hover{transform:translateY(-2px);box-shadow:0 6px 20px #007aff66;background:linear-gradient(135deg,#0056cc,#8a4fd8)}.pill-size:active{transform:translateY(0);box-shadow:0 2px 8px #007aff4d}@media (max-width: 480px){.header{padding:12px 16px 8px;border-radius:0;border-bottom:1px solid rgba(255,255,255,.1)}.header-controls{gap:12px;margin-top:-4px;margin-bottom:0;margin-right:-8px}.app-title{font-size:1.5rem;letter-spacing:.5px;margin-top:-4px;margin-bottom:0;margin-left:-8px}.chapter-indicator{font-size:11px;padding:5px 10px;border-radius:12px}.book-selector-toggle{padding:8px 14px;font-size:.8rem;border-radius:20px}.book-selector-toggle svg{font-size:1rem}.pill-size{width:90px;height:28px;border-radius:16px;box-shadow:0 2px 6px #007aff33;transition:none;position:relative;overflow:hidden}.pill-size span{display:block;font-size:.85rem;transition:opacity .35s cubic-bezier(.4,0,.2,1),transform .35s cubic-bezier(.4,0,.2,1);will-change:opacity,transform}.pill-size.changing span{opacity:0;transform:translateY(8px) scale(.95);pointer-events:none}.pill-size:not(.changing) span{opacity:1;transform:translateY(0) scale(1)}.pill-size:hover,.pill-size:active{background:linear-gradient(135deg,var(--apple-blue),var(--apple-purple));box-shadow:0 2px 6px #007aff33;transform:none}}.menu-toggle{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:50%;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.menu-toggle:hover{background:#ffffff1a;color:var(--text-primary)}.menu-toggle svg{font-size:24px}.glass-popover{position:absolute;top:100%;right:0;margin-top:-4px;background:#ffffff40;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);border-radius:16px;box-shadow:0 8px 32px #0000004d;padding:16px;min-width:200px;z-index:1000;animation:popoverFadeIn .2s ease-out}[data-theme=dark] .glass-popover{background:#00000040;border:1px solid rgba(0,0,0,.2);box-shadow:0 8px 32px #0006}[data-theme=light] .glass-popover{background:#fff8;border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0003}@keyframes popoverFadeIn{0%{opacity:0;transform:translateY(-8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes popoverFadeInMobile{0%{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes popoverFadeOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-4px) scale(.98)}}.glass-popover.closing{animation:popoverFadeOut .2s ease-in forwards}.popover-content{display:flex;flex-direction:column;gap:16px}.popover-item{display:flex;align-items:center;justify-content:space-between;gap:12px}.popover-label{font-size:14px;font-weight:500;font-family:Rubik,sans-serif;color:#fff!important;white-space:nowrap;flex-shrink:0;text-align:right;margin-left:auto}[data-theme=light] .popover-label{color:#000c!important}.glass-popover .image-fit-switcher{margin-right:0}.glass-popover .theme-switcher{margin:0}@media (max-width: 480px){.glass-popover{right:8px;min-width:200px;max-width:calc(100vw - 32px);padding:16px;border-radius:12px;margin-top:8px;animation:popoverFadeInMobile .3s ease-out}.popover-label{font-size:14px}.popover-item{gap:12px}}.theme-switcher{background-color:var(--bg-tertiary);border:none;border-radius:20px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;padding:4px;position:relative;width:56px;height:32px;transition:background-color .3s ease}.theme-switcher:focus{outline:none}.theme-switcher .icon{color:var(--text-secondary);transition:transform .3s ease,color .3s ease;font-size:20px!important}.theme-switcher .icon.active{color:var(--text-primary)}.theme-switcher:before{content:"";position:absolute;top:3px;left:3px;width:26px;height:26px;background-color:var(--bg-primary);border-radius:50%;box-shadow:0 1px 3px #0003;transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.theme-switcher .sun{transform:translate(2px,1px)}.theme-switcher .moon{transform:translate(0)}[data-theme=dark] .theme-switcher:before{transform:translate(24px)}:root{--border-radius: 16px;--transition-medium: .3s ease-in-out;--placeholder-bg: #f0f0f0;--error-bg: #fff0f0;--accent-color: #007aff;--text-secondary: #666}.image-viewer{position:relative;width:100%;height:100%;display:flex;justify-content:center;align-items:center;flex:1;min-height:0;overflow:hidden;border-radius:var(--border-radius);cursor:pointer;background:var(--background, #0000);transition:all .12s cubic-bezier(.25,.46,.45,.94);-webkit-transform:translateZ(0);transform:translateZ(0);-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-perspective:1000;perspective:1000}.image-viewer:hover{transform:var(--transform, scale(1));box-shadow:var(--box-shadow, 0 0 0 0 #0000);background:var(--background-hover, #0000)}.image-container,.image-viewer-container,.timed-image-wrapper,.image-slide-wrapper{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;border-radius:var(--border-radius);box-sizing:border-box;-webkit-transform:translateZ(0);transform:translateZ(0);-webkit-backface-visibility:hidden;backface-visibility:hidden}.image-container:active{transform:scale(.98)}.chapter-image,.chapter-image-slide,.cover-image{width:100%;height:100%;object-fit:cover;border-radius:var(--border-radius);opacity:0;transition:opacity var(--transition-medium);-webkit-transform:translateZ(0);transform:translateZ(0);-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-perspective:1000;perspective:1000;image-rendering:-webkit-optimize-contrast;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges;image-rendering:pixelated;-ms-interpolation-mode:nearest-neighbor;font-size:0;line-height:0}.chapter-image.visible,.chapter-image-slide.visible{opacity:1;transition:opacity .5s ease-out}.chapter-image-slide.crossfade-prev{opacity:1;z-index:0;transition:opacity .3s ease-out}@supports (-webkit-touch-callout: none){.chapter-image-slide{transition:opacity .5s ease-out!important;-webkit-transform:translateZ(0)!important;transform:translateZ(0)!important;image-rendering:-webkit-optimize-contrast!important;image-rendering:crisp-edges!important}.chapter-image-slide.visible{transition:opacity .5s ease-out!important}.chapter-image-slide.crossfade-prev{transition:opacity .3s ease-out!important}.timed-image-wrapper img{transition:opacity .5s ease-out!important}.image-viewer,.image-viewer-container,.timed-image-wrapper{-webkit-transform:translateZ(0)!important;transform:translateZ(0)!important;-webkit-backface-visibility:hidden!important;backface-visibility:hidden!important}}.image-placeholder,.image-error{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#ffffffb3;border-radius:var(--border-radius);text-align:center}.loading-spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top-color:#fffc;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-icon{font-size:32px;margin-bottom:8px;opacity:.6}.image-error p{font-size:14px;line-height:1.3;padding:0 16px}.drag-handle{position:absolute;top:0;right:0;bottom:0;left:0;cursor:grab}.drag-handle:active{cursor:grabbing}.image-fit-switcher{width:56px;height:32px;padding:7px;margin-right:8px;display:flex;align-items:center;justify-content:space-between;position:relative;background:var(--bg-tertiary);border:none;border-radius:20px;cursor:pointer;transition:background-color .3s ease}.image-fit-switcher .icon{font-size:16px!important;color:var(--text-secondary);transition:all .3s cubic-bezier(.4,0,.2,1);z-index:2;transform:scale(1);opacity:.7}.image-fit-switcher .icon.active{color:var(--text-primary);opacity:1;transform:scale(1.1);filter:drop-shadow(0 1px 2px rgba(0,0,0,.2))}.image-fit-switcher:active .icon{transform:scale(.95);transition:all .1s ease}.image-fit-switcher-slider{content:"";position:absolute;top:3px;width:26px;height:26px;background-color:var(--bg-primary);border-radius:50%;box-shadow:0 1px 3px #0003;z-index:1}.chapter-image.contain,.chapter-image-slide.contain{background:transparent!important;position:absolute!important;top:50%!important;left:50%!important;max-width:100%!important;max-height:100%!important;width:auto!important;height:auto!important;-webkit-transform:translate(-50%,-50%) translateZ(0)!important;transform:translate(-50%,-50%) translateZ(0)!important}[data-theme=dark] .chapter-image.contain,[data-theme=dark] .chapter-image-slide.contain,[data-theme=light] .chapter-image.contain,[data-theme=light] .chapter-image-slide.contain{background:transparent!important}.image-viewer.contain,.image-viewer-container.contain,.timed-image-wrapper.contain{background:transparent!important;border-radius:0!important;box-shadow:none!important}.chapter-image-slide.contain,video.chapter-image-slide.contain{position:absolute!important;top:50%!important;left:50%!important;max-width:100%!important;max-height:100%!important;width:auto!important;height:auto!important}@media (min-width: 481px){.image-viewer-container,.timed-image-wrapper,.chapter-image-slide{width:100%;height:100%;max-width:100%;max-height:100%}}@media screen and (-webkit-min-device-pixel-ratio: 0){.chapter-image-slide{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}}@supports (-webkit-touch-callout: none){.timed-image-wrapper{-webkit-transform:translateZ(0);transform:translateZ(0)}.chapter-image-slide{transition:opacity .5s ease-out!important}}.image-modal{position:fixed;top:0;left:0;width:100%;height:100%;z-index:20;display:flex;align-items:center;justify-content:center;padding:0}.image-modal:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:0;pointer-events:auto;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.image-modal-content{max-width:95vw;max-height:95vh;object-fit:contain;border-radius:var(--radius-large);box-shadow:0 25px 50px -12px #00000080;z-index:1;position:relative}:root{--landing-bg: var(--desktop-bg);--landing-title: #fff;--landing-title-shadow: 0 6px 32px rgba(0,0,0,.18), 0 1.5px 6px rgba(0,0,0,.08);--landing-btn-bg: linear-gradient(135deg, var(--apple-blue), var(--apple-purple));--landing-btn-color: #fff;--landing-btn-shadow: 0 6px 20px 0 rgba(0,122,255,.18);--slide-shadow: 0 8px 32px 0 rgba(100, 100, 255, .12), 0 1.5px 6px 0 rgba(123,47,242,.08);--slide-border: 2.5px solid #fff;--eq-bar-color: #fff;--eq-bar-opacity: .45}[data-theme=dark]{--landing-bg: linear-gradient(120deg, #23232a 0%, #2c2c2e 60%, #3a2e4d 100%);--landing-title: #fff;--landing-title-shadow: 0 6px 32px rgba(0,0,0,.38), 0 1.5px 6px rgba(0,0,0,.18);--landing-btn-bg: linear-gradient(135deg, var(--apple-blue), var(--apple-purple));--landing-btn-color: #fff;--landing-btn-shadow: 0 6px 20px 0 rgba(0,122,255,.32);--slide-shadow: 0 8px 32px 0 rgba(0,0,0,.28), 0 1.5px 6px 0 rgba(0,0,0,.18);--slide-border: 2.5px solid #222b3a;--eq-bar-color: #222b3a;--eq-bar-opacity: .7}.landing-root{position:fixed;top:0;right:0;bottom:0;left:0;width:100vw;height:100vh;overflow:hidden;z-index:2000;display:flex;align-items:center;justify-content:center;background:var(--landing-bg);animation:landingFadeIn 1.2s cubic-bezier(.22,.61,.36,1)}@keyframes landingFadeIn{0%{opacity:0;transform:scale(1.04)}to{opacity:1;transform:scale(1)}}.landing-content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100vw;height:100vh;animation:contentAppear 1.2s .2s cubic-bezier(.22,.61,.36,1) both}@keyframes contentAppear{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.landing-title{font-family:Rubik,Segoe UI,Arial,sans-serif;font-size:clamp(5.5rem,16vw,13rem);color:var(--landing-title);letter-spacing:.005em;font-weight:900;text-transform:lowercase;margin-bottom:1.2rem;transition:transform .4s cubic-bezier(.22,.61,.36,1),color .3s,text-shadow .3s;text-align:center;pointer-events:auto;line-height:1.04;-webkit-user-select:none;user-select:none;text-shadow:var(--landing-title-shadow);position:relative;z-index:100}.landing-subtitle{font-family:Rubik,sans-serif;font-size:clamp(1.25rem,2.5vw,2.2rem);color:#e0e0e0;margin-bottom:1.1rem;text-align:center;text-shadow:0 2px 8px rgba(0,0,0,.18);font-weight:500;transition:transform .4s cubic-bezier(.22,.61,.36,1);pointer-events:auto;letter-spacing:.04em;-webkit-user-select:none;user-select:none;position:relative;z-index:100}.landing-tagline{font-family:Rubik,sans-serif;font-size:clamp(1.1rem,1.7vw,1.5rem);color:#b7b7c9;margin-bottom:2.2rem;text-align:center;opacity:.92;letter-spacing:.02em;pointer-events:auto;-webkit-user-select:none;user-select:none;animation:taglineFadeIn 1.2s .5s cubic-bezier(.22,.61,.36,1) both;font-weight:400;position:relative;z-index:100}@keyframes taglineFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:.92;transform:translateY(0)}}.landing-start-btn{pointer-events:auto;padding:20px 64px;font-size:1.4rem;font-family:Rubik,sans-serif;font-weight:700;border-radius:22px;background:linear-gradient(135deg,var(--apple-blue),var(--apple-purple));color:#fff;border:2px solid rgba(255,255,255,.35);box-shadow:0 6px 24px #007aff61,0 0 0 6px #af52de2e;cursor:pointer;transition:background .2s,transform .18s,box-shadow .2s,color .2s,border .2s;margin-top:1.5rem;outline:none;-webkit-user-select:none;user-select:none;animation:btnAppear 1.2s .7s cubic-bezier(.22,.61,.36,1) both;position:relative;overflow:visible;z-index:10}.landing-start-btn:before{content:"";position:absolute;top:-10px;right:-10px;bottom:-10px;left:-10px;border-radius:32px;background:radial-gradient(circle at 60% 40%,var(--apple-purple) 0%,transparent 80%);opacity:.18;z-index:-1;filter:blur(8px);pointer-events:none;transition:opacity .3s}.landing-start-btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:32px;background:linear-gradient(90deg,#ffffff2e,#af52de1a);opacity:.18;z-index:1;filter:blur(1px);pointer-events:none;transition:opacity .3s}.landing-start-btn:hover,.landing-start-btn:focus{background:linear-gradient(135deg,var(--apple-purple) 0%,var(--apple-blue) 100%);transform:scale(1.15);color:#fff;border:2.5px solid rgba(255,255,255,.7);box-shadow:0 0 0 12px #7b2ff238,0 16px 48px 16px var(--apple-blue)}@keyframes btnHoverGlowLightPulse{0%{box-shadow:0 0 0 12px #5856d624,0 0 16px 4px #fff,0 8px 32px 8px #09f,0 0 80px 24px var(--apple-blue),0 0 40px 12px var(--apple-indigo) inset;filter:brightness(1.1) drop-shadow(0 0 32px #0099ff) drop-shadow(0 0 48px #fff)}60%{box-shadow:0 0 0 36px #5856d652,0 0 64px 16px #fff,0 32px 128px 32px #09f,0 0 200px 64px var(--apple-blue),0 0 160px 32px var(--apple-indigo) inset;filter:brightness(1.45) drop-shadow(0 0 192px #0099ff) drop-shadow(0 0 256px #fff)}to{box-shadow:0 0 0 12px #5856d624,0 0 16px 4px #fff,0 8px 32px 8px #09f,0 0 80px 24px var(--apple-blue),0 0 40px 12px var(--apple-indigo) inset;filter:brightness(1.1) drop-shadow(0 0 32px #0099ff) drop-shadow(0 0 48px #fff)}}.landing-start-btn:active{transform:scale(.97);filter:brightness(.96) drop-shadow(0 0 12px var(--apple-blue))}@media (max-width: 600px){.landing-start-btn{padding:14px 32px;font-size:1rem;border-radius:16px}.landing-start-btn:before{top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:20px}.landing-start-btn:after{top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:20px}}[data-theme=dark] .landing-start-btn{background:linear-gradient(135deg,var(--apple-blue),var(--apple-purple));color:#fff;box-shadow:0 6px 24px #007aff61,0 0 #af52de2e,0 0 0 6px #af52de2e,0 0 32px 8px #007aff2e;filter:drop-shadow(0 0 24px var(--apple-purple)) drop-shadow(0 0 48px var(--apple-blue))}[data-theme=dark] .landing-start-btn:hover,[data-theme=dark] .landing-start-btn:focus{background:linear-gradient(135deg,var(--apple-purple) 0%,var(--apple-blue) 100%);color:#fff;box-shadow:0 0 0 12px #7b2ff238,0 16px 48px 16px var(--apple-blue),0 0 96px 32px var(--apple-purple),0 0 64px 16px var(--apple-blue);filter:brightness(1.22) drop-shadow(0 0 64px var(--apple-purple)) drop-shadow(0 0 96px var(--apple-blue));animation:btnHoverGlowDark 1.2s linear infinite alternate}[data-theme=dark] .landing-start-btn:active{filter:brightness(.96) drop-shadow(0 0 12px var(--apple-blue))}@keyframes btnHoverGlowDark{0%{box-shadow:0 0 0 12px #7b2ff238,0 16px 48px 16px var(--apple-blue),0 0 96px 32px var(--apple-purple),0 0 64px 16px var(--apple-blue);filter:brightness(1.22) drop-shadow(0 0 64px var(--apple-purple)) drop-shadow(0 0 96px var(--apple-blue))}to{box-shadow:0 0 0 24px #7b2ff252,0 32px 96px 32px var(--apple-blue),0 0 192px 64px var(--apple-purple),0 0 128px 32px var(--apple-blue);filter:brightness(1.32) drop-shadow(0 0 96px var(--apple-purple)) drop-shadow(0 0 128px var(--apple-blue))}}[data-theme=light] .landing-start-btn{background:linear-gradient(135deg,var(--apple-blue),var(--apple-purple));color:#fff;box-shadow:0 6px 24px #007aff40,0 0 #af52de1f,0 0 0 6px #af52de1f,0 0 32px 8px #007aff1f;filter:drop-shadow(0 0 16px var(--apple-purple)) drop-shadow(0 0 24px var(--apple-blue))}[data-theme=light] .landing-start-btn:hover,[data-theme=light] .landing-start-btn:focus{background:linear-gradient(135deg,var(--apple-purple) 0%,var(--apple-blue) 100%);color:#fff;transform:scale(1.15);box-shadow:0 0 0 12px #7b2ff226,0 16px 48px 16px var(--apple-blue),0 0 96px 32px var(--apple-purple),0 0 64px 16px var(--apple-blue);filter:brightness(1.22) drop-shadow(0 0 64px var(--apple-purple)) drop-shadow(0 0 96px var(--apple-blue));animation:btnHoverGlowDark 1.2s linear infinite alternate}[data-theme=light] .landing-start-btn:active{filter:brightness(.96) drop-shadow(0 0 12px var(--apple-blue))}.landing-newformat{position:fixed;left:0;right:0;bottom:24px;z-index:100;font-family:Rubik,sans-serif;font-size:clamp(1rem,1.2vw,1.15rem);color:#b7b7c9;text-align:center;opacity:.7;letter-spacing:.01em;font-weight:500;pointer-events:none;-webkit-user-select:none;user-select:none;animation:taglineFadeIn 1.2s .3s cubic-bezier(.22,.61,.36,1) both}.landing-theme-toggle{position:fixed;top:24px;right:24px;z-index:200;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:50%;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease;animation:taglineFadeIn 1.2s .4s cubic-bezier(.22,.61,.36,1) both}.landing-theme-toggle:hover{background:#ffffff26;border-color:#ffffff4d;transform:scale(1.1)}.landing-theme-toggle:active{transform:scale(.95)}.landing-theme-toggle svg{font-size:20px;color:#fffc;transition:color .3s ease}.landing-theme-toggle:hover svg{color:#fff}[data-theme=light] .landing-theme-toggle{background:#0000001a;border-color:#00000026}[data-theme=light] .landing-theme-toggle:hover{background:#00000026;border-color:#00000040}[data-theme=light] .landing-theme-toggle svg{color:#000000b3}[data-theme=light] .landing-theme-toggle:hover svg{color:#000000e6}.parallax-circle{position:absolute;border-radius:50%;pointer-events:none;opacity:.12;z-index:1;filter:blur(.5px);animation:circlePulse 8s ease-in-out infinite alternate}.circle1{width:180px;height:180px;background:radial-gradient(circle at 40% 60%,#7b2ff2,#23232a);animation-delay:0s}.circle2{width:120px;height:120px;background:radial-gradient(circle at 60% 40%,#f357a8,#23232a);animation-delay:1.2s}.circle3{width:90px;height:90px;background:radial-gradient(circle at 50% 50%,#7b2ff2,#f357a8);opacity:.13;animation-delay:2.4s}@media (max-width: 600px){.circle1{width:120px;height:120px}.circle2{width:80px;height:80px}.circle3{width:60px;height:60px}}@keyframes circlePulse{0%{filter:blur(.5px) brightness(1)}to{filter:blur(2.5px) brightness(1.12)}}.parallax-dot{position:absolute;width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,#7b2ff2 60%,#f357a8);opacity:.22;z-index:1;box-shadow:0 0 16px 2px #7b2ff2,0 0 8px 1px #f357a8;animation:dotFloat 5s ease-in-out infinite alternate}@media (max-width: 600px){.parallax-dot{width:12px;height:12px;box-shadow:0 0 8px 1px #7b2ff2,0 0 4px .5px #f357a8}}.dot1{animation-delay:.7s}.dot2{animation-delay:2.1s}@keyframes dotFloat{0%{transform:scale(1) translateY(0)}to{transform:scale(1.18) translateY(-12px)}}.parallax-wave{position:absolute;left:0;right:0;bottom:0;height:120px;z-index:1;pointer-events:none;opacity:.18;animation:waveMove 8s ease-in-out infinite alternate}@keyframes waveMove{0%{filter:blur(.5px)}to{filter:blur(2.5px)}}.glow-blob{position:absolute;border-radius:50%;pointer-events:none;z-index:0;filter:blur(24px) brightness(1.1);opacity:.15;animation:blobMove 16s ease-in-out infinite alternate;transition:opacity .5s}.blob1{width:340px;height:340px;background:radial-gradient(circle at 40% 60%,#7b2ff2,#23232a);animation-delay:0s}.blob2{width:220px;height:220px;background:radial-gradient(circle at 60% 40%,#f357a8,#23232a);animation-delay:2.5s}.blob3{width:180px;height:180px;background:radial-gradient(circle at 50% 50%,#7b2ff2,#f357a8);opacity:.16;animation-delay:5s}@media (max-width: 600px){.blob1{width:200px;height:200px}.blob2{width:140px;height:140px}.blob3{width:100px;height:100px}}@keyframes blobMove{0%{transform:scale(1) translateY(0)}to{transform:scale(1.15) translateY(40px)}}.landing-content>*{animation:fadeUp 1.1s cubic-bezier(.22,.61,.36,1) forwards}.landing-title{animation-delay:.1s}.landing-tagline{animation-delay:.35s}.landing-start-btn{animation-delay:.6s}@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}.landing-start-btn.pulse{animation:btnAppear 1.2s .7s cubic-bezier(.22,.61,.36,1) both,pulseBtn 2.2s infinite cubic-bezier(.4,0,.2,1);box-shadow:0 6px 20px #007aff52,0 0 #af52de1f}@keyframes pulseBtn{0%,to{box-shadow:0 6px 20px #007aff52,0 0 #af52de1f}50%{box-shadow:0 12px 32px #7b2ff238,0 0 24px 8px #af52de2e}}.parallax-circle,.parallax-dot,.parallax-wave{transition:transform .7s cubic-bezier(.22,.61,.36,1),filter .5s}.landing-root{background:var(--landing-bg);overflow:hidden}@media (max-width: 600px){.landing-content{padding:6vh 4vw 0 4vw;align-items:center;justify-content:flex-start;height:auto;min-height:unset}.landing-start-btn:before{filter:blur(4px);top:-6px;right:-6px;bottom:-6px;left:-6px}.landing-start-btn:after{filter:blur(.5px)}.parallax-circle{opacity:.08;animation-duration:12s}.parallax-dot{opacity:.15;animation-duration:8s}.parallax-wave{opacity:.12;animation-duration:12s}.glow-blob{filter:blur(16px) brightness(1.05);opacity:.1;animation-duration:20s}.landing-title{font-size:4.4rem;margin-bottom:.7rem;line-height:1.08}.landing-tagline{font-size:1.18rem;margin-bottom:1.2rem;margin-top:.1rem;line-height:1.3}.landing-start-btn{padding:15px 0;width:100%;max-width:320px;font-size:1.15rem;margin-top:.7rem;margin-bottom:1.1rem;border-radius:18px}.landing-newformat{font-size:.98rem;bottom:10px;padding:0 8px}.landing-theme-toggle{top:16px;right:16px;width:40px;height:40px}.landing-theme-toggle svg{font-size:18px}}@media (max-width: 480px){.landing-start-btn{box-shadow:0 4px 16px #007aff4d}.landing-start-btn:hover,.landing-start-btn:focus{box-shadow:0 0 0 8px #7b2ff226,0 8px 24px 8px var(--apple-blue)}}@media (prefers-reduced-motion: reduce){.landing-start-btn,.landing-title,.landing-subtitle,.landing-tagline,.landing-newformat,.parallax-circle,.parallax-dot,.parallax-wave,.glow-blob{animation:none!important;transition:none!important}.landing-start-btn:before,.landing-start-btn:after{display:none}}.star{position:absolute;width:2.5px;height:2.5px;border-radius:50%;background:#fff;box-shadow:0 0 8px 2px #7b2ff2,0 0 2px #fff;pointer-events:none;z-index:2;animation:starTwinkle var(--star-duration, 4s) infinite alternate;opacity:.7}@keyframes starTwinkle{0%,to{opacity:.7;filter:blur(.5px)}50%{opacity:1;filter:blur(1.5px)}}.comet{position:fixed;left:-120px;top:18vh;z-index:20;pointer-events:none;animation:cometFly 1.7s cubic-bezier(.4,0,.2,1) forwards}@keyframes cometFly{0%{left:-120px;opacity:0}10%{opacity:1}80%{opacity:1}to{left:110vw;opacity:0}}.slides-3d{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none;perspective:1200px;overflow:visible}.slide-3d-wrapper{position:absolute;top:0;left:0;width:180px;height:180px;pointer-events:none;will-change:transform,filter;display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:22px;background:#222;z-index:1;border:var(--slide-border);box-shadow:var(--slide-shadow);outline:2px solid rgba(123,47,242,.08);cursor:grab;pointer-events:auto}.slide-3d-wrapper:active{cursor:grabbing}.slide-3d{position:absolute;top:0;left:0;width:180px;height:180px;object-fit:cover;border-radius:22px;z-index:1}.slide-audio-wave{position:absolute;top:0;left:0;width:100%;height:100%;z-index:2;pointer-events:none;filter:drop-shadow(0 2px 8px #fff8)}.slide-eq-bars{position:absolute;top:0;left:0;width:180px!important;height:180px!important;z-index:2;pointer-events:none}.slide-eq-bars rect{fill:var(--eq-bar-color);opacity:var(--eq-bar-opacity)}@media (max-width: 600px){.slide-3d-wrapper,.slide-3d{width:90px;height:90px;border-radius:10px}.slide-eq-bars{width:90px!important;height:90px!important}}.audio-quality-selector{position:relative;display:inline-block}.quality-button{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff;cursor:pointer;transition:all .2s ease;font-size:14px;min-width:120px}.quality-button:hover{background:#ffffff26;border-color:#ffffff4d}.quality-button.active{background:#fff3;border-color:#fff6}.quality-name{font-weight:500}.quality-bitrate{font-size:12px;opacity:.7;background:#ffffff1a;padding:2px 6px;border-radius:3px}.quality-arrow{transition:transform .2s ease;margin-left:auto}.quality-arrow.rotated{transform:rotate(180deg)}.quality-dropdown{position:absolute;top:100%;left:0;right:0;background:#000000f2;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:8px 0;margin-top:4px;z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 32px #0000004d}.quality-option{position:relative;padding:12px 16px;cursor:pointer;transition:background-color .2s ease;display:flex;align-items:center;justify-content:space-between}.quality-option:hover{background:#ffffff1a}.quality-option.selected{background:#ffffff26}.quality-option-header{display:flex;flex-direction:column;gap:4px}.quality-option-name{font-weight:500;color:#fff;font-size:14px}.quality-option-bitrate{font-size:12px;color:#ffffffb3;background:#ffffff1a;padding:2px 6px;border-radius:3px;display:inline-block;width:fit-content}.quality-option-description{font-size:12px;color:#fff9;margin-top:2px}.quality-option-check{color:#4caf50;margin-left:12px}.loading-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.quality-button.loading{opacity:.7;cursor:not-allowed}.quality-button.error{background:#f4433633;border-color:#f4433666;color:#ffcdd2}[data-theme=dark] .quality-button{background:#ffffff0d;border-color:#ffffff1a}[data-theme=dark] .quality-button:hover{background:#ffffff1a;border-color:#fff3}[data-theme=dark] .quality-dropdown{background:#000000fa;border-color:#ffffff1a}[data-theme=light] .quality-button{background:#0000001a;border-color:#0003;color:#333}[data-theme=light] .quality-button:hover{background:#00000026;border-color:#0000004d}[data-theme=light] .quality-dropdown{background:#fffffffa;border-color:#0000001a;color:#333}[data-theme=light] .quality-option-name{color:#333}[data-theme=light] .quality-option-bitrate{color:#000000b3;background:#0000001a}[data-theme=light] .quality-option-description{color:#0009}.book-selector{padding:12px;max-width:1200px;margin:0 auto;display:flex;flex-direction:column;justify-content:flex-start;overflow:visible;position:absolute;top:0;left:0;right:0;bottom:0;height:100%}.book-selector-loading,.book-selector-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;color:var(--text-secondary);position:relative;border-radius:var(--radius-large);overflow:hidden;background:var(--bg-secondary);padding:40px 20px;text-align:center;font-family:Rubik,sans-serif}.book-selector-loading:before,.book-selector-empty:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#007aff0d,#af52de0d,#007aff0d);opacity:1;transition:opacity var(--transition-medium)}.loading-spinner{width:40px;height:40px;border:3px solid transparent;border-top:3px solid var(--apple-blue);border-right:3px solid var(--apple-purple);border-radius:50%;animation:spin 1.2s linear infinite;margin-bottom:16px;position:relative;z-index:2}.loading-spinner:after{content:"";position:absolute;top:-3px;left:-3px;right:-3px;bottom:-3px;border:3px solid transparent;border-top:3px solid rgba(0,122,255,.3);border-radius:50%;animation:spin 2s linear infinite reverse}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.book-selector-loading p,.book-selector-empty p{color:var(--text-primary);font-size:1rem;font-weight:500;margin:0;line-height:1.5;position:relative;z-index:2;letter-spacing:.5px;font-family:Rubik,sans-serif}.book-selector-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-top:0;padding:0x 0px 0px;overflow:visible;position:relative;z-index:1}@media (max-width: 768px) and (max-height: 900px){.book-selector-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px) and (max-height: 600px){.book-selector-grid{grid-template-columns:repeat(2,1fr)}}@media (max-height: 715px){.book-card.modern{transform:scale(.95);transform-origin:center center}}@media (max-height: 650px){.book-card.modern{transform:scale(.9);transform-origin:center center}}@media (max-height: 580px){.book-card.modern{transform:scale(.85);transform-origin:center center}}@media (max-height: 520px){.book-card.modern{transform:scale(.8);transform-origin:center center}}.book-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:8px;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden;transform-style:preserve-3d;perspective:1000px;max-width:320px}.book-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#007aff0d,#af52de0d,#007aff0d);opacity:0;transition:opacity .2s ease;border-radius:8px}.book-card:hover{transform:translateY(-2px) rotateX(2deg) rotateY(2deg);border-color:var(--apple-blue)}.book-card:hover:before{opacity:1}.book-cover{position:relative;width:100%;aspect-ratio:1;margin-bottom:8px;border-radius:8px;overflow:hidden;background:var(--bg-tertiary);transform:translateZ(10px)}.book-cover img{width:100%;height:100%;object-fit:cover;transition:transform .2s ease}.book-card:hover .book-cover img{transform:scale(1.05)}.book-cover-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:1.2rem;color:var(--text-secondary);background:var(--bg-tertiary)}.book-info{flex:1;position:relative;z-index:2}.book-title{font-size:.9rem;font-weight:600;color:var(--text-primary);margin-bottom:4px;line-height:1.2;font-family:Rubik,sans-serif;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.book-description{color:var(--text-secondary);font-size:.8rem;line-height:1.2;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-family:Rubik,sans-serif}.book-meta{display:none}.book-chapters{position:absolute;top:6px;right:6px;background:linear-gradient(135deg,var(--apple-blue),var(--apple-purple));color:#fff;padding:4px 6px;border-radius:6px;font-size:.65rem;font-weight:600;font-family:Rubik,sans-serif;box-shadow:0 3px 8px #007aff4d;z-index:3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@media (max-width: 768px){.book-selector{padding:10px;top:0;bottom:0;height:100%;overflow:visible}.book-selector-grid{grid-template-columns:repeat(3,1fr);gap:5px;max-height:55vh;padding:16px}@media (max-height: 900px){.book-selector-grid{grid-template-columns:repeat(2,1fr)}}@media (max-height: 600px){.book-selector-grid{grid-template-columns:repeat(3,1fr)}}@media (max-height: 715px){.book-card.modern{transform:scale(.95);transform-origin:center center}}@media (max-height: 650px){.book-card.modern{transform:scale(.9);transform-origin:center center}}@media (max-height: 580px){.book-card.modern{transform:scale(.85);transform-origin:center center}}@media (max-height: 520px){.book-card.modern{transform:scale(.8);transform-origin:center center}}.book-card{padding:6px;border-radius:10px;max-width:280px}.book-title{font-size:.85rem}.book-description{font-size:.75rem}.book-chapters{font-size:.6rem;padding:3px 5px;top:5px;right:5px}}@media (max-width: 480px){.book-selector{padding:8px;top:0;bottom:0;height:100%;overflow:visible}.book-selector-grid{grid-template-columns:repeat(2,1fr);gap:4px;padding:12px}@media (max-height: 900px){.book-selector-grid{grid-template-columns:repeat(3,1fr)}}@media (max-height: 600px){.book-selector-grid{grid-template-columns:repeat(3,1fr)}}@media (max-height: 715px){.book-card.modern{transform:scale(.95);transform-origin:center center}}@media (max-height: 650px){.book-card.modern{transform:scale(.9);transform-origin:center center}}@media (max-height: 580px){.book-card.modern{transform:scale(.85);transform-origin:center center}}@media (max-height: 520px){.book-card.modern{transform:scale(.8);transform-origin:center center}}.book-card{padding:5px;border-radius:9px;max-width:240px}.book-title{font-size:.8rem}.book-description{font-size:.7rem}.book-chapters{font-size:.55rem;padding:2px 4px;top:4px;right:4px}}@media (max-width: 360px){.book-selector{top:0;bottom:0;height:100%;overflow:visible}.book-selector-grid{grid-template-columns:repeat(2,1fr);gap:3px;padding:10px}@media (max-height: 900px){.book-selector-grid{grid-template-columns:repeat(3,1fr)}}@media (max-height: 600px){.book-selector-grid{grid-template-columns:repeat(3,1fr)}}@media (max-height: 715px){.book-card.modern{transform:scale(.95);transform-origin:center center}}@media (max-height: 650px){.book-card.modern{transform:scale(.9);transform-origin:center center}}@media (max-height: 580px){.book-card.modern{transform:scale(.85);transform-origin:center center}}@media (max-height: 520px){.book-card.modern{transform:scale(.8);transform-origin:center center}}.book-card{padding:4px;border-radius:8px;max-width:220px}.book-title{font-size:.75rem}.book-description{font-size:.65rem}.book-chapters{font-size:.5rem;padding:2px 3px;top:3px;right:3px}}.book-card.modern{background:var(--bg-primary);border-radius:20px;box-shadow:0 12px 40px #00000040,0 6px 20px #00000026,0 2px 8px #0000001a;border:1px solid rgba(255,255,255,.1);padding:0;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;min-height:240px;max-width:240px;cursor:pointer;position:relative;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none;pointer-events:auto}.book-card.modern:hover{box-shadow:0 20px 60px #00000059,0 10px 30px #00000040,0 4px 12px #00000026;transform:translateY(-8px) scale(1.02);border-color:#fff3}.book-card-cover-wrapper{position:relative;width:100%;aspect-ratio:1/1.2;background:linear-gradient(135deg,var(--bg-tertiary),rgba(0,122,255,.05));display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:20px 20px 0 0}.book-card-cover{width:100%;height:100%;object-fit:cover;border-radius:20px 20px 0 0;transition:transform .4s cubic-bezier(.4,0,.2,1);z-index:1;filter:brightness(.95) contrast(1.05)}.book-card.modern:hover .book-card-cover{transform:scale(1.08);filter:brightness(1.05) contrast(1.1)}.book-card-cover-placeholder{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;font-size:2.5rem;color:var(--text-secondary);background:var(--bg-tertiary);z-index:0}.book-card-chapters{position:absolute;top:8px;left:8px;background:linear-gradient(135deg,var(--apple-blue),var(--apple-purple));color:#fff;padding:4px 10px;border-radius:12px;font-size:.7rem;font-weight:700;box-shadow:0 4px 12px #007aff4d,0 2px 4px #0003;z-index:2;letter-spacing:.3px;-webkit-user-select:none;user-select:none;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);transition:all .3s ease}.book-card-info{flex:1;display:flex;flex-direction:column;padding:12px 12px 10px;gap:6px;background:linear-gradient(180deg,#ffffff05,#ffffff0d);border-radius:0 0 20px 20px}.book-card-title{font-size:1rem;font-weight:800;color:var(--text-primary);margin:0 0 3px;line-height:1.25;font-family:Rubik,sans-serif;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-shadow:0 1px 2px rgba(0,0,0,.1)}.book-card-author{font-size:.85rem;color:var(--apple-blue);font-weight:600;margin-bottom:3px;font-family:Rubik,sans-serif;opacity:.9;letter-spacing:.2px}.book-card-description{color:var(--text-secondary);font-size:.78rem;line-height:1.35;margin:0 0 10px;font-family:Rubik,sans-serif;opacity:.85;letter-spacing:.1px;display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;word-wrap:break-word}.book-card-more{display:flex;align-items:center;justify-content:flex-end;margin-top:auto;padding-top:4px;border-top:1px solid rgba(255,255,255,.05)}.book-card-more-icon{font-size:1.1rem;color:var(--apple-purple);opacity:.8;transition:all .3s ease;margin-left:6px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.book-card.modern:hover .book-card-more-icon{opacity:1;color:var(--apple-blue);transform:translate(2px);filter:drop-shadow(0 2px 4px rgba(0,122,255,.3))}[data-theme=light] .book-card.modern{background:#ffffffe6;border:1px solid rgba(0,0,0,.08);box-shadow:0 8px 32px #007aff14,0 4px 16px #af52de0f,0 2px 8px #0000000d}[data-theme=light] .book-card.modern:hover{box-shadow:0 16px 48px #007aff26,0 8px 24px #af52de1a,0 4px 12px #00000014;border-color:#00000026}[data-theme=light] .book-card-cover-wrapper{background:linear-gradient(135deg,#fffc,#007aff08)}[data-theme=light] .book-card-info{background:linear-gradient(180deg,#ffffff4d,#ffffff1a)}[data-theme=light] .book-card-more{border-top:1px solid rgba(0,0,0,.05)}[data-theme=dark] .book-card.modern{box-shadow:0 12px 40px #00000040,0 6px 20px #00000026,0 2px 8px #0000001a}[data-theme=dark] .book-card.modern:hover{box-shadow:0 20px 60px #00000059,0 10px 30px #00000040,0 4px 12px #00000026}[data-theme=dark] .book-modal-chapter-item:hover{background:var(--bg-secondary);border:1px solid var(--apple-blue);transform:translateY(-1px);box-shadow:0 4px 12px #007aff33}[data-theme=dark] .book-modal-chapter-item.selected{background:linear-gradient(135deg,var(--apple-blue),var(--apple-purple));border:1px solid var(--apple-blue);box-shadow:0 6px 20px #007aff66;transform:translateY(-2px)}@media (max-width: 768px){.book-card.modern{min-height:200px;max-width:90vw;border-radius:16px;min-width:44px;min-height:44px}.book-card-info{padding:6px 5px 5px}.book-card-title{font-size:.85rem}.book-card-author{font-size:.7rem}.book-card-description{font-size:.65rem;-webkit-line-clamp:2}.book-card-chapters{font-size:.55rem;padding:2px 5px;top:4px;left:4px}}@media (max-width: 480px){.book-card.modern{min-height:240px;border-radius:20px;max-width:240px;padding:0;min-width:48px;min-height:48px}[data-theme=dark] .book-card.modern{box-shadow:0 12px 40px #00000040,0 6px 20px #00000026,0 2px 8px #0000001a}[data-theme=light] .book-card.modern{box-shadow:0 8px 32px #007aff14,0 4px 16px #af52de0f,0 2px 8px #0000000d}.book-card-info{padding:10px 8px 8px;gap:4px}.book-card-title{font-size:.98rem;font-weight:700;color:var(--text-primary);margin:0 0 2px;line-height:1.22;font-family:Rubik,sans-serif;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.book-card-author{font-size:.82rem;color:var(--apple-blue);font-weight:500;margin-bottom:2px;font-family:Rubik,sans-serif;opacity:.85}.book-card-description{color:var(--text-secondary);font-size:.75rem;-webkit-line-clamp:2;line-height:1.32;margin:0 0 8px;font-family:Rubik,sans-serif}.book-card-chapters{font-size:.7rem;padding:3px 8px;top:7px;left:7px;border-radius:9px}}@media (min-width: 769px) and (min-height: 901px){.book-selector-grid{grid-template-columns:repeat(4,1fr);justify-items:start;justify-content:start;padding:0}}@media (min-width: 769px) and (max-height: 900px){.book-selector-grid{grid-template-columns:repeat(3,1fr);justify-items:start;justify-content:start;padding:0}}@media (min-width: 769px) and (max-height: 600px){.book-selector-grid{grid-template-columns:repeat(3,1fr);justify-items:start;justify-content:start;padding:0}}@media (min-width: 769px) and (max-height: 715px){.book-card.modern{transform:scale(.95);transform-origin:center center}}@media (min-width: 769px) and (max-height: 650px){.book-card.modern{transform:scale(.9);transform-origin:center center}}@media (min-width: 769px) and (max-height: 580px){.book-card.modern{transform:scale(.85);transform-origin:center center}}@media (min-width: 769px) and (max-height: 520px){.book-card.modern{transform:scale(.8);transform-origin:center center}}@media (min-width: 769px) and (max-height: 900px){.book-modal-card{max-height:90vh!important;max-width:60vw!important;width:80vw!important}.book-modal-content{transform:none!important;flex-direction:row!important;gap:0!important}.book-modal-left-section{flex:0 0 50%!important;display:flex!important;flex-direction:column!important;border-right:1px solid var(--border-color)!important}.book-modal-right-section{flex:0 0 50%!important;display:flex!important;flex-direction:column!important;overflow:hidden!important}.book-modal-cover-block{aspect-ratio:1/.8!important;border-radius:24px 0 0!important}.book-modal-info{padding:16px 20px 12px!important;gap:6px!important;flex:1!important}.book-modal-title{font-size:1.2rem!important;line-height:1.3!important}.book-modal-author{font-size:.9rem!important}.book-modal-description{font-size:.85rem!important;line-height:1.4!important}.book-modal-actions{margin-top:auto!important;padding-top:12px!important}.book-modal-chapters-list-blur{flex:1!important;max-height:none!important;border-radius:0 0 24px!important;overflow:hidden!important}.book-modal-chapters-list{padding:16px 20px!important;gap:8px!important;height:100%!important;overflow-y:auto!important}.book-modal-chapter-item{padding:10px 12px!important;gap:10px!important;font-size:.9rem!important}.book-modal-close{top:12px!important;right:12px!important;z-index:15!important}}.book-selector-horizontal{display:grid!important;grid-template-columns:repeat(2,1fr);overflow-x:hidden;overflow-y:auto;gap:16px;padding:20px;scrollbar-width:thin;scrollbar-color:var(--apple-blue) var(--bg-secondary);overscroll-behavior-y:contain;-webkit-overflow-scrolling:touch;touch-action:pan-y;position:relative}.book-selector-horizontal .book-card.modern{width:100%;max-width:none;min-width:auto}.book-selector-horizontal::-webkit-scrollbar{width:8px;background:var(--bg-secondary);border-radius:8px}.book-selector-horizontal::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--apple-blue),var(--apple-purple));border-radius:8px}@media (max-width: 768px){.book-selector-horizontal{min-height:350px;max-height:100vh;max-width:100vw;padding:12px 8px 8px;grid-template-columns:repeat(2,1fr);gap:8px}.book-card.modern{width:100%;max-width:none;min-width:auto;min-height:250px}}.book-modal-overlay{position:fixed;z-index:1000;top:0;right:0;bottom:0;left:0;background:#14141e73;display:flex;align-items:center;justify-content:center;animation:modal-fade-in .3s;padding:20px;transform-style:preserve-3d;backface-visibility:hidden;will-change:opacity}.book-modal-overlay.closing{animation:modal-fade-out .4s cubic-bezier(.4,0,.2,1);animation-fill-mode:forwards}[data-theme=light] .book-modal-overlay{background:#0000004d}[data-theme=light] .book-modal-card{background:var(--bg-primary);border:2px solid var(--border-color);box-shadow:0 8px 48px #0000001f}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-fade-out{0%{opacity:1}to{opacity:0}}.book-modal-card{background:var(--bg-primary);border-radius:32px;box-shadow:0 8px 48px #0000002e;max-width:480px;width:95vw;max-height:90vh;display:flex;flex-direction:column;position:relative;overflow:hidden;animation:modal-zoom-in .35s cubic-bezier(.22,1,.36,1);border:2px solid var(--border-color);transform-style:preserve-3d;backface-visibility:hidden;will-change:transform,opacity}.book-modal-overlay.closing .book-modal-card{animation:modal-zoom-out .4s cubic-bezier(.4,0,.2,1);animation-fill-mode:forwards}.book-modal-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.book-modal-left-section,.book-modal-right-section{display:flex;flex-direction:column}@keyframes modal-zoom-in{0%{transform:scale(.85) translateY(40px);opacity:.5}to{transform:scale(1) translateY(0);opacity:1}}@keyframes modal-zoom-out{0%{transform:scale(1) translateY(0);opacity:1}to{transform:scale(.85) translateY(40px);opacity:.5}}.book-modal-close{position:absolute;top:18px;right:18px;z-index:10;background:#1e1e28b3;color:#fff;border:none;border-radius:50%;width:36px;height:36px;font-size:1.5rem;cursor:pointer;box-shadow:0 2px 8px #0000001f;display:flex;align-items:center;justify-content:center;transition:background .18s;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none;min-width:44px;min-height:44px}.book-modal-close:hover{background:#3c3c50d9}.book-modal-close:disabled{opacity:.6;cursor:not-allowed}.book-modal-close:disabled:hover{background:#1e1e28b3}.book-modal-cover-block{position:relative;width:100%;aspect-ratio:1/1;background:var(--bg-tertiary);display:flex;align-items:flex-end;justify-content:center;overflow:hidden}.book-modal-cover{width:100%;height:100%;object-fit:cover;border-radius:0;z-index:1;box-shadow:0 2px 16px #0000001a}.book-modal-chapters-chip{position:absolute;top:16px;left:16px;background:linear-gradient(135deg,var(--apple-blue),var(--apple-purple));color:#fff;padding:6px 14px;border-radius:12px;font-size:.92rem;font-weight:600;box-shadow:0 2px 8px #007aff21;z-index:2;letter-spacing:.2px;-webkit-user-select:none;user-select:none;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.book-modal-info{padding:22px 24px 10px;display:flex;flex-direction:column;align-items:flex-start;gap:8px}.book-modal-title{font-size:1.35rem;font-weight:800;color:var(--text-primary);margin:0 0 2px;line-height:1.22;font-family:Rubik,sans-serif}.book-modal-author{font-size:1rem;color:var(--apple-blue);font-weight:500;margin-bottom:2px;font-family:Rubik,sans-serif;opacity:.85}.book-modal-description{color:var(--text-secondary);font-size:.98rem;line-height:1.32;margin:0 0 8px;font-family:Rubik,sans-serif}.book-modal-actions{display:flex;gap:14px;margin-top:8px;width:100%}.book-modal-read-btn{width:100%;background:linear-gradient(90deg,var(--apple-blue),var(--apple-purple));color:#fff;border:none;border-radius:12px;padding:14px 0;font-size:1.1rem;font-weight:700;cursor:pointer;box-shadow:0 2px 8px #0000001a;transition:background .38s cubic-bezier(.22,1,.36,1),filter .38s cubic-bezier(.22,1,.36,1),box-shadow .38s cubic-bezier(.22,1,.36,1);margin:0;position:relative;overflow:hidden;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none;min-height:44px}.book-modal-read-btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#00000021;opacity:0;transition:opacity .38s cubic-bezier(.22,1,.36,1);border-radius:12px;pointer-events:none;mix-blend-mode:multiply;z-index:1}.book-modal-read-btn:hover:after{opacity:1}.book-modal-read-btn:hover{box-shadow:0 0 0 2px var(--apple-blue),0 4px 24px #007aff2e;filter:none}.book-modal-read-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.book-modal-read-btn:disabled:hover{box-shadow:0 4px 12px #007aff4d;transform:none}.book-modal-read-btn span{position:relative;z-index:2;color:#fff;transition:color .38s cubic-bezier(.22,1,.36,1)}.book-modal-chapters-btn{background:linear-gradient(90deg,var(--apple-blue),var(--apple-purple));color:#fff;border:none;border-radius:8px;padding:10px 22px;font-size:1rem;font-weight:700;cursor:pointer;box-shadow:0 2px 8px #0000001a;transition:background .18s,transform .18s;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none;min-height:44px;min-width:44px}.book-modal-chapters-btn:hover{background:linear-gradient(90deg,var(--apple-purple),var(--apple-blue));transform:translateY(-2px) scale(1.04)}.book-modal-chapters-list-blur{width:100%;padding:0;background:var(--bg-secondary);border-radius:0 0 24px 24px;margin-top:10px;box-shadow:0 2px 12px #0000001a;max-height:220px;overflow-y:auto;display:flex;flex-direction:column}[data-theme=light] .book-modal-chapters-list-blur{background:var(--bg-secondary)}[data-theme=light] .book-modal-chapter-item{border:1px solid rgba(0,0,0,.1);background:#fffc}[data-theme=light] .book-modal-chapter-item:hover{background:linear-gradient(135deg,#ffffffe6,#007aff0d);border-color:var(--apple-blue);transform:translateY(-1px);box-shadow:0 4px 12px #007aff33}[data-theme=light] .book-modal-chapter-item:hover .book-modal-chapter-num{color:var(--apple-blue);transform:scale(1.1);transition:all .3s ease}[data-theme=light] .book-modal-chapter-item.selected{background:linear-gradient(135deg,var(--apple-blue),var(--apple-purple));border:1px solid var(--apple-blue);box-shadow:0 6px 20px #007aff66;transform:translateY(-2px)}[data-theme=light] .book-modal-chapter-item.selected .book-modal-chapter-num{color:#fff;font-weight:700;transform:scale(1.15);text-shadow:0 1px 2px rgba(0,0,0,.2);transition:all .3s ease}.book-modal-chapters-list{padding:16px 24px;display:flex;flex-direction:column;gap:10px}.book-modal-chapter-item{display:flex;align-items:center;gap:12px;font-size:1.05rem;color:var(--text-primary);font-family:Rubik,sans-serif;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;padding:10px 16px;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;position:relative;overflow:hidden;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none}[data-theme=dark] .book-modal-chapter-item{border:1px solid rgba(255,255,255,.15)}.book-modal-chapter-item:hover{background:linear-gradient(135deg,#ffffff1a,#007aff0d);border-color:var(--apple-blue);transform:translateY(-1px);box-shadow:0 4px 12px #007aff33}.book-modal-chapter-item:hover .book-modal-chapter-num{color:var(--apple-blue);transform:scale(1.1);transition:all .3s ease}.book-modal-chapter-num{font-weight:700;font-size:1.1rem;color:var(--apple-blue);min-width:28px;text-align:right;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.book-modal-chapter-title{font-weight:500;font-size:1.05rem;color:inherit}.book-modal-chapter-item.selected{background:linear-gradient(135deg,var(--apple-blue),var(--apple-purple));color:#fff;border:1px solid var(--apple-blue);box-shadow:0 6px 20px #007aff66;transform:translateY(-2px);transition:all .3s cubic-bezier(.4,0,.2,1)}.book-modal-chapter-item.selected .book-modal-chapter-num{color:#fff;font-weight:700;transform:scale(1.15);text-shadow:0 1px 2px rgba(0,0,0,.2);transition:all .3s ease}.book-selector-grid.blurred{filter:blur(4px) grayscale(.2) brightness(.8);pointer-events:none;transition:filter .25s cubic-bezier(.4,0,.2,1);will-change:filter}.book-modal-overlay.closing~.book-selector-grid.blurred{filter:blur(0px) grayscale(0) brightness(1)!important;transition:filter .4s cubic-bezier(.4,0,.2,1)}.book-card.opened{z-index:1001;box-shadow:0 8px 48px #0000002e;transform:scale(1.08) translateY(-12px);transition:transform .35s cubic-bezier(.22,1,.36,1),box-shadow .25s}@media (max-width: 600px){.book-modal-overlay{padding:16px}.book-modal-chapter-item{min-height:48px;padding:12px 16px}.book-modal-read-btn{min-height:48px;padding:16px 0}.book-modal-chapters-btn{min-height:48px;min-width:48px;padding:12px 20px}.book-modal-close{min-width:36px;min-height:36px;width:36px;height:36px}.book-modal-card{max-width:100%;width:100%;border-radius:24px;padding:0;max-height:85vh}.book-modal-close{top:12px;right:12px;width:32px;height:32px;font-size:1.2rem}.book-modal-cover-block{aspect-ratio:1/.8}.book-modal-chapters-chip{top:12px;left:12px;padding:4px 10px;font-size:.8rem;border-radius:10px}.book-modal-info{padding:16px 16px 8px;gap:6px}.book-modal-title{font-size:1.2rem;line-height:1.3}.book-modal-author{font-size:.9rem}.book-modal-description{font-size:.85rem;line-height:1.4}.book-modal-actions{gap:10px;margin-top:6px}.book-modal-read-btn{padding:12px 0;font-size:1rem;border-radius:6px}.book-modal-chapters-btn{padding:8px 16px;font-size:.9rem;border-radius:6px}.book-modal-chapters-list-blur{max-height:220px;border-radius:0 0 24px 24px}.book-modal-chapters-list{padding:12px 16px;gap:8px}.book-modal-chapter-item{font-size:.95rem;padding:8px 12px;gap:10px;border-radius:10px}.book-modal-chapter-num{font-size:1rem;min-width:24px}.book-modal-chapter-title{font-size:.95rem}}@media (max-width: 480px){.book-modal-overlay{padding:12px}.book-modal-chapter-item{min-height:52px;padding:14px 18px}.book-modal-read-btn{min-height:52px;padding:18px 0}.book-modal-chapters-btn{min-height:52px;min-width:52px;padding:14px 22px}.book-modal-close{min-width:40px;min-height:40px;width:40px;height:40px}.book-modal-card{max-width:100%;width:100%;border-radius:20px;max-height:90vh}.book-modal-close{top:8px;right:8px;width:28px;height:28px;font-size:1rem}.book-modal-cover-block{aspect-ratio:1/.8}.book-modal-chapters-chip{top:8px;left:8px;padding:3px 8px;font-size:.75rem;border-radius:8px}.book-modal-info{padding:12px 12px 6px;gap:4px}.book-modal-title{font-size:1.1rem;line-height:1.25}.book-modal-author{font-size:.85rem}.book-modal-description{font-size:.8rem;line-height:1.35}.book-modal-actions{gap:8px;margin-top:4px}.book-modal-read-btn{padding:10px 0;font-size:.95rem;border-radius:6px}.book-modal-chapters-btn{padding:6px 12px;font-size:.85rem;border-radius:6px}.book-modal-chapters-list-blur{max-height:200px;border-radius:0 0 20px 20px}.book-modal-chapters-list{padding:8px 12px;gap:6px}.book-modal-chapter-item{font-size:.9rem;padding:6px 10px;gap:8px;border-radius:8px}.book-modal-chapter-num{font-size:.95rem;min-width:20px}.book-modal-chapter-title{font-size:.9rem}}.book-modal-chapter-item:active,.book-modal-read-btn:active{transform:scale(.98);transition:transform .1s ease}.book-modal-chapters-btn:active{transform:scale(.95);transition:transform .1s ease}.book-modal-close:active{transform:scale(.9);transition:transform .1s ease}.book-card.modern:active{transform:scale(.98);transition:transform .1s ease}@media (hover: none) and (pointer: coarse){.book-card.modern:hover{transform:none;box-shadow:0 12px 40px #00000040,0 6px 20px #00000026,0 2px 8px #0000001a}.book-card.modern:hover .book-card-cover{transform:none;filter:brightness(.95) contrast(1.05)}.book-card.modern:hover .book-card-more-icon{transform:none;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}[data-theme=light] .book-card.modern:hover{transform:none;box-shadow:0 12px 40px #00000026,0 6px 20px #0000001a,0 2px 8px #0000000d}[data-theme=dark] .book-card.modern:hover{transform:none;box-shadow:0 12px 40px #0006,0 6px 20px #0000004d,0 2px 8px #0003}}
