:root{color:#f6ead2;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;--bg:#080c12;--bg-deep:#060a0f;--panel:#121a248c;--panel-strong:#18222eb8;--glass-border:#cee2f01f;--glass-highlight:#dcecfa1f;--text:#f6ead2;--muted:#b9a98d;--faint:#7c6d58;--accent:#c45532;--accent-strong:#ff7a45;--steel:#6f9bd6;--gold:#e6b15c;--ink:#080604;--line:#e6b15c33;--line-strong:#e6b15c66;--radius-panel:20px;--radius-pill:999px;background:#0c0907;font-family:Source Han Sans SC,PingFang SC,Microsoft YaHei,Noto Sans CJK SC,system-ui,sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background-color:#080c12;background-image:radial-gradient(60% 50% at 16% 6%,#466e9642,#0000 60%),radial-gradient(55% 50% at 86% 24%,#7896be24,#0000 58%),radial-gradient(70% 55% at 50% 112%,#c455321f,#0000 62%),none;background-position:0 0,0 0,0 0,0 0;background-repeat:repeat,repeat,repeat,repeat;background-size:auto,auto,auto,auto;background-attachment:fixed;background-origin:padding-box,padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box,border-box;min-width:320px;min-height:100dvh;margin:0}body:after{content:"";z-index:0;pointer-events:none;filter:blur(40px);background:radial-gradient(circle at 28% 38%,#78a0c814,#0000 30%),radial-gradient(circle at 72% 62%,#5a82aa12,#0000 32%);animation:22s ease-in-out infinite alternate auroraDrift;position:fixed;inset:-20%}@keyframes auroraDrift{0%{transform:translate(0,0)scale(1)}to{transform:translate(4%,-3%)scale(1.08)}}body:before{content:"";z-index:30;pointer-events:none;opacity:.05;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='120' height='120' filter='url(%23n)'/%3E%3C/svg%3E");position:fixed;inset:0}a{color:inherit;text-decoration:none}button,input{font:inherit}button{cursor:pointer}button:focus-visible,a:focus-visible,input:focus-visible,[role=button]:focus-visible{outline:2px solid var(--gold);outline-offset:4px}.app-shell{z-index:1;min-height:100dvh;position:relative}.page-transition{transform-origin:top;min-height:calc(100dvh - 72px);animation:.6s cubic-bezier(.16,1,.3,1) pageEnter}@keyframes pageEnter{0%{opacity:0;filter:blur(4px);transform:translateY(24px)scale(.98)}to{opacity:1;filter:blur();transform:translateY(0)scale(1)}}.site-nav{z-index:40;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#0a1018db;justify-content:space-between;align-items:center;gap:24px;height:72px;padding:0 clamp(20px,5vw,72px);display:flex;position:sticky;top:0}.nav-toggle{border:1px solid var(--line);width:42px;height:42px;color:var(--text);background:#cee2f00f;border-radius:12px;place-items:center;display:none}.brand-mark{letter-spacing:.08em;color:var(--gold);white-space:nowrap;font-weight:800}.nav-links{color:var(--muted);white-space:nowrap;align-items:center;gap:clamp(14px,3vw,34px);display:flex}.nav-links a{border-radius:var(--radius-pill);border:1px solid #0000;padding:8px 12px;font-size:.94rem;transition:color .22s,transform .22s,border-color .22s,background .22s}.nav-links a:hover,.nav-links a.is-active{color:var(--text);background:#e6b15c0f;border-color:#e6b15c38;transform:translateY(-1px)}.hero-section{align-items:flex-end;min-height:100dvh;padding:0 clamp(20px,7vw,110px) clamp(56px,10vh,120px);display:flex;position:relative;overflow:hidden}.hero-cover-image{background-image:url(/scenes/songjiang.webp);background-position:50% 38%;background-size:cover;animation:26s ease-in-out infinite alternate heroPan;position:absolute;inset:0;transform:scale(1.06)}.hero-cover-grade{mix-blend-mode:normal;background:linear-gradient(#080e168c 0%,#080e1633 38%,#070b12e6 100%),linear-gradient(90deg,#070b12d1 0%,#070b1240 50%,#0000 100%),radial-gradient(circle at 70% 30%,#3c6e9629,#0000 55%);position:absolute;inset:0}.hero-cover-grade:after{content:"";mix-blend-mode:overlay;background:#28507829;position:absolute;inset:0}@keyframes heroPan{0%{transform:scale(1.06)translate(0)}to{transform:scale(1.12)translate(-2%)}}.hero-copy-block{z-index:1;max-width:720px;position:relative}.hero-copy-block>*{opacity:0;animation:.8s cubic-bezier(.16,1,.3,1) forwards heroReveal}.hero-copy-block>.hero-kicker{animation-delay:.12s}.hero-copy-block>h1{animation-delay:.26s}.hero-copy-block>.hero-copy{animation-delay:.42s}.hero-copy-block>.hero-actions{animation-delay:.56s}@keyframes heroReveal{0%{opacity:0;filter:blur(6px);transform:translateY(26px)}to{opacity:1;filter:blur();transform:translateY(0)}}.hero-kicker,.section-kicker,.panel-label{color:var(--gold);letter-spacing:.22em;margin:0 0 14px;font-size:.78rem;font-weight:800}.hero-section h1{letter-spacing:-.03em;background:linear-gradient(#f4fbff 26%,#aac4dc 128%);color:#0000;text-shadow:0 10px 50px #08101a99;-webkit-background-clip:text;background-clip:text;max-width:880px;margin:0;font-size:clamp(3rem,7.5vw,7rem);line-height:1.04}.hero-copy{color:#d7e2ec;text-shadow:0 2px 14px #08101ab3;max-width:600px;margin:22px 0 0;font-size:clamp(1rem,2vw,1.3rem);line-height:1.85}.hero-actions{flex-wrap:wrap;gap:14px;margin-top:34px;display:flex}.button,.inline-buttons button,.event-actions button,.filter-row button{border:1px solid var(--line);border-radius:var(--radius-pill);color:var(--text);letter-spacing:.03em;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(#fff5dc14,#fff5dc08),#f6ead20d;padding:12px 24px;font-weight:600;transition:transform .22s,border-color .22s,background .22s,box-shadow .22s;box-shadow:inset 0 1px #fff5dc1f,0 4px 12px #0000001a}.button.primary{color:#fff7ea;background:radial-gradient(circle at 20% 0,#ffd99b33,#0000 34%),linear-gradient(135deg,#c45532,#8f3b25);border-color:#e06d3fbf}.button.secondary{color:#f6ead2}.button:hover,.inline-buttons button:hover,.event-actions button:hover,.filter-row button:hover{border-color:var(--gold);transform:translateY(-1px);box-shadow:0 12px 26px #00000038,inset 0 1px #fff5dc1f}.button:active,.inline-buttons button:active,.event-actions button:active,.filter-row button:active{transform:translateY(1px)}.section-block{padding:clamp(76px,9vw,132px) clamp(20px,6vw,96px)}.section-heading{max-width:760px;margin-bottom:34px}.section-heading.compact{margin-bottom:28px}.section-heading h2,.timeline-detail h2,.source-card h2{letter-spacing:-.04em;background:linear-gradient(#fff7ea 35%,#c79a55 130%);color:#0000;-webkit-background-clip:text;background-clip:text;margin:0;font-size:clamp(2.1rem,4.6vw,4.6rem);line-height:1.06}.section-heading p,.timeline-detail>p,.source-card p{color:var(--muted);line-height:1.8}.source-card{grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);align-items:stretch;gap:22px;display:grid}.character-grid,.world-map-layout{grid-template-columns:1fr;gap:22px;display:grid}.detail-panel,.character-panel,.graph-card,.timeline-track,.timeline-detail,.source-card,.profile-card{border:1px solid var(--glass-border);border-radius:var(--radius-panel);background:var(--panel);-webkit-backdrop-filter:blur(20px)saturate(140%);backdrop-filter:blur(20px)saturate(140%);box-shadow:inset 0 1px 0 var(--glass-highlight), 0 24px 70px #00000073}.map-figure{border-radius:var(--radius-panel);border:1px solid var(--glass-border);background:#0a121c;width:100%;line-height:0;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #fff8dc1a,0 24px 70px #00000073}.map-base{width:100%;height:auto;display:block}.map-markers{line-height:normal;position:absolute;inset:0}.map-pin{z-index:2;background:0 0;border:0;justify-items:center;gap:5px;padding:0;transition:transform .18s cubic-bezier(.16,1,.3,1);display:grid;position:absolute;transform:translate(-50%,-50%)}.pin-dot{background:#f7fafae6;border:2px solid #14243ad9;border-radius:50%;width:13px;height:13px;box-shadow:0 0 0 4px #0a121c59,0 2px 6px #0009}.pin-label{border-radius:var(--radius-pill);color:#f8fbff;white-space:nowrap;text-shadow:0 1px 2px #000000e6;opacity:.95;pointer-events:none;background:#060b12c7;border:1px solid #cee2f047;padding:1px 7px;font-size:.7rem;font-weight:700;transition:opacity .16s,transform .16s,background .16s;box-shadow:0 1px 4px #00000080}.map-pin:hover{z-index:4;transform:translate(-50%,-50%)scale(1.12)}.map-pin:hover .pin-label{opacity:1;background:#060b12f2;border-color:#e6b15c99}.map-pin.is-active .pin-dot,.map-pin.is-character-location .pin-dot{background:#e6b15c;border-color:#5a3416;box-shadow:0 0 0 4px #e6b15c40,0 2px 6px #0009}.map-pin.is-selected{z-index:5}.map-pin.is-selected .pin-dot{background:#ff7a45;border-color:#2a1710;width:16px;height:16px;animation:1.8s ease-in-out infinite pinPulse;box-shadow:0 0 0 5px #c4553259,0 0 14px #ff7a45b3}.map-pin.is-selected .pin-label{opacity:1;color:#fff7ea;background:#8d3f25;border-color:#2a1710;transform:translateY(0)}@keyframes pinPulse{0%,to{box-shadow:0 0 0 5px #c4553259,0 0 12px #ff7a4599}50%{box-shadow:0 0 0 8px #c455322e,0 0 20px #ff7a45d9}}.route-controls{flex-wrap:wrap;align-items:center;gap:14px;display:flex}.route-play-btn{border-radius:var(--radius-pill);color:#ffe6bd;cursor:pointer;background:linear-gradient(120deg,#ffb25438,#c4553233);border:1px solid #ffcf7a80;align-items:center;gap:8px;padding:10px 18px;font-size:.9rem;font-weight:700;transition:transform .16s,box-shadow .16s,background .16s;display:inline-flex;box-shadow:0 0 0 1px #ffcf7a1f,0 6px 18px #00000059}.route-play-btn:hover{background:linear-gradient(120deg,#ffb25452,#c4553247);transform:translateY(-1px);box-shadow:0 0 18px #ffa04666}.route-hint{color:var(--muted);margin:0;font-size:.84rem}.route-caption{background:#140e0899;border:1px solid #ffcf7a47;border-radius:14px;flex:320px;align-items:center;gap:12px;min-width:0;padding:8px 12px;display:flex}.route-step-index{color:#ffcf7a;background:#ffcf7a29;border-radius:999px;flex:none;padding:3px 10px;font-size:.8rem;font-weight:700}.route-caption strong{color:#ffe6bd;font-size:.92rem;display:block}.route-caption small{color:var(--muted);margin-top:2px;font-size:.8rem;line-height:1.4;display:block}.route-legend{color:#ffcf7a;opacity:.85;margin-top:4px;font-size:.74rem;font-style:normal;display:block}.route-clear{border:1px solid var(--glass-border);color:var(--muted);cursor:pointer;background:0 0;border-radius:50%;flex:none;margin-left:auto;padding:6px;display:inline-flex}.route-clear:hover{color:#ffe6bd;border-color:#ffcf7a66}.route-traveler{z-index:7;pointer-events:none;transition:left 2.1s cubic-bezier(.45,0,.2,1),top 2.1s cubic-bezier(.45,0,.2,1);position:absolute;transform:translate(-50%,-50%)}.route-traveler-img{object-fit:cover;object-position:top center;border:2px solid #ffcf7a;border-radius:50%;width:40px;height:40px;box-shadow:0 0 0 4px #ffa04647,0 0 18px #ffa046d9}.map-pin.is-journey .pin-dot{background:#ffcf7a;border-color:#5a3416;box-shadow:0 0 0 4px #ffcf7a38,0 2px 6px #0009}.map-pin.is-journey .pin-label{opacity:1;transform:translateY(0)}.map-pin.is-journey-current{z-index:6}.map-pin.is-journey-current .pin-dot{background:#ffb54a;width:16px;height:16px;animation:1.2s ease-in-out infinite pinPulse;box-shadow:0 0 0 6px #ffb54a47,0 0 18px #ffb54ae6}.detail-panel,.profile-card,.graph-card,.timeline-detail,.source-card{padding:24px}.detail-panel h3,.profile-card h3,.graph-header h3,.event-card h3{margin:0 0 12px;font-size:1.45rem}.kind-tag{border-radius:var(--radius-pill);vertical-align:middle;color:var(--gold);background:#e6b15c1f;border:1px solid #e6b15c4d;margin-left:10px;padding:3px 10px;font-size:.72rem;font-weight:700}.detail-panel p,.profile-card p,.event-card p{color:var(--muted);line-height:1.75}.atmosphere,.impact{color:#e8c384!important}.asset-prompt-card{background:#08060447;border:1px solid #e6b15c2e;border-radius:18px;margin:20px 0;padding:14px}.asset-prompt-card.compact{margin:0}.asset-prompt-card h4{color:var(--gold);margin:0 0 8px}.asset-prompt-card p{margin:0;font-size:.92rem}.asset-preview{color:#f6ead285;background:linear-gradient(135deg,#c455321f,#0000),repeating-linear-gradient(45deg,#e6b15c14 0 1px,#0000 1px 12px);border:1px dashed #e6b15c59;border-radius:16px;place-items:center;min-height:130px;margin-bottom:14px;display:grid}.portrait-prompt-layout{grid-template-columns:138px minmax(0,1fr);align-items:stretch;gap:14px;margin:16px 0;display:grid}.portrait-preview{min-height:180px;margin:0}.chip-row,.legend-row,.event-actions,.inline-buttons,.filter-row{flex-wrap:wrap;gap:9px;display:flex}.chip-row span,.legend,.event-card span{border:1px solid var(--line);border-radius:var(--radius-pill);color:#e8c384;background:#e6b15c0f;padding:6px 10px;font-size:.88rem}.mini-list{margin-top:22px}.legend{align-items:center;gap:6px;display:inline-flex}.legend:before{content:"";background:var(--ring,var(--gold));border-radius:50%;width:8px;height:8px}.mini-list h4{margin:0 0 12px}.mini-list article{border-top:1px solid #e6b15c29;padding:12px 0}.mini-list small,.profile-meta dd,.profile-meta dt{color:var(--muted);line-height:1.6;display:block}.character-grid{grid-template-columns:1fr}.character-panel{padding:18px}.field-group{gap:8px;display:grid}.field-group label{color:var(--text);font-weight:700}.field-group input{border:1px solid var(--line);width:100%;color:var(--text);background:#0f0b0985;border-radius:14px;padding:13px 14px}.filter-row{margin:14px 0}.filter-row button.is-selected,.character-list button.is-selected,.timeline-rail button.is-selected{border-color:var(--accent-strong);color:#fff7ea;background:#c4553238}.character-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;max-height:440px;padding-right:4px;display:grid;overflow:auto}.character-list button,.timeline-rail button{text-align:left;color:var(--text);background:#0f0b095c;border:1px solid #e6b15c29;border-radius:14px;padding:12px}.character-list span,.timeline-rail span{color:var(--muted);margin-top:5px;font-size:.86rem;line-height:1.45;display:block}.profile-card{margin-top:16px}.role-line{color:#e8c384!important}.profile-meta{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:20px 0 0;display:grid}.profile-meta div{border:1px solid #e6b15c29;border-radius:14px;padding:12px}.graph-card{min-height:720px}.graph-header{justify-content:space-between;align-items:baseline;gap:16px;display:flex}.graph-header p{color:var(--muted)}.relationship-flat{background:radial-gradient(circle,#c4553229,#0000 36%),radial-gradient(circle at 82% 18%,#6f9bd61a,#0000 30%),linear-gradient(160deg,#161009 0%,#0c0907 60%,#110a13 100%);border:1px solid #e6b15c29;border-radius:22px;min-height:470px;margin-top:12px;position:relative;overflow:hidden;box-shadow:inset 0 0 50px #00000080}.relationship-flat:before{content:"";border:1px dashed #e6b15c29;border-radius:50%;position:absolute;inset:13%}.relationship-links{width:100%;height:100%;position:absolute;inset:0}.relationship-edge-tag{z-index:2;border-radius:var(--radius-pill);pointer-events:none;background:#080604d1;border:1px solid #e6b15c33;padding:1px 7px;font-size:.68rem;font-weight:700;position:absolute;transform:translate(-50%,-50%)}.relationship-anchor{z-index:3;position:absolute;transform:translate(-50%,-50%)}.node-core{text-align:center;width:104px;color:var(--text);cursor:pointer;box-shadow:0 12px 26px #0006, inset 0 0 0 1.5px var(--ring,#e6b15c59);animation:5.6s ease-in-out infinite nodeFloat;animation-delay:var(--float-delay,0s);background:#160f0beb;border:0;border-radius:16px;justify-items:center;gap:2px;padding:12px 10px;transition:transform .2s cubic-bezier(.16,1,.3,1),box-shadow .2s;display:grid}.node-core:hover{box-shadow:0 18px 34px #00000080, inset 0 0 0 2px var(--ring,var(--gold));transform:translateY(-3px)scale(1.05)}.node-core strong{font-size:1.04rem}.node-core small{color:var(--muted);font-size:.74rem}.node-core.is-center{color:#fff7ea;background:radial-gradient(circle at 26% 0,#ffe7b22e,#0000 40%),linear-gradient(150deg,#8d3f25f5,#2b1912fa);border-radius:22px;width:150px;padding:18px 14px;animation:none;box-shadow:0 22px 48px #00000073,inset 0 0 0 1.5px #e6b15c80}.node-core.is-center strong{font-size:1.5rem}.node-core.is-center small{color:#fff7eabd}@keyframes nodeFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.relationship-summary{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:16px;display:grid}.relationship-summary article{background:#0806043d;border:1px solid #e6b15c29;border-radius:14px;padding:12px}.relationship-summary strong{color:var(--gold);margin-bottom:5px;display:block}.relationship-summary span{color:var(--muted);font-size:.92rem;line-height:1.55}.timeline-wrap{gap:24px;display:grid}.timeline-track{scroll-snap-type:x proximity;gap:14px;padding:16px;display:flex;overflow-x:auto}.timeline-step{text-align:left;width:190px;color:var(--text);scroll-snap-align:start;background:#0c121a80;border:1px solid #cee2f024;border-radius:16px;flex:none;align-content:start;gap:6px;padding:14px 16px;transition:transform .2s,border-color .2s,background .2s;display:grid;position:relative}.timeline-step:hover{border-color:#e6b15c66;transform:translateY(-2px)}.timeline-step.is-selected{border-color:var(--accent-strong);background:#c4553238;box-shadow:0 12px 28px #0006}.step-index{letter-spacing:.12em;color:var(--gold);font-size:.82rem;font-weight:900}.step-range{color:var(--muted);font-size:.74rem}.step-title{font-size:1rem;line-height:1.35}.timeline-detail{padding:28px clamp(20px,3vw,36px)}.timeline-detail-head{max-width:70ch}.timeline-detail-head h2{margin:6px 0 12px}.timeline-detail-head>p{color:var(--muted);line-height:1.85}.event-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px;margin-top:28px;display:grid}.event-card{border-radius:var(--radius-panel);background:#0c121a66;border:1px solid #cee2f01f;align-content:start;gap:10px;padding:20px;display:grid}.event-range{justify-self:start}.event-card h3{margin:0}.event-actions{margin-top:6px}.source-card{grid-template-columns:minmax(0,.8fr) minmax(220px,.36fr) minmax(0,1fr)}.source-stats{gap:12px;margin:0;display:grid}.source-stats div{border:1px solid #e6b15c29;border-radius:14px;padding:16px}.source-stats dt{color:var(--muted)}.source-stats dd{color:var(--text);margin:6px 0 0;font-size:1.8rem;font-weight:800}.chapter-picks{gap:12px;display:grid}.chapter-picks article{border-left:2px solid var(--accent);padding-left:14px}.chapter-picks span{color:var(--muted);margin-top:6px;display:block}@media (width<=900px){.hero-section,.world-map-layout,.character-grid,.source-card,.event-grid,.character-list,.profile-meta,.relationship-summary{grid-template-columns:1fr}}@media (width<=760px){.site-nav{justify-content:space-between;height:64px;padding:0 16px;overflow:visible}.nav-toggle{display:grid}.nav-links{border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#0a1018f5;flex-direction:column;align-items:stretch;gap:6px;padding:12px 16px 16px;display:none;position:absolute;top:100%;left:0;right:0;box-shadow:0 20px 40px #00000073}.nav-links.is-open{display:flex}.nav-links a{border-color:#cee2f01a;padding:12px 14px;font-size:1rem}}@media (width<=640px){.hero-section{padding:86px 18px 42px}.section-block{padding:64px 18px}.pin-dot{width:11px;height:11px}.pin-label{opacity:1;padding:1px 6px;font-size:.62rem}.graph-card svg{min-height:420px}}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.asset-preview.has-image{background:#0c0907;border:1px solid #e6b15c38;border-radius:16px;min-height:0;padding:0;position:relative;overflow:hidden}.asset-preview.has-image img{aspect-ratio:16/9;object-fit:cover;width:100%;display:block}.asset-caption{border-radius:var(--radius-pill);color:#f7fafa;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0a1624b3;border:1px solid #cee2f042;padding:3px 10px;font-size:.74rem;font-weight:700;position:absolute;bottom:10px;left:10px}.themes-layout{max-width:1180px;margin:0 auto}.themes-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;margin-top:40px;display:grid}.theme-card{border:1px solid var(--glass-border);border-radius:var(--radius-panel);background:var(--panel);-webkit-backdrop-filter:blur(20px)saturate(140%);backdrop-filter:blur(20px)saturate(140%);box-shadow:inset 0 1px 0 var(--glass-highlight), 0 22px 60px #0006;align-content:start;gap:12px;padding:26px 24px;display:grid;position:relative;overflow:hidden}.theme-card:before{content:"";background:linear-gradient(180deg, var(--accent-strong), transparent);width:3px;position:absolute;top:0;bottom:0;left:0}.theme-index{letter-spacing:.2em;color:var(--gold);font-size:.86rem;font-weight:800}.theme-card h3{margin:0;font-size:1.4rem;line-height:1.25}.theme-insight{color:#e8c384;margin:0;font-size:1.02rem;line-height:1.6}.theme-detail{color:var(--muted);margin:0;line-height:1.85}.theme-link{border-radius:var(--radius-pill);color:var(--text);border:1px solid var(--line);background:#f6ead20d;justify-self:start;margin-top:4px;padding:8px 14px;font-size:.84rem;font-weight:700;transition:transform .2s,border-color .2s}.theme-link:hover{border-color:var(--gold);transform:translateY(-1px)}.themes-closing{border-radius:var(--radius-panel);background:radial-gradient(circle at 12% 0,#ff7a451f,#0000 40%),#140e0b80;border:1px solid #e6b15c38;margin-top:36px;padding:30px 32px}.themes-closing p{color:#f0e3cc;max-width:70ch;margin:0;font-size:1.1rem;line-height:2}@media (width<=1024px){.themes-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=680px){.themes-grid{grid-template-columns:1fr}}.detail-panel{grid-template-columns:minmax(0,1.5fr) minmax(260px,1fr);align-items:start;gap:28px;display:grid}.detail-main,.detail-side{min-width:0}.scene-block{margin:14px 0 16px}.asset-image{background:#0c0907;border:1px solid #cee2f02e;border-radius:16px;position:relative;overflow:hidden}.asset-image img{object-fit:cover;width:100%;display:block}.asset-image.scene img{aspect-ratio:16/9}.asset-image.portrait img{aspect-ratio:3/4}.asset-empty{color:#cee2f080;letter-spacing:.06em;background:linear-gradient(135deg,#c4553214,#0000),repeating-linear-gradient(45deg,#cee2f00d 0 1px,#0000 1px 12px);border:1px dashed #cee2f047;border-radius:16px;place-items:center;font-size:.84rem;display:grid}.asset-empty.scene{aspect-ratio:16/9}.asset-empty.portrait{aspect-ratio:3/4}.portrait-layout{grid-template-columns:132px minmax(0,1fr);align-items:start;gap:16px;margin:16px 0;display:grid}.portrait-text{min-width:0}.portrait-text p{margin:0 0 12px}@media (width<=900px){.detail-panel,.portrait-layout{grid-template-columns:1fr}}.graph-modes{border-radius:var(--radius-pill);border:1px solid var(--line);background:#08060466;gap:6px;padding:4px;display:inline-flex}.graph-modes button{border-radius:var(--radius-pill);color:var(--muted);background:0 0;border:0;padding:6px 14px;font-size:.84rem;font-weight:700;transition:color .18s,background .18s}.graph-modes button.is-selected{color:#fff7ea;background:#c4553252}.relationship-network{background:radial-gradient(circle,#c455321f,#0000 40%),linear-gradient(160deg,#161009 0%,#0c0907 60%,#110a13 100%);border:1px solid #e6b15c29;border-radius:22px;min-height:560px;margin-top:12px;position:relative;overflow:hidden}.net-node{z-index:2;color:#b9a98da8;background:0 0;border:0;justify-items:center;gap:3px;padding:0;transition:transform .18s,color .18s;display:grid;position:absolute;transform:translate(-50%,-50%)}.net-node .net-dot{border:2px solid var(--ring,#e6b15c80);background:#1a120d;border-radius:50%;width:11px;height:11px}.net-node .net-name{white-space:nowrap;font-size:.72rem;font-weight:600}.net-node.is-neighbor{color:var(--text)}.net-node:hover{color:#fff7ea;z-index:4;transform:translate(-50%,-50%)scale(1.12)}.net-node.is-selected{z-index:5;color:#fff7ea}.net-node.is-selected .net-dot{background:var(--accent);border-color:var(--gold);width:16px;height:16px;box-shadow:0 0 0 4px #c4553247}.net-node.is-selected .net-name{font-size:.84rem;font-weight:800}.relationship-tree{background:linear-gradient(160deg,#161009 0%,#0c0907 60%,#110a13 100%);border:1px solid #e6b15c29;border-radius:22px;margin-top:12px;padding:28px 20px 24px}.tree-root{justify-content:center;display:flex}.tree-trunk{background:linear-gradient(180deg, var(--gold), transparent);width:2px;height:26px;margin:0 auto}.tree-branches{flex-wrap:wrap;justify-content:center;gap:16px;display:flex}.tree-branch{align-content:start;justify-items:center;gap:10px;min-width:132px;display:grid}.branch-head{border-radius:var(--radius-pill);border:1px solid var(--ring,var(--line));color:var(--text);background:#140e0bcc;align-items:center;gap:8px;padding:8px 14px;font-weight:800;transition:transform .18s,box-shadow .18s;display:inline-flex}.branch-head:hover{transform:translateY(-1px);box-shadow:0 8px 18px #00000059}.branch-dot{background:var(--ring,var(--gold));border-radius:50%;width:9px;height:9px}.branch-count{border-radius:var(--radius-pill);color:var(--gold);background:#e6b15c1f;padding:1px 7px;font-size:.72rem}.branch-caret{color:var(--muted);font-weight:700}.branch-children{border-top:1px dashed #e6b15c4d;gap:8px;width:100%;padding-top:10px;display:grid}.branch-person{text-align:center;color:var(--text);background:#0806044d;border:1px solid #e6b15c2e;border-radius:12px;gap:2px;padding:10px 12px;transition:transform .16s,border-color .16s;display:grid}.branch-person:hover{border-color:var(--gold);transform:translateY(-2px)}.branch-person small{color:var(--muted);font-size:.76rem}@media (width<=640px){.graph-header{flex-direction:column;align-items:flex-start;gap:12px}}.character-groups{gap:14px;max-height:460px;padding-right:4px;display:grid;overflow:auto}.character-group{gap:8px;display:grid}.list-section-head{letter-spacing:.04em;color:var(--muted);border-bottom:1px solid #e6b15c24;align-items:center;gap:8px;margin:0;padding:2px 2px 4px;font-size:.78rem;display:flex}.list-section-head .lsh-title{color:var(--text);font-size:.92rem;font-weight:700}.list-section-head .lsh-count{text-align:center;border-radius:999px;min-width:22px;padding:1px 7px;font-size:.74rem;font-weight:700}.list-section-head.is-main .lsh-title{color:var(--gold)}.list-section-head.is-main .lsh-count{color:var(--gold);background:#e6b15c2e}.list-section-head.is-supporting .lsh-count{color:var(--steel);background:#96b2c429}.list-section-head small{color:var(--muted);opacity:.85;margin-left:auto;font-size:.72rem}.character-list button.is-main{border-left:3px solid #e6b15c8c}.character-list.is-supporting-grid button{opacity:.92;background:#0f0b0938}.character-list button strong{align-items:center;gap:8px;display:flex}.tier-badge{letter-spacing:.04em;border-radius:999px;flex:none;padding:1px 7px;font-size:.66rem;font-weight:700;line-height:1.5}.tier-badge.is-main{color:var(--gold);background:#e6b15c29;border:1px solid #e6b15c66}.tier-badge.is-supporting{color:var(--steel);background:#96b2c424;border:1px solid #96b2c452}.tier-dot{background:var(--steel);vertical-align:middle;border-radius:50%;width:6px;height:6px;margin-left:6px;display:inline-block}.supporting-intro{background:#0c121a66;border:1px dashed #cee2f033;border-radius:16px;margin:16px 0;padding:16px}.supporting-intro p{margin:0 0 12px}.highlights{flex-direction:column;gap:2.6rem;display:flex}.highlights .section-heading code{border:1px solid var(--line);color:var(--gold);background:#e6b15c1f;border-radius:6px;padding:.05rem .4rem;font-size:.85em}.hl-phase{flex-direction:column;gap:1.4rem;padding-top:.4rem;display:flex}.hl-phase-head{border:1px solid var(--glass-border);border-left:3px solid var(--accent-strong);background:linear-gradient(120deg,#c4553224,#121a2466);border-radius:16px;align-items:flex-start;gap:1rem;padding:1rem 1.2rem;display:flex}.hl-phase-faction .hl-phase-head{border-left-color:var(--gold);background:linear-gradient(120deg,#e6b15c1f,#121a2466)}.hl-phase-war .hl-phase-head{background:linear-gradient(120deg,#d05a4f29,#0c101680);border-left-color:#d05a4f}.hl-phase-tag{letter-spacing:.16em;color:var(--gold);border:1px solid var(--line-strong);background:#080c1280;border-radius:999px;flex-shrink:0;margin-top:.2rem;padding:.3rem .6rem;font-size:.74rem}.hl-phase-head h3{color:var(--text);margin:0 0 .3rem;font-size:1.18rem}.hl-phase-head p{color:var(--muted);margin:0;font-size:.92rem;line-height:1.6}.hl-cards{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.4rem;display:grid}.hl-card{border:1px solid var(--glass-border);background:var(--panel);box-shadow:inset 0 1px 0 var(--glass-highlight), 0 14px 30px #00000059;border-radius:18px;flex-direction:column;transition:transform .2s,border-color .2s;display:flex;overflow:hidden}.hl-card:hover{border-color:var(--line-strong);transform:translateY(-4px)}.hl-card-media{aspect-ratio:16/9;background:var(--bg-deep);position:relative}.hl-video,.hl-card-media .hl-video-empty{width:100%;height:100%;position:absolute;inset:0}.hl-video{object-fit:cover;background:#000}.hl-video-empty{color:var(--muted);border-bottom:1px solid var(--glass-border);background:repeating-linear-gradient(45deg,#ffffff05 0 10px,#0000 10px 20px),linear-gradient(160deg,#18222ecc,#0c1016e6);flex-direction:column;justify-content:center;align-items:center;gap:.4rem;display:flex;overflow:hidden}.hl-video-poster{object-fit:cover;filter:brightness(.62)saturate(.9);width:100%;height:100%;position:absolute;inset:0}.hl-video-badge{z-index:1;border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#080c129e;border-radius:12px;flex-direction:column;align-items:center;gap:.35rem;padding:.6rem .9rem;display:flex;position:relative}.hl-video-badge span{letter-spacing:.08em;color:var(--text);font-size:.82rem}.hl-video-empty code{color:var(--gold);opacity:.85;font-size:.72rem}.hl-card-body{flex-direction:column;gap:.6rem;padding:1.1rem 1.2rem 1.3rem;display:flex}.hl-card-top{flex-direction:column;gap:.3rem;display:flex}.hl-chapter{letter-spacing:.1em;color:var(--gold);opacity:.9;font-size:.72rem}.hl-card-body h4{color:var(--text);margin:0;font-size:1.12rem}.hl-hook{color:var(--accent-strong);margin:0;font-size:.96rem;font-weight:600;line-height:1.6}.hl-desc{color:#ddd0bb;margin:0;font-size:.9rem;line-height:1.75}.hl-signif{color:var(--muted);border:1px solid var(--glass-border);background:#080c1273;border-radius:10px;margin:0;padding:.55rem .7rem;font-size:.86rem;line-height:1.7}.hl-signif strong{color:var(--gold);letter-spacing:.06em;margin-right:.5rem;font-size:.78rem;display:inline-block}.hl-meta{flex-wrap:wrap;gap:.45rem;margin-top:.2rem;display:flex}.hl-chip{color:var(--text);border:1px solid var(--glass-border);cursor:pointer;background:#18222e99;border-radius:999px;align-items:center;gap:.3rem;padding:.3rem .65rem;font-size:.78rem;transition:border-color .18s,color .18s;display:inline-flex}.hl-chip:hover{border-color:var(--gold);color:var(--gold)}.hl-chip-loc{color:var(--gold);border-color:var(--line)}@media (width<=640px){.hl-cards{grid-template-columns:1fr}.hl-phase-head{flex-direction:column;gap:.6rem}}
