:root{--color-bg: #0a0a0f;--color-bg-elevated: #13131a;--color-surface: #1a1a24;--color-gold: #d4a853;--color-gold-dim: #8a7035;--color-crimson: #c0392b;--color-ivory: #f5f0e8;--color-ivory-dim: #a89e8e;--color-text: #e8e4dc;--color-text-dim: #7a7568;--color-jade: #2ecc71;--color-blue-steel: #5b8cb8;--color-purple: #9b59b6;--glow-gold: 0 0 20px rgba(212, 168, 83, .4);--glow-crimson: 0 0 20px rgba(192, 57, 43, .4);--glow-node: 0 0 12px rgba(212, 168, 83, .6);--font-serif: "Noto Serif SC", "Songti SC", "STSong", serif;--font-mono: "SF Mono", "Fira Code", monospace;--panel-width: 420px;--header-height: 60px;--chapter-bar-height: 100px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow:hidden;background-color:var(--color-bg);color:var(--color-text);font-family:var(--font-serif);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}.bg-layer{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0}#bg-grain{opacity:.035;background-image:url('data:image/svg+xml,<svg viewBox="0 0 256 256" xmlns="http://www.w3.org/2000/svg"><filter id="noise"><feTurbulence type="fractalNoise" baseFrequency="0.9" numOctaves="4" stitchTiles="stitch"/></filter><rect width="100%" height="100%" filter="url(%23noise)" opacity="1"/></svg>');background-repeat:repeat;background-size:256px 256px;z-index:1}#bg-particles{z-index:0}#app{position:relative;width:100%;height:100%;z-index:2;display:flex;flex-direction:column}#chapter-bar-mount{position:relative;z-index:50;flex-shrink:0}#chapter-bar-mount .chapter-bar{font-family:var(--font-serif)}.chapter-bar.map-mode .chapter-storyline-part{display:none!important}#chapter-bar-mount .chapter-bar::-webkit-scrollbar{height:4px}#chapter-bar-mount .chapter-bar::-webkit-scrollbar-thumb{background:#d4a85333;border-radius:2px}#header{height:var(--header-height);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 24px;background:linear-gradient(180deg,#0a0a0ff2,#0a0a0f00);position:relative;z-index:10;flex-shrink:0}.title{font-size:24px;font-weight:900;letter-spacing:8px;color:var(--color-gold);text-shadow:0 0 30px rgba(212,168,83,.3)}.subtitle{font-size:12px;color:var(--color-text-dim);letter-spacing:4px;margin-top:2px}.bio-banner{display:flex;align-items:center;justify-content:center;gap:16px;padding:8px 20px;background:#0a0a0fe6;border-bottom:1px solid rgba(212,168,83,.15);flex-shrink:0;z-index:15}.bio-banner.hidden{display:none}.bio-banner-text{font-size:14px;font-weight:600;letter-spacing:2px;color:var(--color-gold)}.bio-banner-exit{padding:4px 16px;background:transparent;border:1px solid rgba(212,168,83,.3);color:var(--color-gold-dim);font-family:var(--font-serif);font-size:12px;border-radius:4px;cursor:pointer;transition:all .3s ease}.bio-banner-exit:hover{background:#d4a8531a;border-color:var(--color-gold);color:var(--color-gold)}#timeline-container{flex:1;position:relative;overflow:hidden;cursor:grab}#timeline-container:active{cursor:grabbing}#timeline-svg{width:100%;height:100%}.panel{position:fixed;top:0;right:0;width:var(--panel-width);height:100%;background:linear-gradient(135deg,#13131af7,#0a0a0ffa);border-left:1px solid rgba(212,168,83,.15);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:100;padding:32px 28px;overflow-y:auto;transition:transform .5s cubic-bezier(.16,1,.3,1),opacity .4s ease}.panel.hidden{transform:translate(100%);opacity:0;pointer-events:none}.panel-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border:1px solid rgba(212,168,83,.2);border-radius:50%;background:transparent;color:var(--color-gold);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.panel-close:hover{background:#d4a8531a;border-color:var(--color-gold)}#character-card{width:360px;right:auto;left:50%;top:50%;height:auto;max-height:85vh;transform:translate(-50%,-50%);border-radius:12px;border:1px solid rgba(212,168,83,.2);text-align:center;padding:40px 32px 32px}#character-card.hidden{transform:translate(-50%,-50%) scale(.9);opacity:0;pointer-events:none}.card-portrait{width:100px;height:100px;border-radius:50%;border:3px solid var(--color-gold);margin:0 auto 16px;background-size:cover;background-position:center;box-shadow:var(--glow-gold)}.card-name{font-size:24px;font-weight:700;color:var(--color-gold);margin-bottom:4px}.card-years{font-size:14px;color:var(--color-text-dim);margin-bottom:16px}.card-bio{font-size:14px;line-height:1.8;color:var(--color-text);text-align:left;margin-bottom:20px}.card-actions{display:flex;gap:10px;justify-content:center}.card-follow-btn,.card-bio-mode-btn{padding:10px 20px;background:transparent;border:1px solid var(--color-gold);color:var(--color-gold);font-family:var(--font-serif);font-size:13px;border-radius:4px;cursor:pointer;transition:all .3s ease}.card-follow-btn:hover,.card-bio-mode-btn:hover{background:#d4a85326;box-shadow:var(--glow-gold)}.card-bio-mode-btn{border-style:dashed}.panel-header{margin-bottom:20px}.event-title{font-size:22px;font-weight:700;color:var(--color-gold);margin-bottom:4px}.event-year{font-size:14px;color:var(--color-text-dim);font-family:var(--font-mono)}.event-characters{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}.event-char-chip{display:flex;align-items:center;gap:6px;padding:4px 12px 4px 4px;background:#ffffff0d;border-radius:20px;border:1px solid rgba(255,255,255,.08);font-size:12px;color:var(--color-ivory-dim)}.event-char-chip img{width:24px;height:24px;border-radius:50%;object-fit:cover}.event-tabs{display:flex;gap:0;margin-bottom:20px;border-bottom:1px solid rgba(255,255,255,.08)}.tab{flex:1;padding:10px 12px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--color-text-dim);font-family:var(--font-serif);font-size:14px;cursor:pointer;transition:all .3s ease}.tab:hover{color:var(--color-text)}.tab.active{color:var(--color-gold);border-bottom-color:var(--color-gold)}.event-content{font-size:15px;line-height:1.9;color:var(--color-text)}.event-content h2{display:none}.event-content p{margin-bottom:12px}.event-content blockquote{border-left:2px solid var(--color-gold);padding-left:16px;margin:16px 0;color:var(--color-ivory-dim);font-style:italic}.event-scenes{margin-top:24px}.scene-card{padding:14px 18px;background:#ffffff08;border:1px solid rgba(212,168,83,.12);border-radius:8px;margin-bottom:10px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:space-between}.scene-card:hover{background:#d4a8530f;border-color:#d4a8534d}.scene-card-title{font-size:14px;color:var(--color-ivory)}.scene-card-arrow{color:var(--color-gold-dim);font-size:18px}.event-related{margin-top:20px;padding-top:16px;border-top:1px solid rgba(255,255,255,.06)}.overlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:200;display:flex;align-items:center;justify-content:center;transition:opacity .4s ease}.overlay.hidden{opacity:0;pointer-events:none}.overlay-backdrop{position:absolute;top:0;left:0;width:100%;height:100%;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.scene-container{position:relative;width:600px;max-width:90vw;max-height:80vh;overflow-y:auto;background:var(--color-bg-elevated);border:1px solid rgba(212,168,83,.15);border-radius:12px;padding:40px 36px}.overlay-close{position:absolute;top:12px;right:12px;width:36px;height:36px;border:1px solid rgba(212,168,83,.2);border-radius:50%;background:transparent;color:var(--color-gold);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.overlay-close:hover{background:#d4a8531a}.scene-title{font-size:20px;color:var(--color-gold);margin-bottom:20px}.dialogue-line{display:flex;gap:12px;margin-bottom:16px;align-items:flex-start}.dialogue-avatar{width:36px;height:36px;border-radius:50%;border:2px solid var(--color-gold-dim);flex-shrink:0;background-size:cover;background-position:center}.dialogue-bubble{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:0 12px 12px;padding:10px 16px;font-size:14px;line-height:1.7;color:var(--color-text);max-width:80%}.dialogue-speaker{font-size:12px;color:var(--color-gold-dim);margin-bottom:3px;font-weight:600}.dialogue-text{color:var(--color-ivory)}.typewriter .char{opacity:0;animation:typeChar .03s forwards}@keyframes typeChar{to{opacity:1}}#minimap{position:fixed;bottom:20px;left:20px;width:200px;height:60px;background:#0a0a0fcc;border:1px solid rgba(212,168,83,.15);border-radius:6px;overflow:hidden;z-index:50}#minimap-canvas{width:100%;height:100%}#minimap-viewport{position:absolute;border:1px solid var(--color-gold);background:#d4a85314;pointer-events:none}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#d4a85333;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#d4a85366}.hidden{pointer-events:none}.zooming .character-line,.zooming .convergence-glow,.zooming .node-connector{shape-rendering:optimizeSpeed}.zooming .node-label,.zooming .personal-label,.zooming .personal-year,.zooming .era-label{visibility:hidden}.zooming .node-pulse{animation:none;opacity:0}.character-line{fill:none;stroke-width:2.5;stroke-linecap:round;transition:opacity .4s ease;pointer-events:stroke;paint-order:stroke}.character-line.dimmed{opacity:.15}.character-line.highlighted{stroke-width:3.5}.event-node{cursor:pointer;transition:transform .3s ease}.event-node:hover .node-ring{stroke-width:3}.node-core{fill:var(--color-gold)}.node-ring{fill:none;stroke:var(--color-gold);stroke-width:1.5;opacity:.5}.node-pulse{fill:none;stroke:var(--color-gold);stroke-width:1;opacity:0;animation:nodePulse 3s ease-out infinite}@keyframes nodePulse{0%{r:8;opacity:.6}to{r:24;opacity:0}}.node-label{font-family:var(--font-serif);font-size:12px;fill:var(--color-ivory-dim);text-anchor:middle;pointer-events:none}.char-start{cursor:pointer}.char-start-portrait{stroke:var(--color-gold-dim);stroke-width:2}.char-start-name{font-family:var(--font-serif);font-size:13px;fill:var(--color-text);font-weight:600}.time-axis line{stroke:#ffffff0f}.time-axis text{font-family:var(--font-mono);font-size:11px;fill:var(--color-text-dim)}.era-label{font-family:var(--font-serif);font-size:12px;fill:var(--color-gold-dim);letter-spacing:2px}.personal-event{transition:opacity .3s ease}.personal-label,.personal-year{pointer-events:none}.feedback-btn{position:fixed;top:16px;right:16px;width:44px;height:44px;border-radius:50%;border:1px solid rgba(212,168,83,.3);background:#13131ae6;color:var(--color-gold-dim);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:60;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.feedback-btn:hover{border-color:var(--color-gold);color:var(--color-gold);box-shadow:var(--glow-gold)}.feedback-overlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:300;display:flex;align-items:center;justify-content:center;transition:opacity .3s ease}.feedback-overlay.hidden{opacity:0;pointer-events:none}.feedback-backdrop{position:absolute;top:0;left:0;width:100%;height:100%;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.feedback-modal{position:relative;width:420px;max-width:90vw;max-height:85vh;overflow-y:auto;background:var(--color-bg-elevated);border:1px solid rgba(212,168,83,.2);border-radius:12px;padding:32px}.feedback-close{position:absolute;top:12px;right:12px;width:32px;height:32px;border:1px solid rgba(212,168,83,.2);border-radius:50%;background:transparent;color:var(--color-gold);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.feedback-close:hover{background:#d4a8531a}.feedback-title{font-size:20px;font-weight:700;color:var(--color-gold);margin-bottom:4px}.feedback-desc{font-size:13px;color:var(--color-text-dim);margin-bottom:20px}.feedback-form{display:flex;flex-direction:column;gap:16px}.feedback-label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--color-ivory-dim)}.feedback-input,.feedback-select,.feedback-textarea{width:100%;padding:10px 14px;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--color-text);font-family:var(--font-serif);font-size:14px;transition:border-color .3s ease}.feedback-input:focus,.feedback-select:focus,.feedback-textarea:focus{outline:none;border-color:#d4a85380}.feedback-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238a7035' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.feedback-select option{background:var(--color-bg-elevated);color:var(--color-text)}.feedback-textarea{resize:vertical;min-height:80px}.feedback-submit{padding:12px 24px;background:transparent;border:1px solid var(--color-gold);color:var(--color-gold);font-family:var(--font-serif);font-size:14px;border-radius:6px;cursor:pointer;transition:all .3s ease}.feedback-submit:hover:not(:disabled){background:#d4a85326;box-shadow:var(--glow-gold)}.feedback-submit:disabled{opacity:.5;cursor:not-allowed}.feedback-status{font-size:13px;text-align:center;min-height:20px}.feedback-status.success{color:var(--color-jade)}.feedback-status.error{color:var(--color-crimson)}.view-switcher{display:flex;gap:0;background:#ffffff0a;border:1px solid rgba(212,168,83,.25);border-radius:6px;overflow:hidden;flex-shrink:0;margin-right:8px}.view-switcher-btn{padding:8px 20px;background:transparent;border:none;border-right:1px solid rgba(212,168,83,.15);color:var(--color-text-dim);font-family:var(--font-serif);font-size:13px;letter-spacing:1px;cursor:pointer;transition:all .3s ease}.view-switcher-btn:last-child{border-right:none}.view-switcher-btn:hover{color:var(--color-ivory);background:#d4a8530f}.view-switcher-btn.active{color:var(--color-gold);background:#d4a8531f}#map-view{position:absolute;top:100px;left:0;width:100%;height:calc(100% - 100px);display:none;flex-direction:column;z-index:5}#map-view.active{display:flex}#map-container{flex:1;position:relative;overflow:hidden;background:var(--color-bg)}.map-svg text{font-family:var(--font-serif);pointer-events:none}.map-layer-filter{position:absolute;top:12px;right:12px;z-index:10;background:#0a0a0fd9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,215,0,.15);border-radius:8px;padding:8px 12px;display:flex;gap:14px}.map-filter-item{display:flex;align-items:center;gap:5px;cursor:pointer;font-size:12px;color:#fffc;font-family:var(--font-serif);-webkit-user-select:none;user-select:none}.map-filter-item input[type=checkbox]{appearance:none;width:14px;height:14px;border:1.5px solid rgba(255,255,255,.3);border-radius:3px;cursor:pointer;position:relative;flex-shrink:0}.map-filter-item input[type=checkbox]:checked{border-color:#ffd70099;background:#ffd70026}.map-filter-item input[type=checkbox]:checked:after{content:"";position:absolute;top:1px;left:4px;width:4px;height:7px;border:solid rgba(255,215,0,.9);border-width:0 1.5px 1.5px 0;transform:rotate(45deg)}.map-filter-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.map-scrubber{position:relative;background:#0a0a0ff2;border-top:1px solid rgba(212,168,83,.15);padding:8px 16px 12px;flex-shrink:0}.scrubber-eras{display:flex;gap:2px;margin-bottom:8px}.scrubber-era{flex-shrink:0;padding:3px 6px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:3px;font-size:10px;color:var(--color-text-dim);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:all .3s ease;cursor:default}.scrubber-era.active{background:#d4a8531a;border-color:#d4a8534d;color:var(--color-gold)}.scrubber-slider-row{display:flex;align-items:center;gap:12px}.scrubber-play-btn{width:32px;height:32px;border-radius:50%;border:1px solid rgba(212,168,83,.3);background:transparent;color:var(--color-gold);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .3s ease}.scrubber-play-btn:hover{background:#d4a8531a;border-color:var(--color-gold)}.scrubber-slider{flex:1;-webkit-appearance:none;appearance:none;height:4px;background:#ffffff1a;border-radius:2px;outline:none;cursor:pointer}.scrubber-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--color-gold);border:2px solid var(--color-bg);box-shadow:0 0 8px #d4a85380;cursor:grab}.scrubber-slider::-webkit-slider-thumb:active{cursor:grabbing}.scrubber-chapter-display{font-size:14px;font-weight:700;color:var(--color-gold);min-width:60px;text-align:center;font-family:var(--font-mono)}.scrubber-info{margin-top:6px;font-size:12px;color:var(--color-text-dim);text-align:center;letter-spacing:1px}.event-map-overlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:250;display:flex;align-items:center;justify-content:center;transition:opacity .4s ease}.event-map-overlay.hidden{opacity:0;pointer-events:none}.event-map-backdrop{position:absolute;top:0;left:0;width:100%;height:100%;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.event-map-modal{position:relative;width:800px;max-width:92vw;height:600px;max-height:80vh;background:var(--color-bg-elevated);border:1px solid rgba(212,168,83,.2);border-radius:12px;overflow:hidden;display:flex;flex-direction:column}.event-map-title{font-size:18px;color:var(--color-gold);padding:16px 48px 8px 20px;flex-shrink:0}.event-map-info{font-size:12px;color:var(--color-text-dim);padding:0 20px 12px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}.event-map-container{flex:1;position:relative;overflow:hidden}.city-marker:hover circle,.city-marker:hover path{filter:brightness(1.3)}.map-event-marker:hover circle{filter:brightness(1.4)}.map-char-avatar:hover circle{filter:brightness(1.3)}@keyframes mapEventPulse{0%{r:5;opacity:.6}to{r:18;opacity:0}}.event-pulse-ring{animation:mapEventPulse 2.5s ease-out infinite}
