:root{--bg-sky-top: #d89a5a;--bg-sky-bot: #e8c79a;--ink: #2a1f15;--ink-soft: #5c4a38;--muted: #8c7a64;--paper: #f5ecd8;--paper-soft: #ebe0c6;--line: #c9b896;--line-soft: #ddd0b0;--vermilion: #b8442e;--vermilion-d: #8e2f1f;--accent: #6b4226}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%;overflow:hidden;font-family:Noto Sans SC,-apple-system,sans-serif;color:var(--ink);user-select:none;-webkit-user-select:none}body{background:linear-gradient(to bottom,#d89a5a,#e8c79a 55%,#c9a878)}#app{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1}canvas{display:block;cursor:grab}canvas.dragging{cursor:grabbing}.brand{position:fixed;top:22px;left:28px;z-index:10;pointer-events:none}.brand .title{font-family:"Noto Serif SC",serif;font-weight:600;font-size:22px;color:var(--ink);letter-spacing:.05em}.brand .sub{font-family:"Noto Serif SC",serif;font-size:12px;color:var(--ink-soft);margin-top:4px;letter-spacing:.15em;font-weight:400}.top-right{position:fixed;top:22px;right:28px;z-index:10;display:flex;gap:8px}.btn{background:var(--paper);border:1px solid var(--line);padding:8px 14px;border-radius:4px;font-family:"Noto Serif SC",serif;font-size:13px;color:var(--ink);cursor:pointer;transition:background .15s}.btn:hover{background:var(--paper-soft)}.btn.active,.btn.primary{background:var(--vermilion);color:var(--paper);border-color:var(--vermilion-d)}.btn.primary:hover{background:var(--vermilion-d)}.panel{position:fixed;left:28px;top:90px;bottom:120px;width:240px;background:var(--paper);border:1px solid var(--line);border-radius:4px;padding:18px 18px 14px;z-index:9;overflow-y:auto;box-shadow:0 8px 24px -8px #3c280a2e}.panel h3{font-family:"Noto Serif SC",serif;font-weight:600;font-size:14px;margin:0 0 14px;padding-bottom:8px;border-bottom:1px solid var(--line-soft);color:var(--ink);letter-spacing:.08em}.field{margin-bottom:16px}.field-label{font-family:"Noto Serif SC",serif;font-size:12px;color:var(--ink-soft);margin-bottom:6px;display:flex;justify-content:space-between;align-items:baseline}.field-label .val{font-weight:500;color:var(--vermilion)}.options{display:flex;gap:4px;flex-wrap:wrap}.opt{flex:1;min-width:0;padding:6px 4px;background:transparent;border:1px solid var(--line-soft);border-radius:3px;font-family:"Noto Serif SC",serif;font-size:12px;color:var(--ink-soft);cursor:pointer;transition:all .12s;text-align:center;white-space:nowrap}.opt:hover{background:var(--paper-soft);color:var(--ink)}.opt.active{background:var(--vermilion);color:var(--paper);border-color:var(--vermilion-d)}.evaluation{position:fixed;bottom:28px;left:28px;width:240px;background:var(--paper);border:1px solid var(--line);border-radius:4px;padding:12px 16px;z-index:9;box-shadow:0 8px 24px -8px #3c280a2e}.evaluation .label{font-family:"Noto Serif SC",serif;font-size:11px;color:var(--muted);letter-spacing:.15em;margin-bottom:6px}.evaluation .rank{font-family:"Noto Serif SC",serif;font-size:15px;font-weight:600;color:var(--vermilion);margin-bottom:4px}.evaluation .note{font-size:11px;color:var(--ink-soft);line-height:1.6}.decompose{position:fixed;right:28px;top:90px;bottom:28px;width:220px;background:var(--paper);border:1px solid var(--line);border-radius:4px;padding:18px 16px;z-index:9;overflow-y:auto;box-shadow:0 8px 24px -8px #3c280a2e;display:flex;flex-direction:column}.decompose h3{font-family:"Noto Serif SC",serif;font-weight:600;font-size:14px;margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--line-soft);letter-spacing:.08em}.layer-list{flex:1}.layer{padding:10px 12px;margin-bottom:4px;border-radius:3px;cursor:pointer;font-family:"Noto Serif SC",serif;font-size:13px;color:var(--ink);transition:all .15s;border-left:3px solid transparent;position:relative}.layer:hover{background:var(--paper-soft);border-left-color:var(--line)}.layer.active{background:var(--paper-soft);border-left-color:var(--vermilion);color:var(--vermilion);font-weight:500}.layer .zh{font-size:13px;letter-spacing:.05em}.layer .desc{font-size:10px;color:var(--muted);margin-top:2px;letter-spacing:.05em}.decompose-actions{padding-top:12px;border-top:1px solid var(--line-soft);display:flex;gap:6px}.decompose-actions .btn{flex:1;padding:7px 8px;font-size:12px;text-align:center}.knowledge-card{position:fixed;left:50%;bottom:-300px;transform:translate(-50%);width:min(560px,calc(100vw - 540px));background:var(--paper);border:1px solid var(--line);border-radius:4px;padding:20px 24px;z-index:11;box-shadow:0 20px 50px -10px #3c280a4d;transition:bottom .4s cubic-bezier(.4,0,.2,1)}.knowledge-card.show{bottom:28px}.knowledge-card .close{position:absolute;top:12px;right:14px;background:none;border:none;cursor:pointer;font-size:18px;color:var(--muted);line-height:1;padding:4px}.knowledge-card .close:hover{color:var(--ink)}.kc-title{font-family:"Noto Serif SC",serif;font-size:18px;font-weight:600;color:var(--ink);margin-bottom:4px;letter-spacing:.08em}.kc-sub{font-family:"Noto Serif SC",serif;font-size:11px;color:var(--muted);margin-bottom:14px;letter-spacing:.2em}.kc-body{font-size:13px;line-height:1.85;color:var(--ink-soft)}.kc-body strong{color:var(--vermilion);font-weight:600}.kc-evolution{margin-top:14px;padding-top:12px;border-top:1px dashed var(--line-soft);font-size:12px;color:var(--muted);line-height:1.8}.kc-evolution span{color:var(--ink-soft)}.narration{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);z-index:20;background:#f5ecd8f5;border:1px solid var(--line);border-radius:4px;padding:32px 40px;max-width:480px;text-align:center;box-shadow:0 30px 80px -20px #3c280a66;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.narration.hidden{display:none}.narration .date{font-family:"Noto Serif SC",serif;font-size:12px;color:var(--muted);letter-spacing:.3em;margin-bottom:16px}.narration .text{font-family:"Noto Serif SC",serif;font-size:15px;line-height:2;color:var(--ink);margin-bottom:24px;letter-spacing:.05em}.narration .text em{color:var(--vermilion);font-style:normal;font-weight:500}.scroll-hint{position:fixed;bottom:28px;left:50%;transform:translate(-50%);font-family:"Noto Serif SC",serif;font-size:11px;color:var(--ink-soft);letter-spacing:.2em;z-index:8;pointer-events:none;text-align:center;opacity:.7}.scroll-hint kbd{font-family:inherit;display:inline-block;padding:1px 5px;background:var(--paper);border:1px solid var(--line);border-radius:2px;font-size:10px;margin:0 2px}.panel::-webkit-scrollbar,.decompose::-webkit-scrollbar{width:6px}.panel::-webkit-scrollbar-thumb,.decompose::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}@media(max-width:900px){.panel,.decompose,.evaluation,.scroll-hint{display:none}}
