*{box-sizing:border-box}#root,body,html{zoom:1;height:100%;margin:0;padding:0;transform-origin:0 0}#root.image-viewer-active,body.image-viewer-active,html.image-viewer-active{overflow:hidden}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--mobile-max:767px;--tablet-min:768px;--tablet-max:1023px;--desktop-min:1024px;--primary-color:#1976d2;--primary-dark:#1565c0;--secondary-color:#ffc107;--background-color:#f5f5f5;--surface-color:#fff;--text-primary:#212121;--text-secondary:#757575;--error-color:#d32f2f;--shadow-1:0 1px 3px #0000001f,0 1px 2px #0000003d;--shadow-2:0 3px 6px #00000029,0 3px 6px #0000003b;--shadow-3:0 10px 20px #00000030,0 6px 6px #0000003b;--z-image-viewer:1;--z-search-button:100;--z-search-modal:200;--z-loading:999}.container{margin:0 auto;max-width:1200px;padding:0 16px}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}[tabindex]:focus-visible,button:focus-visible,input:focus-visible{outline:2px solid #1976d2;outline:2px solid var(--primary-color);outline-offset:2px}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:16px;font-weight:500;justify-content:center;min-height:44px;padding:12px 24px;text-decoration:none;transition:all .2s ease}.btn-primary{background-color:#1976d2;background-color:var(--primary-color);color:#fff}.btn-primary:hover{background-color:#1565c0;background-color:var(--primary-dark)}.btn-secondary{background-color:initial;border:2px solid #1976d2;border:2px solid var(--primary-color);color:#1976d2;color:var(--primary-color)}.btn-secondary:hover{background-color:#1976d2;background-color:var(--primary-color);color:#fff}@media (max-width:767px){.hide-mobile{display:none!important}.container{padding:0 12px}}@media (min-width:768px){.hide-tablet-up{display:none!important}}@media (min-width:1024px){.hide-desktop{display:none!important}}.fade-in{animation:fadeIn .3s ease}.slide-up{animation:slideUp .3s ease}.search-modal{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:var(--z-search-modal)}.search-modal__content{animation:slideUp .3s ease;background:#fff;border-radius:16px;box-shadow:var(--shadow-3);display:flex;flex-direction:column;max-height:90vh;max-width:500px;width:100%}.search-modal__header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:0;padding:24px 24px 16px}.search-modal__title{color:var(--text-primary);font-size:1.5rem;font-weight:600;margin:0}.search-modal__close{align-items:center;background:#0000;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .2s ease;width:40px}.search-modal__close:hover{background:#f5f5f5;color:var(--text-primary)}.search-modal__close svg{height:20px;width:20px}.search-modal__search{border-bottom:1px solid #e0e0e0;padding:24px}.search-modal__type-group{display:flex;gap:8px;margin-bottom:12px}.search-modal__type-btn{background:#fff;border:2px solid #e0e0e0;border-radius:8px;color:var(--text-primary);cursor:pointer;flex:1 1;font-size:.9rem;padding:8px 12px;transition:all .2s ease}.search-modal__type-btn.active,.search-modal__type-btn:hover{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.search-modal__input-wrapper{align-items:center;display:flex;position:relative}.search-modal__search-icon{color:var(--text-secondary);height:20px;left:16px;pointer-events:none;position:absolute;width:20px;z-index:1}.search-modal__input{background:#fff;border:2px solid #e0e0e0;border-radius:12px;font-size:1rem;padding:16px 16px 16px 48px;transition:border-color .2s ease;width:100%}.search-modal__input:focus{border-color:var(--primary-color);outline:none}.search-modal__clear,.search-modal__input::placeholder{color:var(--text-secondary)}.search-modal__clear{align-items:center;background:#0000;border:none;border-radius:4px;cursor:pointer;display:flex;height:24px;justify-content:center;position:absolute;right:12px;transition:all .2s ease;width:24px}.search-modal__clear:hover{background:#f5f5f5;color:var(--text-primary)}.search-modal__clear svg{height:16px;width:16px}.search-modal__body{flex:1 1;min-height:200px;overflow-y:auto;padding:24px}.search-modal__error,.search-modal__loading,.search-modal__no-results,.search-modal__placeholder{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;justify-content:center;padding:40px 20px;text-align:center}.search-modal__spinner{animation:spin 1s linear infinite;border:3px solid #e0e0e0;border-radius:50%;border-top:3px solid var(--primary-color);height:32px;margin-bottom:16px;width:32px}.search-modal__error{color:var(--error-color)}.search-modal__placeholder-icon{color:var(--text-secondary);height:48px;margin-bottom:16px;width:48px}.search-modal__placeholder-icon svg{height:100%;width:100%}.search-modal__placeholder h3{color:var(--text-primary);font-size:1.2rem;margin:0 0 8px}.search-modal__placeholder p{line-height:1.5;margin:0}.search-modal__hint{font-size:.9rem;font-style:italic;margin-top:8px!important}.search-modal__results-count{color:var(--text-secondary);font-size:.9rem;margin:0 0 16px}.search-modal__results-list{list-style:none;margin:0;padding:0}.search-modal__result-item{margin-bottom:8px}.search-modal__result-button{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:12px;cursor:pointer;display:flex;justify-content:space-between;padding:16px;text-align:left;transition:all .2s ease;width:100%}.search-modal__result-button:hover{background:#f8fafe;border-color:var(--primary-color);box-shadow:var(--shadow-1);transform:translateY(-1px)}.search-modal__result-button:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.search-modal__result-info{display:flex;flex-direction:column;gap:4px}.search-modal__result-title{display:block;font-weight:600;margin-bottom:2px}.search-modal__result-artist{color:var(--text-secondary);display:block;font-size:.9rem;margin-bottom:2px}.search-modal__result-id{color:var(--text-primary);font-size:1rem;font-weight:600}.search-modal__result-page{color:var(--text-secondary);font-size:.9rem}.search-modal__result-arrow{color:var(--primary-color);font-size:1.2rem;transition:transform .2s ease}.search-modal__result-button:hover .search-modal__result-arrow{transform:translateX(4px)}@media (max-width:767px){.search-modal{align-items:flex-start;padding:0}.search-modal__content{animation:slideDown .3s ease;border-radius:0 0 16px 16px;margin-top:0;max-height:90vh;max-height:90dvh}.search-modal__body,.search-modal__header,.search-modal__search{padding-left:20px;padding-right:20px}.search-modal__title{font-size:1.3rem}.search-modal__body{max-height:calc(90vh - 200px);max-height:calc(90dvh - 200px);overflow-y:auto}.search-modal__input{appearance:none;font-size:16px}.search-modal__type-btn{min-height:44px;padding:12px 16px}.search-modal__result-button{min-height:48px;padding:20px 16px}.search-modal__close{min-height:44px;min-width:44px}}@media (min-width:768px) and (max-width:1023px){.search-modal__content{max-width:600px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){.search-modal,.search-modal__content{animation:none}.search-modal__spinner{animation:none;border:3px solid var(--primary-color)}}.book-selector{align-items:center;background:linear-gradient(135deg,#1976d2,#1565c0);color:#fff;display:flex;justify-content:center;min-height:100vh;overflow-y:auto;padding:20px}.book-selector__container{max-width:800px;text-align:center;width:100%}.book-selector__header{margin-bottom:48px}.book-selector__title{font-size:3rem;font-weight:700;margin:0 0 16px;text-shadow:0 2px 4px #0000004d}.book-selector__subtitle{font-size:1.2rem;font-weight:300;margin:0;opacity:.9}.book-selector__books{grid-gap:24px;display:grid;gap:24px;margin-bottom:48px}.book-selector__search{margin:0 auto 24px;width:100%}.book-selector__search-btn{background:#fff;border:1px solid #e0e0e0;border-radius:14px;box-shadow:var(--shadow-1);color:var(--text-primary);cursor:pointer;font-size:1.05rem;font-weight:700;padding:14px 20px;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;width:100%}.book-selector__search-btn:hover{border-color:var(--primary-color);box-shadow:var(--shadow-2);transform:translateY(-1px)}.book-card{align-items:center;background:#fff;border:none;border-radius:14px;box-shadow:var(--shadow-2);color:var(--text-primary);cursor:pointer;display:flex;overflow:hidden;padding:18px;position:relative;text-align:left;transition:all .3s ease}.book-card:hover{box-shadow:var(--shadow-3);transform:translateY(-4px)}.book-card:focus-visible{outline:3px solid var(--secondary-color);outline-offset:2px}.book-card:before{background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));content:"";height:4px;left:0;position:absolute;right:0;top:0}.book-card__icon{align-items:center;background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));border-radius:10px;display:flex;flex-shrink:0;height:64px;justify-content:center;margin-right:18px;width:64px}.book-card__number{color:#fff;font-size:1.75rem;font-weight:700}.book-card__content{flex:1 1;min-width:0}.book-card__title{color:var(--text-primary);font-size:1.3rem;font-weight:600;margin:0 0 6px}.book-card__description{color:var(--text-secondary);font-size:.95rem;margin:0 0 12px}.book-card__stats{display:flex;flex-wrap:wrap;gap:16px}.book-card__stat{color:var(--text-secondary);font-size:.9rem}.book-card__arrow,.book-card__stat strong{color:var(--primary-color)}.book-card__arrow{flex-shrink:0;font-size:1.25rem;margin-left:12px;transition:transform .3s ease}.book-card:hover .book-card__arrow{transform:translateX(4px)}.book-selector__footer{margin-top:32px}.book-selector__note{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:8px;font-size:1rem;margin:0;opacity:.8;padding:16px}@media (max-width:767px){.book-selector{align-items:flex-start;padding:40px 16px}.book-selector__title{font-size:2.5rem}.book-selector__subtitle{font-size:1.1rem}.book-card{flex-direction:column;padding:18px;text-align:center}.book-card__icon{margin-bottom:16px;margin-right:0}.book-card__stats{justify-content:center}.book-card__arrow{margin-left:0;margin-top:12px}}@media (min-width:768px){.book-selector__books{gap:20px;grid-template-columns:1fr 1fr;margin:0 auto 40px;max-width:900px}}@media (min-width:1024px){.book-selector__books{grid-template-columns:1fr 1fr;max-width:1000px}}@media (orientation:landscape) and (max-height:480px){.book-selector{padding-top:16px}.book-selector__header{margin-bottom:24px}.book-selector__title{font-size:2.2rem}.book-selector__subtitle{font-size:1rem}.book-selector__search{margin-bottom:20px;max-width:720px}.book-selector__search-btn{font-size:1.2rem;padding:18px 28px}.book-selector__books{gap:16px;grid-template-columns:1fr 1fr;margin-bottom:24px;max-width:none}.book-card{box-shadow:var(--shadow-1);padding:14px 16px}.book-card__icon{height:64px;margin-right:16px;width:64px}.book-card__number{font-size:1.6rem}.book-card__title{font-size:1.25rem}.book-card__description{font-size:.95rem;margin-bottom:10px}.book-card__arrow{font-size:1.2rem}}.offline-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:16px;margin:32px 0 24px;padding:24px}.offline-section__complete,.offline-section__download{align-items:flex-start;display:flex;gap:20px}.offline-section__icon{align-items:center;background:#fff3;border-radius:50%;display:flex;flex-shrink:0;font-size:1.5rem;height:60px;justify-content:center;width:60px}.offline-section__icon--complete{background:#4caf50;color:#fff;font-weight:700}.offline-section__content{flex:1 1;text-align:left}.offline-section__title{color:#fff;font-size:1.4rem;font-weight:600;margin:0 0 8px}.offline-section__description{font-size:1rem;line-height:1.5;margin:0 0 20px;opacity:.9}.offline-section__button{align-items:center;background:#4caf50;border:none;border-radius:12px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:8px;padding:14px 24px;transition:all .2s ease}.offline-section__button:hover:not(:disabled){background:#45a049;box-shadow:0 4px 12px #4caf504d;transform:translateY(-1px)}.offline-section__button:disabled{cursor:not-allowed;opacity:.6}.offline-section__progress{width:100%}.progress-container{display:flex;flex-direction:column;gap:20px}.progress-item{background:#ffffff1a;border-radius:12px;padding:16px}.progress-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.progress-title{color:#fff;font-weight:600}.progress-percentage{color:#fffc;font-size:.9rem;font-weight:500}.progress-bar{background:#fff3;border-radius:4px;height:8px;margin-bottom:8px;overflow:hidden;width:100%}.progress-bar__fill{background:linear-gradient(90deg,#4caf50,#81c784);border-radius:4px;height:100%;position:relative;transition:width .3s ease}.progress-bar__fill:after{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#ffffff4d,#0000);bottom:0;content:"";left:0;position:absolute;right:0;top:0}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.progress-status{align-items:center;color:#4caf50;display:flex;font-size:.9rem;font-weight:600;gap:4px}.offline-section__error{background:#f4433633;border:1px solid #f443364d;border-radius:8px;color:#ffcdd2;margin-top:16px;padding:12px}.offline-section__error p{font-size:.9rem;margin:0}@media (max-width:480px){.book-selector{padding:20px 12px}.book-selector__container{min-height:auto}.book-selector__books,.book-selector__header{margin-bottom:32px}}@media (max-width:768px){.offline-section{margin:24px 0 16px;padding:20px}.offline-section__complete,.offline-section__download{align-items:center;flex-direction:column;gap:16px;text-align:center}.offline-section__content{text-align:center}.offline-section__icon{font-size:1.3rem;height:50px;width:50px}.offline-section__title{font-size:1.2rem}.offline-section__button{justify-content:center;width:100%}.progress-container{gap:16px}.progress-item{padding:14px}}.image-viewer{background:#f5f5f5;height:100vh;overflow:hidden;position:relative;width:100%}.image-viewer__home-btn{align-items:center;background:#000c;border:none;border-radius:50%;box-shadow:0 2px 8px #0000004d;color:#fff;cursor:pointer;display:flex;font-size:18px;height:48px;justify-content:center;left:16px;position:fixed;top:16px;transition:background-color .2s ease;width:48px;z-index:1001}.image-viewer__home-btn:hover{background:#000000e6}.image-viewer__home-btn:active{transform:scale(.95)}.image-viewer__controls{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffff2;border-radius:8px;box-shadow:0 2px 8px #0003;display:flex;gap:8px;padding:8px;position:fixed;right:16px;top:16px;z-index:1000}.image-viewer__controls button{background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px;min-width:32px;padding:8px 12px;transition:all .2s ease}.image-viewer__controls button:hover{background:#f0f0f0;border-color:#999}.image-viewer__controls button:active{transform:scale(.95)}.image-viewer__controls button:disabled{cursor:not-allowed;opacity:.5}.image-viewer__content{background:#f5f5f5;height:100svh;overflow:auto;width:100%}.image-viewer__content--fullscreen{background:linear-gradient(135deg,#f5f5f5,#e8e8e8)}.image-viewer__loading{color:#666;left:50%;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%);z-index:100}.image-viewer__spinner{animation:spin 1s linear infinite;border:4px solid #f0f0f0;border-radius:50%;border-top-color:#333;height:40px;margin:0 auto 16px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.image-viewer__error{background:#fff;border-radius:8px;box-shadow:0 4px 16px #0003;left:50%;max-width:400px;padding:24px;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%);z-index:100}.image-viewer__error-content h3{color:#d32f2f;font-size:18px;margin:0 0 16px}.image-viewer__error-content p{color:#666;line-height:1.5;margin:0 0 24px}.image-viewer__error-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.image-viewer__error-button{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s ease}.image-viewer__error-button:not(.image-viewer__error-button--secondary){background:#1976d2;color:#fff}.image-viewer__error-button:not(.image-viewer__error-button--secondary):hover{background:#1565c0}.image-viewer__error-button--secondary{background:#f5f5f5;border:1px solid #ddd;color:#666}.image-viewer__error-button--secondary:hover{background:#eee}.image-page__loading{background:#fafafa;color:#666}.image-page__error,.image-page__loading{align-items:center;display:flex;font-size:14px;justify-content:center}.image-page__error{background:#fff5f5;border-color:#f56565!important;color:#c53030}body.image-viewer-active{height:100%!important;margin:0!important;padding:0!important;position:fixed!important;width:100%!important}body.image-viewer-active,html.image-viewer-active{overflow:hidden!important}#root.image-viewer-active{height:100svh!important;overflow:hidden!important}@media (max-width:768px){.image-viewer__controls{gap:6px;padding:6px;right:8px;top:8px}.image-viewer__controls button{font-size:12px;min-width:28px;padding:6px 8px}.image-viewer__home-btn{font-size:16px;height:42px;left:8px;top:8px;width:42px}}@media (pointer:coarse){.image-viewer__controls button{min-height:44px;min-width:44px}.image-viewer__home-btn{min-height:48px;min-width:48px}}@media (-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.image-viewer__spinner{border-width:2px}}@media (prefers-color-scheme:dark){.image-viewer{background:#1a1a1a}.image-viewer__content--fullscreen{background:linear-gradient(135deg,#1a1a1a,#2a2a2a)}.image-viewer__loading{color:#ccc}.image-viewer__error{background:#2a2a2a;color:#ccc}}.floating-search-button{align-items:center;background:var(--primary-color);border:none;border-radius:50%;bottom:24px;box-shadow:var(--shadow-3);color:#fff;cursor:pointer;display:flex;height:56px;justify-content:center;position:fixed;right:24px;transition:all .3s ease;width:56px;z-index:var(--z-search-button)}.floating-search-button:hover{background:var(--primary-dark);box-shadow:0 8px 25px #1976d266;transform:scale(1.1)}.floating-search-button:active{transform:scale(.95)}.floating-search-button:focus-visible{outline:3px solid var(--secondary-color);outline-offset:2px}.floating-search-button__icon{height:24px;transition:transform .2s ease;width:24px}.floating-search-button:hover .floating-search-button__icon{transform:scale(1.1)}@media (max-width:767px){.floating-search-button{bottom:20px;height:48px;right:16px;width:48px}.floating-search-button__icon{height:20px;width:20px}}@media (prefers-contrast:high){.floating-search-button{border:2px solid #fff}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.floating-search-button{animation:fadeInUp .5s ease .5s both}.whatsnew-modal{align-items:flex-end;background:#00000080;display:flex;inset:0;justify-content:center;position:fixed;z-index:2000}.whatsnew-modal__content{background:#fff;border-top-left-radius:16px;border-top-right-radius:16px;box-shadow:0 -10px 30px #0003;max-width:560px;padding:16px;width:100%}@media (min-width:768px){.whatsnew-modal{align-items:center}.whatsnew-modal__content{border-radius:16px;padding:20px 20px 16px}}.whatsnew-modal__header{align-items:center;display:flex;justify-content:space-between}.whatsnew-modal__title{font-size:18px;margin:0}.whatsnew-modal__close{background:#0000;border:none;border-radius:8px;cursor:pointer;padding:8px}.whatsnew-modal__body{margin-top:8px}.whatsnew-list{margin:0;padding-left:20px}.whatsnew-list li{margin:8px 0}.whatsnew-modal__footer{display:flex;justify-content:flex-end;margin-top:12px}.whatsnew-modal__button{background:#1976d2;border:none;border-radius:10px;color:#fff;cursor:pointer;font-weight:600;padding:10px 14px}.whatsnew-modal__button:focus{outline:2px solid #90caf9;outline-offset:2px}.search-hint{align-items:center;background:#000000b3;display:flex;height:100%;justify-content:center;left:0;opacity:0;pointer-events:none;position:fixed;top:0;transition:opacity .3s ease;width:100%;z-index:calc(var(--z-search-modal) + 10)}.search-hint--visible{opacity:1;pointer-events:all}.search-hint__content{bottom:92px;position:fixed;right:24px}.search-hint__bubble{background:#fff;border-radius:16px;box-shadow:0 20px 40px #0000004d;max-width:280px;padding:24px;position:relative;text-align:center;transform:scale(.8) translateY(20px);transition:transform .3s ease}.search-hint--visible .search-hint__bubble{transform:scale(1) translateY(0)}.search-hint__title{color:var(--primary-color);font-size:24px;font-weight:700;margin:0 0 12px}.search-hint__description{color:var(--text-primary);font-size:16px;line-height:1.4;margin:0 0 20px}.search-hint__dismiss{background:var(--primary-color);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:background .2s ease}.search-hint__dismiss:hover{background:var(--primary-dark)}.search-hint__dismiss:focus-visible{outline:2px solid var(--secondary-color);outline-offset:2px}.search-hint__arrow{border-left:15px solid #0000;border-right:15px solid #0000;border-top:15px solid #fff;bottom:-15px;height:0;position:absolute;right:30px;width:0}.search-hint__arrow:after{border-left:18px solid #0000;border-right:18px solid #0000;border-top:18px solid #0000004d;content:"";height:0;left:-18px;position:absolute;top:-18px;width:0}.search-hint--visible:before{animation:pulse 2s infinite;border:3px solid var(--secondary-color);border-radius:50%;bottom:24px;content:"";height:80px;pointer-events:none;position:absolute;right:24px;width:80px}@keyframes pulse{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.5)}}@media (max-width:767px){.search-hint__content{bottom:84px;right:16px}.search-hint__bubble{margin:0 16px;max-width:260px;padding:20px}.search-hint__title{font-size:20px}.search-hint__description{font-size:14px}.search-hint__arrow{right:25px}.search-hint--visible:before{bottom:20px;height:68px;right:16px;width:68px}}@media (min-width:768px) and (max-width:1023px){.search-hint__content{bottom:88px;right:20px}}@media (prefers-contrast:high){.search-hint__bubble{border:2px solid var(--text-primary)}.search-hint__arrow{border-top-color:var(--text-primary)}}@media (prefers-reduced-motion:reduce){.search-hint,.search-hint__bubble{transition:none}.search-hint--visible:before{animation:none;opacity:.6}}.password-modal-overlay{align-items:center;animation:password-modal-fade-in .3s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#000c;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:99999}.password-modal{animation:password-modal-slide-up .3s ease-out;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;box-shadow:0 20px 40px #0000004d;color:#fff;max-width:400px;overflow:hidden;padding:2rem;position:relative;width:90%}.password-modal:before{background:linear-gradient(45deg,#ffffff1a,#0000 50%,#ffffff1a);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.password-modal__header{margin-bottom:2rem;text-align:center}.password-modal__title{color:#fff;font-size:1.5rem;font-weight:600;margin:0 0 .5rem}.password-modal__subtitle{font-size:.9rem;line-height:1.4;margin:0;opacity:.9}.password-modal__form{margin-bottom:1.5rem}.password-modal__input-group{margin-bottom:1rem}.password-modal__label{color:#ffffffe6;display:block;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.password-modal__input-wrapper{position:relative}.password-modal__input{background:#ffffff1a;border:2px solid #ffffff4d;border-radius:8px;box-sizing:border-box;color:#fff;font-size:1rem;padding:.75rem 3rem .75rem 1rem;transition:all .3s ease;width:100%}.password-modal__input::placeholder{color:#fff9}.password-modal__input:focus{background:#ffffff26;border-color:#fffc;box-shadow:0 0 0 3px #fff3;outline:none}.password-modal__input--error{background:#ff6b6b1a;border-color:#ff6b6b}.password-modal__input--error:focus{border-color:#ff6b6b;box-shadow:0 0 0 3px #ff6b6b4d}.password-modal__toggle-visibility{background:none;border:none;border-radius:4px;color:#ffffffb3;cursor:pointer;font-size:1.1rem;padding:.5rem;position:absolute;right:8px;top:50%;transform:translateY(-50%);transition:all .2s ease}.password-modal__toggle-visibility:hover{background:#ffffff1a;color:#fff}.password-modal__toggle-visibility:disabled{cursor:not-allowed;opacity:.5}.password-modal__error{align-items:center;animation:password-modal-shake .5s ease-in-out;background:#ff6b6b33;border:1px solid #ff6b6b66;border-radius:6px;display:flex;font-size:.9rem;gap:.5rem;margin-bottom:1rem;padding:.75rem}.password-modal__error-icon{font-size:1rem}.password-modal__submit{align-items:center;background:#fff3;border:2px solid #fff6;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;padding:.875rem 1.5rem;transition:all .3s ease;width:100%}.password-modal__submit:hover:not(:disabled){background:#ffffff4d;border-color:#fff9;box-shadow:0 4px 12px #0003;transform:translateY(-1px)}.password-modal__submit:active:not(:disabled){transform:translateY(0)}.password-modal__submit:disabled{cursor:not-allowed;opacity:.6;transform:none}.password-modal__spinner{animation:password-modal-spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:16px;width:16px}.password-modal__footer{border-top:1px solid #fff3;padding-top:1.5rem}.password-modal__info{align-items:flex-start;display:flex;font-size:.85rem;gap:.5rem;line-height:1.4;margin:0;opacity:.8}.password-modal__info-icon{font-size:1rem;margin-top:.1rem}@keyframes password-modal-fade-in{0%{opacity:0}to{opacity:1}}@keyframes password-modal-slide-up{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes password-modal-shake{0%,to{transform:translateX(0)}10%,30%,50%,70%,90%{transform:translateX(-4px)}20%,40%,60%,80%{transform:translateX(4px)}}@keyframes password-modal-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:480px){.password-modal{border-radius:12px;margin:1rem;padding:1.5rem}.password-modal__title{font-size:1.3rem}.password-modal__input{font-size:16px;padding:.625rem 2.5rem .625rem .875rem}.password-modal__submit{font-size:.95rem;padding:.75rem 1rem}}@media (prefers-contrast:high){.password-modal{background:#000;border:2px solid #fff}.password-modal__input,.password-modal__submit{background:#fff;border-color:#000;color:#000}}@media (prefers-reduced-motion:reduce){.password-modal,.password-modal-overlay,.password-modal__input,.password-modal__submit,.password-modal__toggle-visibility{animation:none;transition:none}.password-modal__submit:hover:not(:disabled){transform:none}}.auth-overlay{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.auth-message{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff1a;border-radius:12px;color:#fff;margin:1rem;max-width:400px;padding:2rem;text-align:center}.auth-message h2{font-size:1.5rem;margin:0 0 .5rem}.auth-message p{line-height:1.4;margin:0;opacity:.9}.app{background-color:var(--background-color);box-sizing:border-box;height:100vh;overflow:hidden;position:relative}.startup-gate{align-items:center;background:#0009;display:flex;inset:0;justify-content:center;position:fixed;z-index:10000}.startup-gate__modal{background:#fff;border-radius:12px;box-shadow:0 10px 30px #00000040;padding:24px;width:min(680px,92vw)}.startup-gate__brand{align-items:center;display:flex;gap:12px;margin-bottom:8px}.startup-gate__logo{border-radius:8px;height:40px;width:40px}.startup-gate__app-name{font-weight:700}.startup-gate__app-sub{color:#666;font-size:.9rem}.startup-gate__title{margin:0 0 8px}.startup-gate__text{margin:0 0 12px}.startup-gate__notice{color:#555;font-size:.9rem;margin-bottom:16px}.startup-gate__actions{display:flex;gap:12px;margin-top:12px}.startup-gate__button{appearance:none;background:#f7f7f7;border:1px solid #ccc;border-radius:8px;cursor:pointer;padding:10px 14px}.startup-gate__button--primary{background:#2563eb;border-color:#2563eb;color:#fff}.startup-gate__progress{margin-top:12px}.startup-gate__row{align-items:center;display:flex;font-weight:600;justify-content:space-between;margin-top:8px}.startup-gate__bar{background:#eee;border-radius:6px;height:10px;overflow:hidden}.startup-gate__fill{background:linear-gradient(90deg,#4ade80,#22c55e);height:100%}.startup-gate__overall{margin-top:8px;text-align:right}.app--book-selector{height:auto;min-height:100vh;overflow-y:auto}@media (max-width:767px){.app{padding:0}}@media (min-width:768px) and (max-width:1023px){.app{padding:0}}@media (min-width:1024px){.app{padding:0}}