:root{font-family:HarmonyOS Sans SC,Noto Sans SC,PingFang SC,Helvetica Neue,Arial,sans-serif;color:#0b192f;background-color:#f5f6fa;line-height:1.6;font-weight:400;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*,*:before,*:after{box-sizing:border-box}body{margin:0;background:radial-gradient(circle at top,#f8fbff,#edf1f8 60%,#e4e9f2);min-height:100vh}#app{min-height:100vh}.page{max-width:1280px;margin:0 auto;padding:2.5rem 1.5rem 3rem;display:flex;flex-direction:column;gap:2rem}.hero{background:#fff;border-radius:28px;padding:2.2rem;display:flex;flex-direction:column;gap:1.2rem;box-shadow:0 30px 60px #0d234314,0 6px 20px #0d23430f}.hero h1{margin:.4rem 0 .8rem;font-size:clamp(2.2rem,4vw,2.8rem);line-height:1.2}.subtitle{color:#4b5874;margin:0;max-width:40rem}.hero-stats{display:flex;gap:1.5rem;flex-wrap:wrap}.stat-number{margin:0;font-size:2rem;font-weight:700;color:#0b6ff8}.stat-label{margin:0;color:#5d6c89;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase}.eyebrow{text-transform:uppercase;letter-spacing:.1em;font-size:.75rem;color:#8c99b5;margin:0}.content-grid{display:grid;grid-template-columns:280px minmax(0,1fr) 350px;gap:1.5rem;align-items:flex-start}.navigation-panel{position:sticky;top:1.5rem;align-self:start;height:calc(100vh - 2rem);max-height:calc(100vh - 2rem);overflow:hidden;display:flex;width:100%}.info-panel{display:flex;flex-direction:column;gap:1.25rem}.info-panel>*:first-child{position:sticky;top:1.5rem}.info-panel>*:not(:first-child){position:static}.info-panel>*{background:#fff;border-radius:24px;padding:1.5rem;box-shadow:0 20px 40px #0b192f0d}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.panel-header h2{margin:.25rem 0 0;font-size:1.2rem}.ghost-button{border:1px solid rgba(11,25,47,.15);border-radius:999px;padding:.4rem 1rem;background:transparent;color:#0b192f;cursor:pointer;font-size:.85rem;transition:all .2s ease}.ghost-button:hover{border-color:#0b6ff8;color:#0b6ff8}.character-chip-row{display:flex;flex-wrap:wrap;gap:.6rem}.character-chip{border-radius:999px;border:1px solid rgba(11,25,47,.12);padding:.35rem .9rem;font-size:.85rem;background:#0b192f05;cursor:pointer;transition:all .2s ease;font-family:inherit;color:inherit;line-height:1.2;min-height:2rem;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;border-width:1px;border-style:solid}.character-chip:focus-visible{outline:2px solid rgba(11,111,248,.6);outline-offset:2px}.character-chip:hover{border-color:#0b6ff8b3}.chip-focus{background:#0b6ff81f;color:#0b6ff8;border-color:#0b6ff866}.character-spotlight{display:flex;flex-direction:column;gap:1rem}.spotlight-header{display:flex;flex-direction:column;gap:.3rem}.spotlight-card{border:1.5px solid rgba(11,25,47,.1);border-radius:24px;padding:1.5rem;background:#fff9;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.spotlight-description{margin:.75rem 0;color:#3b4356}.keyword-row{display:flex;flex-wrap:wrap;gap:.4rem}.tag{display:inline-flex;align-items:center;border-radius:999px;padding:.2rem .75rem;font-size:.75rem;background:#0b192f0d;color:#0b192f}.related-chapters{margin-top:1rem}.chapter-link-grid{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.6rem}.chip-button{border:1px solid rgba(11,25,47,.12);border-radius:12px;padding:.35rem .75rem;background:#fff;cursor:pointer;font-size:.85rem;transition:all .2s ease}.chip-button.active{border-color:#0b6ff8;color:#0b6ff8;background:#0b6ff814}.spotlight-placeholder{border-radius:20px;border:1px dashed rgba(11,25,47,.2);padding:1.5rem;color:#67718c}.chapter-navigation,.relationship-graph,.reader-panel{background:#fff;border-radius:28px;padding:1.75rem;box-shadow:0 25px 50px #0b192f0f}.navigation-panel .chapter-navigation{height:100%;width:100%;display:flex;flex-direction:column;gap:1rem;overflow:hidden}.chapter-nav-scroll{overflow-y:auto;padding-right:.25rem}.chapter-nav-scroll::-webkit-scrollbar{width:6px}.chapter-nav-scroll::-webkit-scrollbar-thumb{background:#0b192f40;border-radius:999px}.chapter-nav-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1rem}.chapter-nav-item{width:100%;border:1px solid rgba(11,25,47,.08);border-radius:18px;padding:1rem;background:#f6f9ff99;text-align:left;cursor:pointer;transition:all .2s ease}.chapter-nav-item:hover{border-color:#0b6ff880;box-shadow:0 15px 30px #0b192f14}.chapter-nav-item.active{border-color:#0b6ff8;background:#0b6ff814}.chapter-nav-title{display:flex;align-items:center;gap:.75rem}.chapter-order{font-size:.85rem;color:#8c99b5}.chapter-nav-title h3{margin:0}.chapter-meta{margin:.25rem 0 0;color:#6b7793;font-size:.9rem}.chapter-theme{margin:.6rem 0 .4rem;color:#1a2a44;font-weight:600}.chapter-summary-line{margin:0;color:#4b5874;font-size:.95rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.chapter-tag-row,.chapter-character-row{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}.character-chip{font-weight:500;background:#0b192f0a}.relationship-graph svg{width:100%;height:auto}.graph-controls{display:flex;flex-wrap:wrap;gap:.5rem}.graph-node{cursor:pointer}.graph-label{font-size:.75rem;font-weight:600;fill:#fff;pointer-events:none}.legend-row{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1.25rem}.legend-item{display:inline-flex;align-items:center;gap:.4rem}.legend-dot{width:.75rem;height:.75rem;border-radius:50%}.reader-panel{padding:2.5rem}.reader-panel.is-transitioning,.chapter-reader{animation:fadeInUp .35s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.chapter-reader-header h1{margin:.4rem 0 0;font-size:clamp(1.9rem,3.5vw,2.6rem)}.label{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:#7b889f;margin:0}.chapter-summary-block{margin-top:1.5rem}.chapter-summary-block h2{margin-bottom:.4rem}blockquote{margin:1rem 0 0;padding-left:1.25rem;border-left:4px solid rgba(11,111,248,.4);color:#1a2a44;font-style:italic}.anchor-grid{margin-top:2rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.anchor-grid article{border-radius:18px;background:#0b192f08;padding:1rem}.character-appearance-section{margin-top:2.5rem}.section-header{display:flex;align-items:baseline;justify-content:space-between;gap:1rem}.body-small{font-size:.85rem;color:#72809c;margin:0}.character-appearance-grid{margin-top:1rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.25rem}.character-card{border:1px solid rgba(11,25,47,.08);border-radius:20px;padding:1.25rem;background:#ffffffe6;display:flex;flex-direction:column;gap:.75rem}.character-card header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.character-card h3{margin:.2rem 0 0}.character-highlight{margin:0;color:#404a63}.emotion-pill{display:flex;align-items:center;gap:.5rem;font-size:.85rem;border-radius:999px;background:#0b192f0d;padding:.3rem .85rem}.tone{font-weight:600}.tone-calm{color:#5c6c80}.tone-tension{color:#e53935}.tone-warmth{color:#f57c00}.tone-melancholy{color:#5c6bc0}.tone-hope{color:#43a047}.intensity{display:inline-flex;gap:.15rem}.dot{width:.4rem;height:.4rem;border-radius:50%;background:#00000026}.dot-on{background:#0b6ff8}.primary-button{border:none;border-radius:999px;background:linear-gradient(120deg,#0b6ff8,#36c1d6);color:#fff;padding:.45rem 1.4rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;font-family:inherit}.primary-button:disabled{opacity:.6;cursor:not-allowed}.primary-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 20px #0b6ff84d}.chat-overlay{position:fixed;inset:0;background:#060e1ea6;display:flex;justify-content:flex-end;padding:1.5rem;z-index:10}.chat-panel{width:min(420px,100%);background:#fff;border-radius:28px;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;max-height:calc(100vh - 3rem);overflow:hidden;box-shadow:0 30px 70px #0a152d59;animation:fadeInUp .35s ease}.chat-header{display:flex;justify-content:space-between;align-items:center;gap:.75rem}.chat-config,.chat-input{display:flex;flex-direction:column;gap:.75rem}.chat-config label,.chat-input label{display:flex;flex-direction:column;gap:.35rem;font-size:.85rem;color:#5a657f}.chat-config input,.chat-config select,.chat-input textarea{border-radius:14px;border:1px solid rgba(11,25,47,.15);padding:.6rem .8rem;font-family:inherit;font-size:.95rem;background:#0b192f05}.chat-messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.75rem;padding-right:.25rem}.chat-bubble{border-radius:18px;padding:.75rem 1rem;font-size:.95rem;line-height:1.5}.chat-bubble.user{align-self:flex-end;background:#0b6ff81f;color:#0b192f}.chat-bubble.assistant{align-self:flex-start;background:#0b192f0d}.chat-bubble.assistant.streaming{border:1px dashed rgba(11,111,248,.35);background:#0b6ff814}.chat-actions{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.chat-error{color:#c62828;font-size:.85rem;margin:0}@media(max-width:720px){.chat-overlay{padding:.5rem}.chat-panel{width:100%;min-height:100%;border-radius:18px}}.attribute-bars{display:flex;flex-direction:column;gap:.6rem}.attribute-bar{display:flex;flex-direction:column;gap:.35rem}.attribute-label{display:flex;justify-content:space-between;font-size:.85rem}.bar-track{width:100%;height:6px;border-radius:999px;background:#0b192f14;overflow:hidden}.bar-fill{height:100%;border-radius:999px}.chapter-body{margin-top:3rem;padding-top:1.5rem;border-top:1px solid rgba(11,25,47,.08)}.chapter-body p{margin:0 0 1rem;color:#1f2d46}.chapter-body p[align=right]{text-align:right}.chapter-body br{content:"";display:block;margin-bottom:.6rem}.empty-state{padding:4rem 2rem;text-align:center;color:#6b7793}button{font-family:inherit}@media(max-width:1100px){.content-grid{grid-template-columns:1fr}.navigation-panel,.info-panel{position:static;max-height:none;height:auto;overflow:visible}.navigation-panel .chapter-navigation{height:auto}.chapter-nav-scroll{max-height:none;overflow:visible}}@media(max-width:720px){.hero,.chapter-navigation,.relationship-graph,.reader-panel{padding:1.5rem}.page{padding:1.5rem 1rem 2rem}}.chapter-insights{display:flex;flex-direction:column;gap:.85rem}.theme-pill{display:inline-flex;align-items:center;border-radius:999px;padding:.2rem .9rem;background:#0b6ff81f;color:#0b58c2;font-weight:600;font-size:.85rem}.summary-text{margin:0;color:#36415b;transition:all .2s ease}.summary-text.collapsed{display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.ghost-button.tiny{align-self:flex-start;padding:.2rem .7rem;font-size:.78rem}.chapter-insights header h2{margin:.1rem 0 0;font-size:1.4rem}.chapter-insights header .chapter-meta{margin-top:.15rem}.anchor-grid.compact{grid-template-columns:1fr;gap:.75rem}.insight-character-list{display:flex;flex-direction:column;gap:1rem}.mini-character-card{border:1px solid rgba(11,25,47,.08);border-radius:18px;padding:1rem;display:flex;flex-direction:column;gap:.6rem;background:#f9fcffcc}.mini-character-card header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.mini-character-card h4{margin:.2rem 0 0}.chapter-nav-scroll{overflow-y:auto;padding-right:.25rem;flex:1}
