Replace the SSR + injected vanilla-JS navigation script with a proper
client-side React app. BookIndex now uses useState/useEffect/useCallback
for all navigation state, scroll tracking, keyboard shortcuts, and history
management. webpack.config.js switches from renderToStaticMarkup to
embedding page data as window.__BOOK_DATA__ JSON; book.js becomes a
createRoot entry point. Also adds babel-loader for JSX bundling, fixes
#root display:contents so the flex height chain is preserved, and
restores missing CSS for header, .logo, .toolbar, and .tab buttons.
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
- Add html/index.html: book viewer with auto-discovering sidebar,
prev/next navigation, keyboard shortcuts, and URL hash persistence
- Add html/book-page.css: shared stylesheet for all book pages derived
from fabula-ultima-sheet.css (dark theme, CSS variables, Cinzel/
Crimson Text fonts, common class styles)
- Add book.js entry point so webpack injects the shared CSS into the
book viewer; update webpack.config.js for two entry points, split
CSS chunk, CopyWebpackPlugin for book pages, and /book dev server
rewrite rule
- Add scripts/strip_watermark.py: removes "Guest Customer (Order
#52072168)" watermark artifacts from all 210 book pages
- Add scripts/restyle_book.py: strips per-page <style> blocks and
injects <link rel="stylesheet" href="book-page.css"> into all pages
- Update Justfile deploy to scp -r dist/* for the new /book subtree
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>