.app-shell{display:grid;grid-template-rows:64px 1fr 40px;height:100%;background:var(--bg)}.toolbar{display:flex;align-items:center;gap:14px;height:64px;padding:0 16px;background:var(--surface);border-bottom:1px solid var(--rule);font-family:var(--sans)}.toolbar__logo{font-family:var(--serif-disp);font-style:italic;font-size:18px;color:var(--text);letter-spacing:.3px}.toolbar__spacer{flex:1}.toolbar button{background:transparent;color:var(--text);border:none;border-bottom:1px solid transparent;padding:4px 8px 3px;font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:.2px;cursor:pointer}.toolbar button:hover:not(:disabled){color:var(--primary);border-bottom-color:var(--primary)}.toolbar button:disabled{color:var(--text-tertiary);cursor:default}.toolbar button[aria-pressed=true]{color:var(--primary);border-bottom-color:var(--primary);font-style:italic}.toolbar__nav{font-family:var(--serif);font-size:22px;padding:0 2px}.toolbar__zoom{font-family:var(--serif);font-size:18px}.toolbar__open{background:var(--primary);color:var(--paper);border:1px solid var(--primary);border-radius:2px;padding:4px 14px;font-weight:600;letter-spacing:.6px}.toolbar__open:hover{background:var(--primary-hover);border-color:var(--primary-hover);color:var(--paper)}.toolbar__page-input{width:48px;background:transparent;color:var(--text);border:none;border-bottom:1px solid var(--border);text-align:center;font-family:var(--sans);font-size:12px}.toolbar__page-input:focus{outline:none;border-bottom-color:var(--primary)}.toolbar__page-total{color:var(--text-secondary);font-size:12px}.toolbar__hl-label{font-family:var(--sans);font-size:10px;letter-spacing:.6px;color:var(--text-tertiary);text-transform:uppercase}.statusbar{display:flex;align-items:center;justify-content:space-between;height:40px;padding:0 16px;background:var(--surface);border-top:1px solid var(--rule);font-size:11px;color:var(--text-secondary)}.statusbar__selection{color:var(--text);font-style:italic}.reader-body{display:grid;grid-template-columns:var(--toc-w, 220px) 1fr var(--right-w, 0px);min-height:0;overflow:hidden}.toc{background:var(--surface);border-right:1px solid var(--border);overflow-y:auto;padding:10px 6px;font-size:12px}.toc__empty{color:var(--text-tertiary);padding:12px;font-style:italic}.toc__item{display:block;width:100%;text-align:left;background:transparent;border:none;color:var(--text-secondary);padding:3px 6px;cursor:pointer;font-family:var(--sans);font-size:12px;border-left:2px solid transparent}.toc__item:hover{color:var(--primary)}.toc__item--l1{color:var(--text);font-weight:600}.toc__item--current{color:var(--primary);border-left-color:var(--primary);background:var(--surface-hover)}.minimap{position:absolute;right:8px;top:0;bottom:0;display:flex;flex-direction:column;justify-content:center;gap:6px;padding:10px 6px;z-index:5;background:#0e131b8c;border-left:1px solid var(--rule);opacity:.35;transition:opacity .18s ease}.minimap:hover{opacity:1}.minimap__chip{position:relative;width:96px;flex:1 1 0;min-height:0;background:#f4f0e8;border:1px solid var(--rule);border-radius:2px;padding:0;cursor:pointer;overflow:hidden;line-height:0}.minimap__chip:hover{border-color:var(--primary)}.minimap__chip--current{border-color:var(--primary);border-width:2px}.minimap__thumb{display:block;width:100%;height:100%;object-fit:contain}.minimap__badge{position:absolute;top:1px;right:1px;min-width:18px;padding:0 3px;background:#0e131bcc;color:var(--text-secondary);font-family:var(--sans);font-size:9px;line-height:12px;text-align:center}.minimap__chip--current .minimap__badge{color:var(--primary);font-weight:600}.minimap__markers{position:absolute;top:2px;left:2px;display:flex;flex-direction:column;gap:2px}.minimap__marker{width:6px;height:6px;border-radius:50%;box-shadow:0 0 0 1px #0e131b99}.reader-pane{position:relative;overflow:hidden}.pageview{height:100%;overflow-y:auto;background:var(--bg);display:flex;flex-direction:column;align-items:center;gap:24px;padding:24px 0}.page{position:relative;background:#fff;box-shadow:0 2px 16px #00000080}.page__canvas{display:block}.page__overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2}.word{position:absolute;cursor:text}.page__bands{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1}.band{position:absolute}.ctx-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40}.ctx-menu{position:fixed;z-index:41;background:var(--surface);border:1px solid var(--border);border-radius:2px;padding:4px;box-shadow:0 4px 18px #00000080}.ctx-menu button{background:transparent;color:var(--text);border:none;cursor:pointer;font-family:var(--sans);font-size:12px;padding:6px 10px;white-space:nowrap}.ctx-menu button:hover{color:var(--primary)}.right-stack{background:var(--surface);border-left:1px solid var(--border);overflow-y:auto}.panel-placeholder{padding:16px;color:var(--text-tertiary);font-size:12px;font-style:italic}.notes-panel{display:flex;flex-direction:column;height:100%;font-size:12px}.notes-panel__tabs{display:flex;border-bottom:1px solid var(--rule)}.notes-panel__tabs button{flex:1;background:transparent;color:var(--text-secondary);border:none;border-bottom:2px solid transparent;padding:10px 0;cursor:pointer;font-family:var(--sans);font-size:12px;letter-spacing:.4px}.notes-panel__tabs button[aria-pressed=true]{color:var(--primary);border-bottom-color:var(--primary);font-style:italic}.notes-panel__body{padding:10px;overflow-y:auto}.notes-panel__new{width:100%;background:transparent;color:var(--text);border:1px solid var(--border);border-radius:2px;padding:7px;cursor:pointer;font-family:var(--sans);font-size:11px;margin-bottom:10px}.notes-panel__new:hover:not(:disabled){color:var(--primary);border-color:var(--primary)}.notes-panel__new:disabled{color:var(--text-tertiary);cursor:default}.note-editor{display:flex;flex-direction:column;gap:6px;margin-bottom:12px;padding:8px;background:var(--paper);border:1px solid var(--border)}.note-editor__quote{color:var(--text-secondary);font-style:italic;font-size:11px}.note-editor input,.note-editor textarea,.note-editor select,.gloss-editor input{background:transparent;color:var(--text);border:none;border-bottom:1px solid var(--border);padding:4px 2px;font-family:var(--sans);font-size:12px}.note-editor textarea{min-height:64px;resize:vertical;font-family:var(--serif)}.note-editor__actions{display:flex;gap:8px}.note-editor__actions button,.gloss-editor button{background:transparent;color:var(--text);border:1px solid var(--border);border-radius:2px;padding:4px 12px;cursor:pointer;font-size:11px}.note-editor__actions button:hover,.gloss-editor button:hover{color:var(--primary);border-color:var(--primary)}.note-row{display:flex;align-items:center;gap:6px;padding:4px 0}.note-row__dot{width:8px;height:8px;border-radius:50%;flex:none}.note-row__title{flex:1;text-align:left;background:transparent;border:none;color:var(--text);cursor:pointer;font-family:var(--sans);font-size:12px;padding:0}.note-row__title:hover{color:var(--primary)}.note-row__page{color:var(--text-tertiary);font-size:10px}.note-row__del,.gloss-row button{background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;font-size:14px}.note-row__del:hover,.gloss-row button:hover{color:var(--note-tension)}.gloss-editor{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.gloss-row{display:flex;align-items:baseline;gap:8px;padding:5px 0;border-bottom:1px solid var(--border)}.gloss-row__term{color:var(--primary);font-weight:600}.gloss-row__def{flex:1;color:var(--text-secondary)}.note-row--on{background:var(--surface-hover)}.note-editor__colors{display:flex;gap:6px}.note-swatch{width:16px;height:16px;border-radius:50%;border:1px solid var(--border);cursor:pointer;padding:0}.note-swatch--on{box-shadow:0 0 0 2px var(--primary)}.note-editor__parent{display:flex;align-items:center;gap:6px;font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--text-tertiary)}.note-editor__parent select{flex:1;background:transparent;color:var(--text);border:none;border-bottom:1px solid var(--border);font-family:var(--serif);font-size:12px;font-style:italic}.note-fmt{display:flex;align-items:center;gap:4px}.note-fmt button{width:24px;height:22px;background:transparent;color:var(--text);border:none;border-bottom:1px solid transparent;cursor:pointer;font-family:var(--serif);font-size:14px}.note-fmt button:hover{color:var(--primary);border-bottom-color:var(--primary)}.note-fmt select{background:transparent;color:var(--text);border:none;border-bottom:1px solid var(--border);font-size:11px}.note-body{min-height:100px;max-height:320px;overflow-y:auto;background:var(--paper);color:var(--text);border:1px solid var(--border);border-radius:1px;padding:8px 10px;font-family:var(--serif);font-size:13px;line-height:1.6}.note-body:focus{outline:none;border-color:var(--primary)}:root{--bg: #0e131b;--paper: #161c27;--surface: #131923;--surface-hover: #1d2535;--primary: #d4a85a;--primary-hover: #e6bd72;--text: #e8e1cf;--text-secondary: #9b9079;--text-tertiary: #6b6453;--border: #2a3142;--rule: #38415a;--accent: #6b8a8a;--highlight: #3a2e1a;--serif: "Source Serif 4", "Source Serif Pro", "Constantia", "Cambria", "Georgia", serif;--serif-disp: "Newsreader", "Source Serif 4", "Constantia", "Cambria", "Georgia", serif;--sans: "IBM Plex Sans", "Inter", "Segoe UI Variable Text", "Segoe UI", sans-serif;--note-default: #6366f1;--note-unclear: #f59e0b;--note-clear: #10b981;--note-tension: #ef4444;--note-key: #22d3ee}*{box-sizing:border-box}html,body,#root{margin:0;height:100%;background:var(--bg);color:var(--text);font-family:var(--sans)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--rule)}
