html{scroll-behavior:smooth}.book-page{min-height:100vh;padding-bottom:env(safe-area-inset-bottom)}.book-page .top-nav{position:static}.book-page__toast{position:fixed;top:1rem;left:1rem;right:1rem;background-color:var(--primary);color:var(--black);padding:.5rem 1rem;border-radius:.5rem;box-shadow:0 10px 15px -3px rgba(0,0,0,.1);z-index:50;animation:slideInFromRight .3s ease-out;text-align:center}@media (min-width:640px){.book-page__toast{left:auto;right:1rem;text-align:left}}@keyframes slideInFromRight{0%{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}.book-page__book-header{display:flex;align-items:flex-start;padding:1.5rem 0 0;margin-bottom:1rem}@media (min-width:640px){.book-page__book-header{padding:2rem 0 0;margin-bottom:1.5rem}}.btn-view-prompt{text-decoration:underline;display:flex;gap:4px;cursor:pointer;transition:color .3s;svg{margin-top:2px}&:hover{color:var(--primary)}}.book-page__title{font-size:2rem;font-weight:700;color:var(--black);margin-bottom:.5rem;word-wrap:break-word}@media (min-width:640px){.book-page__title{font-size:2.5rem}}.book-page__meta{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;font-size:.75rem;color:var(--gray-500)}@media (min-width:640px){.book-page__meta{font-size:.875rem}}.book-page__meta-separator{display:none}@media (min-width:640px){.book-page__meta-separator{display:inline}}.book-page__content{max-width:56rem;margin:0 auto;padding:2rem 1rem 1rem;font-family:var(--font-serif)}@media (min-width:640px){.book-page__content{padding:3rem 1rem 2rem}}.book-page__outline{padding:1rem;margin-bottom:1.5rem;background-color:#FEF3C7;border:1px solid #fcd34d;border-radius:8px;cursor:pointer;transition:background-color .2s}.book-page__outline:hover{background-color:#FDE68A}@media (min-width:640px){.book-page__outline{padding:1.5rem;margin-bottom:2rem}}.book-page__outline-toggle{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem;font-size:.875rem;font-weight:600;color:#92400E;transition:color .2s}.book-page__outline:hover .book-page__outline-toggle{color:#78350F}.book-page__outline-toggle-icon{font-size:.75rem;transition:transform .2s}.book-page__outline-toggle-text{flex:1;text-align:left}.book-page__outline-content{margin-top:1rem;padding-top:2rem;border-top:1px solid #fcd34d;color:#92400E;cursor:default}.book-page__outline-line{margin-bottom:.75rem;line-height:1.6;white-space:pre-wrap}.book-page__outline-line strong{font-weight:700;color:#78350F}.book-page__toc{margin-bottom:1.5rem}@media (min-width:640px){.book-page__toc{margin-bottom:2rem}}.book-page__toc-title{font-size:1.125rem;font-weight:600;color:var(--black);margin-bottom:.75rem}@media (min-width:640px){.book-page__toc-title{font-size:1.25rem;margin-bottom:1rem}}.book-page__toc-list{display:flex;flex-direction:column;gap:.5rem}.book-page__toc-item{display:inline-block;text-align:left;margin-left:2rem;margin-bottom:.5rem;width:fit-content;transition:color .3s}.book-page__toc-item:after{content:"";display:block;height:1px;background:linear-gradient(to right,transparent 0,var(--primary) 10%,var(--primary) 90%,transparent 100%);transition:opacity .3s;opacity:0}.book-page__toc-item:hover{color:var(--primary)}.book-page__toc-item:hover:after{content:"";display:block;height:1px;opacity:1}.book-page__book-content{padding:1rem 0}@media (min-width:640px){.book-page__book-content{padding:1.5rem 0}}@media (min-width:1024px){.book-page__book-content{padding:2rem 0}}.book-page__chapter{margin-bottom:3rem}@media (min-width:640px){.book-page__chapter{margin-bottom:4rem}}.book-page__chapter:last-child{margin-bottom:0}.book-page__chapter-title{font-size:1.125rem;font-weight:700;color:var(--black);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--gray-500)}@media (min-width:640px){.book-page__chapter-title{font-size:1.25rem;margin-bottom:1.5rem}}@media (min-width:1024px){.book-page__chapter-title{font-size:1.5rem}}.book-page__chapter-content{color:var(--black);line-height:1.625}.book-page__scene{margin-bottom:1.5rem}.book-page__scene:not(:first-child):before{content:"";display:block;height:1px;background:linear-gradient(to right,transparent 25%,var(--primary) 50%,transparent 75%);margin:1.5rem 0}.book-page__paragraph{margin-bottom:.75rem;text-align:justify}@media (min-width:640px){.book-page__paragraph{margin-bottom:1rem;text-align:left}}.book-page__footer{margin-top:2rem}@media (min-width:640px){.book-page__footer{margin-top:3rem}}.book-page__footer-inner{max-width:56rem;margin:0 auto;padding:1rem}@media (min-width:640px){.book-page__footer-inner{padding:1.5rem 1rem}}.book-page__footer-content{display:flex;flex-direction:column;gap:1rem}@media (min-width:640px){.book-page__footer-content{flex-direction:row;align-items:center;justify-content:space-between;gap:0}}.book-page__back-btn{color:var(--gray-500);transition:color .2s;display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.875rem;background:none;border:none;cursor:pointer;padding:0}@media (min-width:640px){.book-page__back-btn{font-size:1rem;justify-content:flex-start}}.book-page__back-btn:hover{color:var(--black)}.book-page__back-icon{width:1rem;height:1rem}@media (min-width:640px){.book-page__back-icon{width:1.25rem;height:1.25rem}}.book-page__actions{display:flex;flex-direction:column;align-items:center;gap:.75rem}@media (min-width:640px){.book-page__actions{flex-direction:row;gap:.75rem}}.book-page__action-btn{padding:.5rem .75rem;font-size:.875rem;display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%}@media (min-width:640px){.book-page__action-btn{padding:.5rem 1rem;width:auto}}.book-page__action-btn:disabled{opacity:.5;cursor:not-allowed}.book-page__action-icon,.book-page__spinner{width:1rem;height:1rem}.book-page__spinner{border:2px solid transparent;border-bottom:2px solid var(--black);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.book-page__loading{min-height:100vh;background-color:var(--white);display:flex;align-items:center;justify-content:center;padding:1rem}.book-page__loading-content{text-align:center}.book-page__loading-spinner{width:2.5rem;height:2.5rem;border:2px solid transparent;border-bottom:2px solid var(--primary);border-radius:50%;margin:0 auto .75rem;animation:spin 1s linear infinite}@media (min-width:640px){.book-page__loading-spinner{width:3rem;height:3rem;margin-bottom:1rem}}.book-page__loading-text{font-size:.875rem;color:var(--gray-500)}@media (min-width:640px){.book-page__loading-text{font-size:1rem}}.book-page__error{min-height:100vh;background-color:var(--white);display:flex;align-items:center;justify-content:center;padding:1rem}.book-page__error-content{text-align:center;max-width:20rem;margin:0 auto}.book-page__error-icon{color:#ef4444;font-size:2.25rem;margin-bottom:.75rem}@media (min-width:640px){.book-page__error-icon{font-size:3.75rem;margin-bottom:1rem}}.book-page__error-title{font-size:1rem;font-weight:500;color:var(--black);margin-bottom:.5rem}@media (min-width:640px){.book-page__error-title{font-size:1.125rem}}.book-page__error-message{font-size:.875rem;color:var(--gray-500);margin-bottom:1rem}@media (min-width:640px){.book-page__error-message{font-size:1rem}}.book-page__error-btn{padding:.5rem .75rem;font-size:.875rem;font-weight:500;width:100%;justify-content:center}@media (min-width:640px){.book-page__error-btn{padding:.5rem 1rem;width:auto}}.book-page__cover-container{margin-bottom:2rem}.book-page__cover-wrapper{position:relative;width:400px;max-width:100%}.book-page__cover-image{width:100%;height:auto;border-radius:8px;box-shadow:0 4px 6px rgba(0,0,0,.1)}.book-page__cover-status{margin-bottom:2rem}.book-page__cover-generating{margin-bottom:2rem;padding:1rem;background-color:#FEF3C7;border:1px solid #f59e0b;border-radius:6px}.book-page__cover-generating-header{display:flex;align-items:center;gap:.5rem}.book-page__cover-generating-icon{width:20px;height:20px;color:#D97706}.book-page__cover-generating-text{color:#92400E;font-weight:500}.book-page__cover-generating-message{color:#92400E;font-size:.875rem;margin-top:.5rem;margin-left:1.75rem}.book-page__cover-failed{padding:1rem;background-color:#FEE2E2;border:1px solid #ef4444;border-radius:6px;margin-bottom:1rem}.book-page__cover-failed-title{color:#991B1B;font-weight:500}.book-page__cover-failed-message{color:#991B1B;font-size:.875rem;margin-top:.25rem}.book-page__cover-controls,.book-page__generate-btn{display:flex;align-items:center;gap:.5rem}.book-page__generate-btn{color:white;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:background-color .2s}.book-page__generate-btn--primary{padding:.75rem 1.5rem;background-color:#4F46E5;font-size:1rem}.book-page__generate-btn--secondary{padding:.5rem 1rem;background-color:#6B7280;font-size:.875rem;width:fit-content}.book-page__generate-btn:disabled{background-color:#9CA3AF;cursor:not-allowed}.book-page__generate-icon{width:20px;height:20px}.book-page__generate-icon--small{width:16px;height:16px}.book-page__quality-select{padding:.75rem;background-color:white;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;color:#374151}.book-page__quality-select--small{padding:.5rem;font-size:.875rem}.book-page__quality-select:disabled{cursor:not-allowed}.book-page__cover-error{color:#DC2626;margin-top:.5rem;font-size:.875rem}.book-page__prompt-section{font-size:.875rem;color:#6B7280;margin-top:1rem}.book-page__prompt-edit-btn{padding:.5rem 1rem;font-size:.875rem;background-color:#4F46E5;color:white;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .2s}.book-page__prompt-edit-btn:hover{background-color:#4338CA}.book-page__prompt-label{font-weight:500;margin-bottom:.5rem}.book-page__prompt-textarea{width:100%;min-height:150px;padding:.75rem;background-color:#F3F4F6;border:1px solid #d1d5db;border-radius:4px;font-family:inherit;font-size:.875rem;resize:vertical}.book-page__prompt-help{font-size:.75rem;color:#6B7280;margin-top:.5rem;font-style:italic}.book-page__prompt-actions{display:flex;gap:.5rem;margin-top:.5rem}.book-page__prompt-cancel-btn{padding:.5rem 1rem;font-size:.875rem;background-color:white;color:#374151;border:1px solid #d1d5db;border-radius:4px;cursor:pointer;font-weight:500;transition:background-color .2s}.book-page__prompt-cancel-btn:hover{background-color:#F9FAFB}.book-page__privacy-section{margin-bottom:2rem}.book-page__privacy-label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.book-page__privacy-select{padding:.5rem;background-color:white;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;font-weight:500;color:#374151;max-width:400px;width:100%}.book-page__privacy-select:disabled{cursor:not-allowed}.book-page__header-main{flex:1}.book-page__settings-btn{display:flex;align-items:center;justify-content:center;padding:.5rem;background-color:transparent;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;transition:all .2s;color:#6B7280;margin-left:1rem;margin-top:.9rem}.book-page__settings-btn:hover{background-color:#F3F4F6;color:#374151;border-color:#9CA3AF}.book-page__settings-icon{width:20px;height:20px}.book-page__modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.book-page__modal{background-color:white;border-radius:12px;box-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 10px 10px -5px rgba(0,0,0,.04);max-width:600px;width:100%;max-height:90vh;overflow-y:auto}.book-page__modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid #e5e7eb}.book-page__modal-title{font-size:1.5rem;font-weight:600;color:#111827;margin:0}.book-page__modal-close{display:flex;align-items:center;justify-content:center;padding:.5rem;background-color:transparent;border:none;border-radius:6px;cursor:pointer;color:#6B7280;transition:all .2s}.book-page__modal-close:hover{background-color:#F3F4F6;color:#374151}.book-page__modal-close-icon{width:24px;height:24px}.book-page__modal-content{padding:1.5rem}.book-page__modal-section{margin-bottom:2rem}.book-page__modal-section:last-child{margin-bottom:0}.book-page__modal-section-title{font-size:1.125rem;font-weight:600;color:#111827;margin:0 0 1rem}