:root{--bg: #faf9f7;--bg-secondary: #f3f1ee;--surface: #ffffff;--border: #ddd8d0;--text: #000000;--text-muted: #6b6560;--accent: #1a1a1a;--accent-hover: #333;--error: #c0392b;--success: #27ae60;--shadow: 0 1px 3px rgba(0,0,0,.08);--reading-size: 18pt;--reading-line-height: 1.5;--reading-width: 66ch;--font-serif: Georgia, "Times New Roman", serif;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif}[data-dark=true]{--bg: #1a1905;--bg-secondary: #222211;--surface: #2a2a18;--border: #3a3a28;--text: #e8e4d8;--text-muted: #8a8570;--accent: #e8e4d8;--accent-hover: #ffffff;--shadow: 0 1px 3px rgba(0,0,0,.4)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;overflow-wrap:break-word}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;overflow-x:hidden}h1{font-size:1.5rem;font-weight:700;line-height:1.25}h2{font-size:1.2rem;font-weight:600;line-height:1.3}h3{font-size:1rem;font-weight:600}a{color:var(--text);text-decoration:underline;text-underline-offset:3px}a:not(.btn):hover{color:var(--accent-hover)}.reading-text{font-family:var(--font-serif);font-size:var(--reading-size);line-height:var(--reading-line-height);color:var(--text);text-align:left;max-width:var(--reading-width)}.reading-text p+p{margin-top:1em}.chunk-page{flex:1;min-height:0;display:flex;flex-direction:column;max-width:var(--reading-width);margin:0 auto;width:100%;padding:1.5rem 1.5rem 1rem}.chunk-page-content{flex:1;min-height:0;overflow-y:auto;padding:.25rem .25rem 1rem}.bottom-nav{flex-shrink:0;display:flex;flex-direction:column;gap:.75rem;padding:1rem 0;border-top:1px solid var(--border)}.bottom-nav-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem 1rem}.bottom-nav-row.center{justify-content:center}.bottom-nav-count{font-size:.9rem;color:var(--text-muted);min-width:3.5rem;text-align:center}.pager-arrow{font-size:1.1rem;padding:.5rem 1rem}.progress-rail{position:sticky;top:0;align-self:flex-start;height:100vh;overflow-y:auto;flex-shrink:0;width:130px;border-right:1px solid var(--border);padding:1.5rem 1rem;box-sizing:border-box}@media(max-width:900px){.progress-rail{display:none}}.container{width:100%;max-width:720px;margin:0 auto;padding:0 1rem;box-sizing:border-box}.breadcrumb-link{color:var(--text-muted);font-size:.85rem;text-decoration:none}.book-header-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;width:100%}.book-title-block{min-width:0;flex:1 1 auto;overflow-wrap:anywhere}.book-actions{display:flex;gap:.5rem;flex-wrap:wrap;flex-shrink:0}.chunk-list{width:100%;box-sizing:border-box;border:1px solid var(--border);border-radius:10px;overflow:hidden}.chunk-row{display:flex;align-items:center;gap:1rem;width:100%;box-sizing:border-box;padding:.875rem 1rem;border-bottom:1px solid var(--border);background:var(--surface);text-decoration:none;transition:background .1s}.chunk-row:hover{background:var(--bg-secondary)}.chunk-row-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.chunk-row-label{flex:1 1 auto;min-width:0;font-size:.95rem;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chunk-row-arrow{flex-shrink:0;color:var(--text-muted);font-size:1rem}@media(max-width:640px){.book-header-row{flex-direction:column;align-items:stretch}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1.25rem;border:1.5px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font-family:var(--font-sans);font-size:.875rem;font-weight:500;cursor:pointer;text-decoration:none;transition:background .15s,border-color .15s,color .15s;white-space:nowrap}.btn:hover{background:var(--bg-secondary)}.btn-primary{background:var(--accent);color:var(--bg);border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-ghost{border-color:transparent;background:transparent}.btn-ghost:hover{background:var(--bg-secondary)}.btn:disabled{opacity:.45;cursor:not-allowed}input,textarea{width:100%;padding:.6rem .75rem;border:1.5px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font-family:var(--font-sans);font-size:.9rem;transition:border-color .15s;outline:none}input:focus,textarea:focus{border-color:var(--accent)}textarea{resize:vertical;min-height:120px;font-family:var(--font-serif);font-size:var(--reading-size);line-height:1.6}label{display:block;font-size:.8rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.4rem}.form-group{margin-bottom:1.2rem}.form-error{color:var(--error);font-size:.85rem;margin-top:.4rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:1.25rem;box-shadow:var(--shadow)}.card-heading{margin-bottom:.75rem;font-size:.95rem;font-weight:600}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--text);border-radius:50%;animation:spin .7s linear infinite}.highlight-mark{background:#ffdc0059;border-radius:2px;cursor:pointer}[data-dark=true] .highlight-mark{background:#ffdc002e}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.streaming-cursor:after{content:"▋";animation:blink .8s step-end infinite;font-size:.85em;margin-left:1px}.progress-bar{height:3px;background:var(--border);border-radius:2px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}.app-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.5rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);background:var(--bg);position:sticky;top:0;z-index:100}.app-header .logo{font-family:var(--font-serif);font-style:italic;font-size:1.1rem;font-weight:400;text-decoration:none;color:var(--text)}.interlocutor-response{font-family:var(--font-serif);font-size:var(--reading-size);line-height:var(--reading-line-height);color:var(--text);text-align:left;white-space:pre-wrap}.dialogue-panel{flex:1;min-height:0;display:flex;flex-direction:column}.dialogue-composer{flex-shrink:0;margin:.75rem .25rem .25rem;padding:.5rem .5rem .5rem 1rem;border:1.5px solid var(--border);border-radius:22px;background:var(--surface);display:flex;flex-wrap:nowrap;gap:.5rem;align-items:flex-end;transition:border-color .15s}.dialogue-composer:focus-within{border-color:var(--accent)}.dialogue-composer textarea{flex:1 1 0%;min-width:0;min-height:0;max-height:10rem;resize:none;border:none;background:transparent;padding:.45rem 0;overflow-y:auto}.dialogue-composer textarea:focus{border-color:transparent}.dialogue-composer .send-btn{flex-shrink:0;width:2.25rem;height:2.25rem;padding:0;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.15rem;line-height:1;background:var(--accent);color:var(--bg);cursor:pointer;transition:background .15s}.dialogue-composer .send-btn:hover{background:var(--accent-hover)}.dialogue-composer .send-btn:disabled{opacity:.4;cursor:not-allowed}.chat-thread{display:flex;flex-direction:column;gap:1.25rem}.chat-turn{display:flex;flex-direction:column;max-width:80%}.chat-turn.user{align-self:flex-end}.chat-turn.assistant{align-self:flex-start}.chat-bubble{padding:.75rem 1.1rem;border-radius:16px;font-family:var(--font-serif);font-size:var(--reading-size);line-height:var(--reading-line-height);white-space:pre-wrap;text-align:left}.chat-bubble.assistant{background:var(--bg-secondary);color:var(--text);border-bottom-left-radius:4px}.chat-bubble.user{background:var(--accent);color:var(--bg);border-bottom-right-radius:4px}.chat-label{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.3rem}.chat-turn.user .chat-label{text-align:right}.concept-term{font-style:italic;text-decoration:underline;text-decoration-thickness:1.5px;text-underline-offset:3px;cursor:help;position:relative}.concept-term:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:2px}.concept-popover{z-index:200;width:min(280px,90vw);background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:.75rem .875rem;box-shadow:0 4px 16px #0000001f;pointer-events:none}.concept-popover-term{font-weight:600;font-size:.875rem;margin-bottom:.25rem}.concept-popover-def{font-size:.8125rem;line-height:1.45;color:var(--text-muted)}.concept-card{border:1px solid var(--border);border-radius:8px;padding:1rem 1.125rem;background:var(--surface);margin:1.5rem 0}.concept-card-header{display:flex;align-items:baseline;gap:.5rem;margin-bottom:.5rem}.concept-card-term{font-weight:600;font-size:1rem}.concept-card-source{font-size:.8125rem;color:var(--text-muted);font-style:italic}.concept-card-def{font-size:.9rem;line-height:1.55;margin-bottom:.4rem}.concept-card-note{font-size:.8125rem;color:var(--text-muted);border-left:2px solid var(--border);padding-left:.5rem}.retrieval-card{border:1px solid var(--border);border-radius:10px;padding:1.25rem;background:var(--surface);box-shadow:var(--shadow)}.retrieval-score{display:inline-flex;align-items:center;gap:.25rem;font-size:.8rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:.2rem .5rem;border-radius:4px}.retrieval-score[data-score="3"]{background:#27ae601f;color:#1a8a4a}.retrieval-score[data-score="2"]{background:#3498db1f;color:#1a6a9a}.retrieval-score[data-score="1"]{background:#f39c121f;color:#9a5a00}.retrieval-score[data-score="0"]{background:#c0392b1a;color:#a02020}.reread-highlight{background:#ffdc004d;border-radius:2px}[data-dark=true] .reread-highlight{background:#ffdc0026}.argument-map-container{border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--bg-secondary);position:relative}@media(max-width:640px){.container{padding:0 .875rem}h1{font-size:1.3rem}.app-header{padding:.6rem .875rem}:root{--reading-size: 14pt}.bottom-nav-row{gap:.5rem}.bottom-nav-row .btn{padding:.5rem .75rem}.bottom-nav-count{min-width:2.25rem;font-size:.8rem}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media(prefers-color-scheme:dark){:root:not([data-dark=false]){--bg: #1a1905;--bg-secondary: #222211;--surface: #2a2a18;--border: #3a3a28;--text: #e8e4d8;--text-muted: #8a8570;--accent: #e8e4d8;--accent-hover: #ffffff;--shadow: 0 1px 3px rgba(0,0,0,.4)}}
