html,body,#root{height:100%;margin:0}:root{--paper-50:#faf3df;--paper-100:#f4ead5;--paper-200:#ecdfbe;--paper-300:#dcc89a;--paper-400:#b89866;--ink-900:#1a1109;--ink-700:#3a2a18;--ink-500:#6a543a;--ink-300:#9d8665;--ink-100:#c7b48f;--verm-900:#5a1407;--verm-700:#8a2614;--verm-500:#b53a26;--verm-300:#d97a66;--verm-50:#fbe8e1;--gold-700:#7a5208;--gold-500:#a8740a;--gold-300:#d4a85a;--shi-qing-deep:#2e5d7e;--shi-qing:#3a6890;--shi-lv:#4a8c5a;--shi-lv-light:#5fa572;--zhe-shi:#b87333;--bai-fen:#f4ecd6;--tai-dian:#1f3a4a;--paper:var(--paper-100);--paper-deep:var(--paper-200);--paper-edge:var(--paper-300);--ink:var(--ink-900);--ink-soft:var(--ink-700);--ink-light:var(--ink-500);--gold:var(--gold-500);--vermilion:var(--verm-500);--vermilion-deep:var(--verm-700);--jade:var(--shi-lv);--water:var(--shi-qing);--scroll-wood:#5a3a1a;--font-display:"Noto Serif SC", "Source Han Serif SC", "Songti SC", serif;--font-text:"Source Han Serif SC", "Songti SC", "Noto Serif SC", Georgia, serif;--font-mono:"JetBrains Mono", "SF Mono", ui-monospace, "Courier New", monospace;--shadow-paper:0 1px 0 #fff8e899 inset, 0 2px 6px #3c1e000f;--shadow-card:0 2px 4px #3c1e000d, 0 12px 32px -8px #3c1e002e;--shadow-card-hover:0 4px 8px #3c1e0014, 0 20px 48px -12px #3c1e0047;--shadow-seal:0 1px 2px #5a140a66, 0 0 0 1px #fff8e880 inset;--shadow-panel:-1px 0 0 var(--gold-500), -2px 0 0 #faf3df66, -24px 0 48px -12px #3c1e0038, -8px 0 16px -4px #3c1e001f, inset 1px 0 0 #fff8e899;--ease-expo:cubic-bezier(.22, 1, .36, 1);--ease-power:cubic-bezier(.83, 0, .17, 1);--ease-back:cubic-bezier(.34, 1.56, .64, 1);--ease-smooth:cubic-bezier(.4, 0, .2, 1);--dur-fast:.22s;--dur-base:.42s;--dur-slow:.7s}@media (prefers-reduced-motion:reduce){*{transition-duration:.01ms!important;animation-duration:.01ms!important}}.scroll-curtain{z-index:9999;pointer-events:none;position:fixed;inset:0}.scroll-curtain:before,.scroll-curtain:after{content:"";transition:clip-path 1.1s var(--ease-power) .15s;background:linear-gradient(#2a1a0a,#4a2e10,#2a1a0a);position:absolute;left:0;right:0}.scroll-curtain:before{clip-path:inset(0);height:50%;top:0}.scroll-curtain:after{clip-path:inset(0);height:50%;bottom:0}.scroll-curtain.open:before{clip-path:inset(0 0 100%)}.scroll-curtain.open:after{clip-path:inset(100% 0 0)}.scroll-rod{transform-origin:50%;width:100vw;height:6px;transition:transform .9s var(--ease-power), opacity .5s ease .9s;background:linear-gradient(#3a2a1a 0%,#7a5436 50%,#3a2a1a 100%);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scaleX(0);box-shadow:0 0 20px #78501e99,0 2px 4px #0006}.scroll-curtain.open .scroll-rod{opacity:0;transform:translate(-50%,-50%)scaleX(1)}@keyframes trajectory-draw{0%{stroke-dashoffset:1000px}to{stroke-dashoffset:0}}@keyframes trajectory-ping{0%{r:9;opacity:.9}to{r:28;opacity:0}}.trajectory-node{filter:drop-shadow(0 2px 6px #78140a80)}.trajectory-ping{animation:trajectory-ping 1.6s var(--ease-expo) infinite}.rebellion-banner{z-index:50;color:#ffd0c0;font-family:var(--font-display);letter-spacing:.4em;border:1px solid var(--verm-700);opacity:0;pointer-events:none;transition:all .7s var(--ease-expo);background:linear-gradient(#3a0a05,#1a0303);padding:8px 24px;font-size:14px;position:fixed;top:92px;left:50%;transform:translate(-50%)translateY(-12px);box-shadow:0 4px 16px #781e0a66,inset 0 0 0 1px #ffc8b433}.rebellion-banner.show{opacity:1;letter-spacing:.12em;transform:translate(-50%)translateY(0)}.rebellion-ripple{pointer-events:none}.rebellion-ripple circle{animation:ripple 1.6s var(--ease-expo) infinite}.rebellion-ripple circle:nth-child(2){animation-delay:.4s}.rebellion-ripple circle:nth-child(3){animation-delay:.8s}@keyframes ripple{0%{r:4;opacity:.8}to{r:120;opacity:0}}.map-root.is-rebellion .place-label,.map-root.is-rebellion .ruler-poet-name{filter:saturate(.7)}.map-canvas{transition:filter .7s var(--ease-smooth)}.map-canvas.is-rebellion{filter:saturate(.55)brightness(.78)}.flying-crane{animation:crane-fly 2.4s var(--ease-power) forwards;transform-origin:0 0}@keyframes crane-fly{0%{opacity:0;transform:translate(0)scale(1)rotate(-8deg)}15%{opacity:1;transform:translate(20px,-10px)scale(1.1)rotate(-12deg)}to{opacity:0;transform:translate(400px,-260px)scale(.6)rotate(-4deg)}}.brand-tools{align-items:center;gap:8px;display:flex}.tool-btn{font-family:var(--font-text);background:linear-gradient(180deg, var(--paper-50), var(--paper-200));border:1px solid var(--paper-400);color:var(--ink-700);cursor:pointer;letter-spacing:1px;transition:all var(--dur-fast) var(--ease-smooth);box-shadow:var(--shadow-paper);border-radius:2px;padding:5px 12px;font-size:12px;position:relative}.tool-btn:hover{transform:translateY(-1px);box-shadow:0 4px 8px #3c1e001a}.tool-btn .badge{background:var(--verm-500);color:#fff;font-family:var(--font-mono);border-radius:100px;padding:1px 5px;font-size:10px;font-weight:600;position:absolute;top:-6px;right:-6px}.theme-switcher{border:1px solid var(--paper-300);background:#faf3df99;border-radius:100px;gap:0;padding:2px;display:inline-flex}.theme-pill{color:var(--ink-500);font-family:var(--font-text);letter-spacing:1.5px;cursor:pointer;transition:all var(--dur-fast) var(--ease-smooth);background:0 0;border:none;border-radius:100px;padding:4px 11px;font-size:11px}.theme-pill:hover{color:var(--ink-900)}.theme-pill.active{background:linear-gradient(180deg, var(--ink-700), var(--ink-900));color:var(--paper-50);box-shadow:0 1px 2px #0000004d}.poster-modal{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;animation:fade-in .3s var(--ease-smooth);background:#140e08b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.poster-card{background:var(--paper-50);border:2px solid var(--gold-500);text-align:center;border-radius:4px;width:90%;max-width:480px;padding:40px 48px;position:relative;box-shadow:0 24px 64px #0006}.poster-card h2{font-family:var(--font-display);color:var(--verm-700);letter-spacing:.4em;margin:0 0 8px;font-size:26px}.poster-card .poster-meta{color:var(--ink-500);letter-spacing:3px;margin-bottom:24px;font-size:12px}.poster-stats{grid-template-columns:repeat(3,1fr);gap:16px;margin:24px 0;display:grid}.poster-stat{border:1px solid var(--paper-300);background:linear-gradient(#fff8e8cc,#f4ead566);border-radius:2px;padding:16px 8px}.poster-stat-num{font-family:var(--font-mono);color:var(--verm-700);font-size:32px;font-weight:700;display:block}.poster-stat-label{color:var(--ink-500);letter-spacing:2px;font-size:11px}.poster-seal{background:var(--verm-500);color:#fff8e8;width:50px;height:50px;font-family:var(--font-display);box-shadow:var(--shadow-seal);opacity:.92;border-radius:4px;flex-direction:column;justify-content:center;align-items:center;font-size:14px;display:flex;position:absolute;bottom:24px;right:24px;transform:rotate(8deg)}.poster-close{color:var(--ink-500);cursor:pointer;background:0 0;border:none;font-size:24px;position:absolute;top:12px;right:16px}*{box-sizing:border-box}body,html,#root{height:100%;font-family:var(--font-text);background:var(--paper-100);color:var(--ink-900);font-feature-settings:"palt" 1, "kern" 1;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;margin:0;padding:0;overflow:hidden}.app{background:radial-gradient(circle at 8% 22%,#78501e0f 0,#0000 3px),radial-gradient(circle at 32% 78%,#78501e0d 0,#0000 4px),radial-gradient(circle at 67% 41%,#78501e0d 0,#0000 3px),radial-gradient(circle at 88% 86%,#78501e0f 0,#0000 4px),radial-gradient(circle at 12% 55%,#78501e0a 0,#0000 5px),radial-gradient(80% 60% at 50% 30%,#f4ead5 0%,#e8d8a8 60%,#d8c188 100%);grid-template-rows:auto auto 1fr;width:100vw;height:100vh;display:grid;position:relative;overflow:hidden}.app:before{content:"";background:repeating-linear-gradient(90deg, #6a4a1a80 0px, #6a4a1a80 12px, #4a2a0a80 12px, #4a2a0a80 24px), linear-gradient(to bottom, var(--scroll-wood) 0%, #3a2a0a 100%);z-index:100;pointer-events:none;border-bottom:1px solid #2a1a05;height:14px;position:absolute;top:0;left:0;right:0;box-shadow:0 1px 3px #0000004d}.app:after{content:"";background:repeating-linear-gradient(90deg, #6a4a1a80 0px, #6a4a1a80 12px, #4a2a0a80 12px, #4a2a0a80 24px), linear-gradient(to top, var(--scroll-wood) 0%, #3a2a0a 100%);z-index:100;pointer-events:none;border-top:1px solid #2a1a05;height:14px;position:absolute;bottom:0;left:0;right:0;box-shadow:0 -1px 3px #0000004d}.app-brand{color:var(--ink-900);z-index:10;background:0 0;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:20px;padding:26px 40px 12px;display:flex;position:relative}.brand-left{flex-shrink:0}.brand-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.streak-pill{background:linear-gradient(180deg, var(--paper-50), var(--paper-200));border:1px solid var(--gold-500);cursor:pointer;font-family:var(--font-text);color:var(--ink-900);box-shadow:var(--shadow-paper);transition:all var(--dur-fast) var(--ease-smooth);border-radius:100px;align-items:center;gap:6px;padding:5px 12px 5px 10px;font-size:12px;display:inline-flex}.streak-pill:hover{transform:translateY(-1px);box-shadow:0 4px 8px #3c1e001f}.streak-pill.checked{border-color:var(--gold-700);background:linear-gradient(#ffe9b0,#f5cf6a)}.streak-flame{font-size:14px;line-height:1}.streak-count{font-family:var(--font-mono);color:var(--verm-700);font-variant-numeric:tabular-nums lining-nums;font-size:14px;font-weight:700}.streak-label{color:var(--ink-700);letter-spacing:1px;font-size:11px}.app-brand h1{font-family:var(--font-display);letter-spacing:.42em;background:linear-gradient(180deg, var(--verm-700) 0%, var(--verm-900) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0;font-size:32px;font-weight:600;line-height:1}.app-brand p{color:var(--ink-500);letter-spacing:3px;font-size:11px;font-style:italic;font-family:var(--font-text);margin:6px 0 0}.grade-filter{flex-wrap:wrap;gap:4px;display:flex}.grade-btn{border:1px solid var(--paper-300);color:var(--ink-700);font-family:var(--font-text);cursor:pointer;transition:all var(--dur-fast) var(--ease-smooth);letter-spacing:2px;box-shadow:var(--shadow-paper);background:#faf3df99;border-radius:2px;padding:5px 12px;font-size:12px}.grade-btn:hover{color:var(--ink-900);background:#fff8e8e6;transform:translateY(-1px);box-shadow:0 4px 8px #3c1e0014}.grade-btn.active{background:linear-gradient(180deg, var(--verm-500), var(--verm-700));color:var(--paper-50);border-color:var(--verm-900);box-shadow:var(--shadow-seal);text-shadow:0 1px #5a140a99}.top-timeline{z-index:10;background:0 0;flex-direction:column;min-height:160px;max-height:28vh;padding:0 32px 6px;display:flex;position:relative}.period-strip{border-bottom:2px solid var(--ink-soft);height:22px;margin-bottom:0;position:relative}.period-segment{color:#fff8e8;letter-spacing:6px;text-shadow:0 1px #0000004d;justify-content:center;align-items:center;height:22px;font-size:13px;font-weight:700;display:flex;position:absolute;top:0}.poet-ruler{flex:1;min-height:60px;position:relative}.ruler-baseline{background:var(--ink-soft);height:2px;position:absolute;bottom:16px;left:0;right:0}.ruler-event-line{background:var(--ink-light);opacity:.5;width:1px;height:calc(100% - 4px);position:absolute;bottom:0;transform:translate(-50%)}.ruler-event-line.major{background:var(--vermilion);opacity:.6;width:2px}.ruler-poet{cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;padding:0;transition:filter .15s,transform .15s;display:flex;position:absolute;transform:translate(-50%)}.ruler-poet:hover{z-index:5;filter:brightness(1.15)}.ruler-poet.active{z-index:6}.ruler-poet.gone{opacity:.35}.ruler-poet-bar{background:var(--vermilion);border-radius:1px 1px 0 0;width:3px;height:100%;display:block}.ruler-poet.gone .ruler-poet-bar{background:var(--ink-light)}.ruler-poet.active .ruler-poet-bar{background:var(--vermilion-deep);width:4px;box-shadow:0 0 0 1px var(--gold)}.ruler-poet-label{white-space:nowrap;pointer-events:none;align-items:baseline;gap:3px;font-family:Songti SC,serif;display:flex;position:absolute;bottom:-16px}.ruler-poet-name{color:var(--ink);letter-spacing:.5px;font-size:11px;font-weight:700}.ruler-poet-year{color:var(--ink-light);font-size:8px}.ruler-poet.gone .ruler-poet-name{color:var(--ink-light)}.ruler-poet.active .ruler-poet-name{color:var(--vermilion)}.ruler-events{height:20px;position:absolute;bottom:-34px;left:0;right:0}.ruler-event{white-space:nowrap;pointer-events:none;flex-direction:column;align-items:center;font-size:9px;display:flex;position:absolute;bottom:0;transform:translate(-50%)}.ruler-event-year{color:var(--ink-soft);font-size:9px}.ruler-event-title{color:var(--ink-soft)}.ruler-event.major .ruler-event-title{color:var(--vermilion);font-weight:700}.year-control{border-top:1px dashed var(--paper-edge);align-items:center;gap:12px;margin-top:38px;padding-top:4px;display:flex}.year-slider{accent-color:var(--vermilion);flex:1}.year-readout{color:var(--vermilion);letter-spacing:4px;text-align:right;min-width:100px;font-size:13px;font-weight:700}.main-row{z-index:10;grid-template-columns:280px 1fr;height:100%;min-height:0;display:grid;position:relative;overflow:hidden}.poem-toc{border-right:1px solid var(--paper-edge);min-height:0;color:var(--ink);background:0 0;flex-direction:column;display:flex;position:relative}.poem-toc:after{content:"";background:linear-gradient(to bottom, transparent, var(--paper-edge) 20%, var(--paper-edge) 80%, transparent);width:1px;position:absolute;top:0;bottom:0;right:0}.toc-header{border-bottom:2px solid var(--ink-soft);flex-shrink:0;padding:14px 18px 8px}.toc-header h2{letter-spacing:6px;color:var(--vermilion);margin:0;font-size:18px;font-weight:700}.toc-header p{letter-spacing:2px;color:var(--ink-soft);margin:4px 0 0;font-size:10px;font-style:italic}.toc-scroll{flex:1;min-height:0;padding:4px 0 20px;overflow-y:auto}.toc-scroll::-webkit-scrollbar{width:6px}.toc-scroll::-webkit-scrollbar-thumb{background:var(--paper-edge)}.toc-scroll::-webkit-scrollbar-track{background:0 0}.grade-section{margin-bottom:4px}.grade-label{color:var(--ink);letter-spacing:3px;border-bottom:1px dashed var(--paper-edge);align-items:baseline;gap:8px;margin:0;padding:8px 18px 4px;font-size:13px;font-weight:700;display:flex}.grade-num{background:linear-gradient(180deg, var(--verm-500), var(--verm-700));color:var(--paper-50);font-family:var(--font-mono);letter-spacing:0;box-shadow:var(--shadow-seal);text-shadow:0 1px #5a140a99;font-variant-numeric:tabular-nums lining-nums;border-radius:2px;padding:2px 6px;font-size:11px;font-weight:600}.grade-count{color:var(--ink-light);letter-spacing:0;margin-left:auto;font-size:10px;font-weight:400}.poem-toc-list{margin:0;padding:0;list-style:none}.toc-item{cursor:pointer;color:var(--ink);border-left:2px solid #0000;font-size:11px;transition:background .15s,border-color .15s}.toc-row{grid-template-columns:22px 1fr auto;align-items:baseline;gap:6px;padding:3px 18px;display:grid}.toc-item:hover .toc-row{background:#a8740a1a}.toc-item.active{border-left-color:var(--vermilion)}.toc-item.active .toc-row{background:#b53a2626}.toc-item.open .toc-row{background:#a8740a14;font-weight:600}.toc-body{border-left:2px solid var(--gold);background:#f4ead580;margin-left:18px;padding:4px 18px 8px 26px}.toc-poem-text{white-space:pre-wrap;color:var(--ink);margin:0;font-family:Songti SC,serif;font-size:12px;line-height:1.8}.toc-poem-trans{color:var(--ink-soft);margin:4px 0 0;font-size:10px;font-style:italic;line-height:1.5}.toc-num{color:var(--vermilion);text-align:right;font-size:9px;font-weight:700}.toc-title{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;letter-spacing:.5px;overflow:hidden}.toc-author{color:var(--ink-soft);font-size:10px}.toc-icon{color:var(--gold-500);margin-left:6px;font-size:10px;display:inline-block}.toc-item.learned .toc-num{background:linear-gradient(180deg, var(--shi-lv), var(--shi-lv-light))}.toc-item.review .toc-num{background:linear-gradient(180deg, var(--gold-500), var(--gold-700));animation:review-pulse 2s var(--ease-smooth) infinite}@keyframes review-pulse{0%,to{box-shadow:var(--shadow-seal)}50%{box-shadow:0 0 0 4px #a8740a33, var(--shadow-seal)}}.map-wrap{background-color:var(--paper-200);min-width:0;min-height:0;position:relative;overflow:hidden}.map-wrap:after{content:"";background-image:linear-gradient(90deg, #f4ead5 0%, #f4ead5d9 4%, #f4ead500 12%, #f4ead500 88%, #f4ead5d9 96%, #f4ead5 100%), radial-gradient(ellipse 90% 70% at 50% 50%, transparent 60%, #00000038 100%), var(--painting-url,url(/assets/qianli-jiangshan.jpg));background-size:100% 100%,cover,cover;background-position:center, center, var(--painting-pos,38% center);z-index:0;pointer-events:none;filter:saturate(.95)brightness(.92)contrast(1.08);transition:filter .5s var(--ease-smooth);background-repeat:no-repeat,no-repeat,no-repeat;position:absolute;inset:0}.map-wrap:before{content:"";z-index:1;pointer-events:none;border-left:1px solid var(--gold-500);border-right:1px solid var(--gold-500);box-shadow:inset 4px 0 0 var(--paper-50), inset -4px 0 0 var(--paper-50), inset 5px 0 0 var(--gold-700), inset -5px 0 0 var(--gold-700);opacity:.55;position:absolute;inset:0 12px}.map-canvas{z-index:3;z-index:2;shape-rendering:geometricprecision;text-rendering:optimizelegibility;width:100%;height:100%;display:block;position:relative}.place{cursor:pointer;filter:drop-shadow(0 2px 6px #0006)}.place:hover{filter:drop-shadow(0 4px 12px #0009)brightness(1.1)}.place.active circle{stroke:var(--gold);stroke-width:3px}.place .halo{animation:3s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:.25}50%{opacity:.5}}.place-label{pointer-events:none;font-family:var(--font-display);paint-order:stroke;stroke:#fff8e8f2;stroke-width:3.5px;stroke-linejoin:round;font-weight:600}.poem-panel{-webkit-backdrop-filter:blur(20px)saturate(1.2);width:420px;color:var(--ink-900);box-shadow:var(--shadow-panel);z-index:20;opacity:0;background:linear-gradient(#faf3dff5 0%,#f4ead5f0 100%);border-left:none;border-radius:4px 0 0 4px;padding:28px 32px;display:none;position:absolute;top:12px;bottom:12px;right:0;overflow-y:auto;transform:translate(20px)}.poem-panel.open{animation:panel-slide-in .42s var(--ease-expo) forwards;display:block}@keyframes panel-slide-in{0%{opacity:0;filter:blur(8px);transform:translate(20px)}to{opacity:1;filter:blur();transform:translate(0)}}.poem-panel::-webkit-scrollbar{width:6px}.poem-panel::-webkit-scrollbar-thumb{background:var(--paper-edge)}.panel-close{cursor:pointer;color:var(--ink-soft);z-index:11;background:0 0;border:none;font-size:28px;line-height:1;position:absolute;top:10px;right:14px}.panel-header h2{color:var(--vermilion);letter-spacing:2px;margin:0;font-size:24px;font-weight:700}.panel-header .style-name{color:var(--ink-soft);font-size:14px;font-weight:400}.modern-name{color:var(--ink-soft);margin:4px 0;font-size:12px}.poem-count{color:var(--gold);border-bottom:1px solid var(--paper-edge);letter-spacing:2px;margin:8px 0 12px;padding-bottom:8px;font-size:11px}.aggregate-hint{color:var(--vermilion);letter-spacing:2px;margin:4px 0 0;font-size:11px;font-style:italic}.poem-card{border-bottom:1px dashed var(--paper-edge);padding:12px 0}.poem-head{align-items:baseline;gap:8px;display:flex}.poem-num{background:linear-gradient(180deg, var(--verm-500), var(--verm-700));color:var(--paper-50);font-family:var(--font-mono);text-align:center;font-variant-numeric:tabular-nums lining-nums;min-width:26px;box-shadow:var(--shadow-seal);text-shadow:0 1px #5a140a99;letter-spacing:0;border-radius:2px;padding:2px 6px;font-size:11px;font-weight:600}.poem-head h3{color:var(--ink);letter-spacing:1px;flex:1;margin:0;font-size:16px}.poem-author{color:var(--ink-soft);font-size:11px}.poem-body{font-family:var(--font-text);letter-spacing:.08em;white-space:pre-wrap;color:var(--ink-900);margin:12px 0;font-size:17px;line-height:2.05}.poem-meta,.poem-context{color:var(--ink-light);margin:3px 0 0;font-size:10px;font-style:italic}.empty{color:var(--ink-soft);text-align:center;padding:24px;font-size:14px}.poet-group{border-left:3px double var(--gold);margin:14px 0;padding:8px 0 8px 14px}.poet-group-head{border-bottom:1px dashed var(--paper-edge);align-items:baseline;gap:10px;margin-bottom:6px;padding-bottom:4px;display:flex}.poet-group-name{color:var(--vermilion);letter-spacing:2px;font-size:17px;font-weight:700}.poet-group-meta{color:var(--ink-soft);font-size:10px}.poem-card.sub{padding:10px 0 6px}.immersive-overlay{z-index:2000;background:radial-gradient(ellipse at center, #140c068c 0%, #0a0603eb 80%), var(--painting-url,url(/assets/qianli-jiangshan.jpg));background-size:cover,cover;background-position:center, var(--painting-pos,38% center);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:imm-fade-in .4s var(--ease-expo);cursor:zoom-out;justify-content:center;align-items:center;padding:40px;display:flex;position:fixed;inset:0}@keyframes imm-fade-in{0%{opacity:0}to{opacity:1}}.immersive-paper{border:1px solid var(--gold-500);width:100%;max-width:720px;max-height:90vh;box-shadow:0 0 0 1px var(--gold-700), 0 0 0 8px #7a520826, 0 32px 64px #0009;font-family:var(--font-text);cursor:default;animation:imm-paper-in .6s var(--ease-expo);background:linear-gradient(#faf3dffa 0%,#f4ead5f5 100%);padding:56px 64px 64px;position:relative;overflow-y:auto}@keyframes imm-paper-in{0%{opacity:0;transform:translateY(20px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.immersive-close{border:1px solid var(--ink-300);color:var(--ink-700);cursor:pointer;width:32px;height:32px;transition:all var(--dur-fast) var(--ease-smooth);background:0 0;border-radius:100px;font-size:14px;position:absolute;top:16px;right:16px}.immersive-close:hover{background:var(--verm-500);color:var(--paper-50);border-color:var(--verm-700);transform:rotate(90deg)}.immersive-seal{background:linear-gradient(180deg, var(--verm-500), var(--verm-700));width:44px;height:44px;color:var(--paper-50);font-family:var(--font-mono);box-shadow:var(--shadow-seal);border-radius:2px;justify-content:center;align-items:center;font-size:18px;font-weight:700;display:flex;position:absolute;top:56px;left:64px}.immersive-head{text-align:center;border-bottom:1px solid var(--paper-300);margin:24px 0 32px;padding-bottom:20px}.immersive-title{font-family:var(--font-display);color:var(--ink-900);letter-spacing:.16em;background:linear-gradient(180deg, var(--ink-900) 0%, var(--verm-700) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 12px;font-size:42px;font-weight:600}.immersive-meta{color:var(--ink-500);letter-spacing:2px;margin:0;font-size:13px;font-style:italic}.immersive-tabs{justify-content:center;gap:4px;margin-bottom:28px;display:flex}.immersive-tab{border:1px solid var(--paper-300);color:var(--ink-500);font-family:var(--font-text);letter-spacing:3px;cursor:pointer;transition:all var(--dur-fast) var(--ease-smooth);background:0 0;border-radius:1px;padding:6px 18px;font-size:13px}.immersive-tab:hover{color:var(--ink-900);background:#a8740a14}.immersive-tab.active{background:linear-gradient(180deg, var(--verm-500), var(--verm-700));color:var(--paper-50);border-color:var(--verm-900);box-shadow:var(--shadow-seal)}.immersive-body{font-family:var(--font-text);letter-spacing:.18em;text-align:center;white-space:pre-wrap;color:var(--ink-900);margin:0 0 28px;font-size:24px;line-height:2.2}.immersive-body.mode-pinyin{letter-spacing:.05em;color:var(--ink-700);font-size:18px;font-style:italic}.immersive-body.mode-translation{letter-spacing:.08em;text-align:left;color:var(--ink-700);font-size:17px;line-height:2}.immersive-notes{border-left:3px solid var(--gold-500);background:#a8740a0f;margin:24px 0 16px;padding:16px 20px}.immersive-notes h3{color:var(--verm-700);letter-spacing:4px;margin:0 0 8px;font-size:12px;font-weight:700}.immersive-notes dl{grid-template-columns:auto 1fr;gap:6px 14px;margin:0;font-size:13px;display:grid}.immersive-notes dt{color:var(--verm-700);font-weight:600}.immersive-notes dd{color:var(--ink-700);margin:0}.immersive-context{border-top:1px dashed var(--paper-300);color:var(--ink-500);align-items:baseline;gap:12px;padding-top:16px;font-size:12px;font-style:italic;display:flex}.immersive-context .ctx-label{color:var(--verm-700);letter-spacing:2px;font-style:normal;font-weight:700}.immersive-audio{width:100%;height:36px;margin:16px 0 0}.immersive-hint{color:var(--ink-300);letter-spacing:1px;font-size:10px;position:absolute;bottom:12px;right:16px}.immersive-hint kbd{background:var(--paper-200);border:1px solid var(--ink-300);font-family:var(--font-mono);border-radius:2px;padding:1px 4px;font-size:9px}.toc-immersive-btn{border:1px solid var(--gold-500);color:var(--gold-700);font-family:var(--font-text);letter-spacing:2px;cursor:pointer;transition:all var(--dur-fast) var(--ease-smooth);background:0 0;border-radius:1px;margin-top:8px;padding:4px 10px;font-size:11px}.toc-immersive-btn:hover{background:var(--gold-500);color:var(--paper-50)}.immersive-share-btn{border:1px solid var(--gold-500);color:var(--gold-700);height:32px;font-family:var(--font-text);letter-spacing:2px;cursor:pointer;transition:all var(--dur-fast) var(--ease-smooth);background:0 0;border-radius:100px;padding:0 12px;font-size:12px;position:absolute;top:16px;right:60px}.immersive-share-btn:hover{background:var(--gold-500);color:var(--paper-50)}.recite-panel{border:1px dashed var(--gold-500);background:#a8740a0d;margin:16px 0;padding:20px 22px}.recite-target{border-left:3px solid var(--ink-700);background:#fff8e899;margin-bottom:16px;padding:12px}.recite-label{color:var(--verm-700);letter-spacing:2px;margin-right:8px;font-size:11px;font-weight:700}.recite-text{font-family:var(--font-text);color:var(--ink-900);letter-spacing:.1em;font-size:15px;line-height:1.8}.recite-controls{text-align:center;margin:16px 0}.recite-btn{font-family:var(--font-text);letter-spacing:2px;cursor:pointer;transition:all var(--dur-fast) var(--ease-smooth);border:none;border-radius:100px;padding:10px 28px;font-size:15px;font-weight:700}.recite-btn.start{background:linear-gradient(180deg, var(--verm-500), var(--verm-700));color:var(--paper-50);box-shadow:0 4px 12px #b53a2666}.recite-btn.start:hover{transform:translateY(-1px);box-shadow:0 6px 16px #b53a2680}.recite-btn.stop{background:var(--ink-700);color:var(--paper-50);animation:1.5s ease-in-out infinite recite-pulse}@keyframes recite-pulse{0%,to{box-shadow:0 0 #b53a2666}50%{box-shadow:0 0 0 8px #b53a2600}}.recite-error{color:var(--verm-700);border-left:3px solid var(--verm-500);background:#b53a261a;margin-top:8px;padding:8px 12px;font-size:12px}.recite-result{border-left:3px solid var(--gold-500);background:#fff8e899;margin-top:12px;padding:12px}.recite-heard{font-family:var(--font-text);color:var(--ink-700);margin-top:4px;font-size:14px;line-height:1.8}.recite-score{text-align:center;border-radius:4px;flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;margin-top:16px;padding:18px 20px;display:flex}.recite-score.score-gold{border:1px solid var(--gold-500);background:linear-gradient(#fff3cc,#ffe9a0)}.recite-score.score-silver{border:1px solid var(--paper-400);background:linear-gradient(#fff8e8e6,#e8d8a899)}.recite-score.score-bronze{border:1px solid var(--verm-300);background:linear-gradient(#b53a2614,#b53a2629)}.score-num{font-family:var(--font-mono);color:var(--verm-700);font-size:36px;font-weight:700}.score-label{color:var(--ink-700);font-size:14px}.score-msg{width:100%;color:var(--ink-700);letter-spacing:2px;margin-top:4px;font-size:12px}.share-overlay{z-index:3000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:imm-fade-in .3s var(--ease-expo);background:#0a0603e0;justify-content:center;align-items:center;padding:40px;display:flex;position:fixed;inset:0}.share-wrap{flex-direction:column;align-items:center;gap:16px;display:flex;position:relative}.share-close{background:var(--paper-50);border:1px solid var(--ink-300);width:36px;height:36px;color:var(--ink-700);cursor:pointer;z-index:10;transition:all var(--dur-fast) var(--ease-smooth);border-radius:100px;font-size:16px;position:absolute;top:-12px;right:-12px}.share-close:hover{background:var(--verm-500);color:var(--paper-50);transform:rotate(90deg)}.share-card{background:radial-gradient(circle at 30% 20%, #b873330a 0%, transparent 60%), linear-gradient(180deg, var(--paper-50) 0%, var(--paper-200) 100%);width:360px;box-shadow:0 0 0 1px var(--gold-500), 0 0 0 6px #7a52081a, 0 24px 60px #00000080;text-align:center;padding:48px 36px 40px;position:relative}.share-card:before,.share-card:after{content:"";background:repeating-linear-gradient(90deg, var(--scroll-wood) 0px, var(--scroll-wood) 8px, #3a2a0a 8px, #3a2a0a 16px);height:8px;position:absolute;left:12px;right:12px}.share-card:before{top:-2px}.share-card:after{bottom:-2px}.share-seal-top{background:linear-gradient(180deg, var(--verm-500), var(--verm-700));color:var(--paper-50);font-family:var(--font-display);letter-spacing:2px;box-shadow:var(--shadow-seal);padding:4px 8px;font-size:9px;position:absolute;top:16px;right:16px}.share-num{background:linear-gradient(180deg, var(--verm-500), var(--verm-700));width:32px;height:32px;color:var(--paper-50);font-family:var(--font-mono);box-shadow:var(--shadow-seal);justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex;position:absolute;top:24px;left:24px}.share-title{font-family:var(--font-display);letter-spacing:.18em;background:linear-gradient(180deg, var(--ink-900), var(--verm-700));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:16px 0 8px;font-size:28px}.share-author{color:var(--ink-500);letter-spacing:2px;margin:0 0 24px;font-size:12px;font-style:italic}.share-period{color:var(--gold-700);font-style:normal}.share-body{font-family:var(--font-text);letter-spacing:.16em;color:var(--ink-900);white-space:pre-wrap;margin:0 0 24px;font-size:18px;line-height:2.1}.share-meta{color:var(--ink-500);letter-spacing:1px;margin:0 0 8px;font-size:11px}.share-context{color:var(--ink-300);margin:8px 0 0;font-size:10px;font-style:italic}.share-foot{border-top:1px dashed var(--paper-300);color:var(--ink-500);letter-spacing:1px;justify-content:space-between;margin-top:28px;padding-top:16px;font-size:9px;display:flex}.share-brand{color:var(--verm-700);font-weight:700}.share-actions{flex-direction:column;align-items:center;gap:4px;display:flex}.share-btn-row{gap:8px;display:flex}.share-action-btn{background:var(--gold-500);color:var(--paper-50);border:1px solid var(--gold-500);font-family:var(--font-text);letter-spacing:1px;cursor:pointer;transition:all var(--dur-fast) var(--ease-smooth);border-radius:100px;padding:8px 16px;font-size:12px}.share-action-btn:hover{background:var(--gold-700);border-color:var(--gold-700)}.share-action-btn.secondary{color:var(--gold-500);background:0 0}.share-action-btn.secondary:hover{background:var(--gold-500);color:var(--paper-50)}.share-tip{color:var(--paper-300);letter-spacing:1px;font-size:10px}@media (width<=768px){.app{grid-template-rows:auto auto auto 1fr;overflow-y:auto}.app-brand{gap:8px;padding:16px 16px 6px}.app-brand h1{letter-spacing:.3em;font-size:22px}.app-brand p{letter-spacing:1px;font-size:10px}.brand-actions{flex-direction:column;align-items:flex-start;gap:8px;width:100%}.brand-tools{flex-wrap:wrap}.grade-filter{flex-wrap:nowrap;width:100%;padding-bottom:2px;overflow-x:auto}.grade-btn{flex-shrink:0;padding:3px 8px;font-size:10px}.theme-switcher{justify-content:center;width:100%}.top-timeline{min-height:80px;max-height:100px;padding:4px 12px}.poet-ruler{display:none}.ruler-events{justify-content:space-between;margin-top:4px;display:flex;position:static}.main-row{grid-template-columns:1fr;height:auto;min-height:60vh}.poem-toc{z-index:50;background:var(--paper-50);border-right:1px solid var(--paper-300);width:80vw;max-width:320px;transition:transform .3s var(--ease-smooth);position:fixed;top:0;bottom:0;left:0;transform:translate(-100%);box-shadow:4px 0 24px #0000004d}.poem-toc.mobile-open{transform:translate(0)}.map-wrap{min-height:50vh}.poem-panel{border-left:none;border-radius:12px 12px 0 0;width:100%;height:70vh;padding:16px 20px;inset:auto 0 0}.poem-panel.open{animation:panel-slide-up .42s var(--ease-expo) forwards}@keyframes panel-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.panel-header h2{font-size:20px}.poem-body{font-size:15px}.rebellion-banner{padding:6px 14px;font-size:11px;top:70px}}@media (width<=480px){.app-brand h1{letter-spacing:.2em;font-size:18px}.grade-btn{padding:2px 6px;font-size:9px}.theme-pill{padding:3px 8px;font-size:10px}}.poem-tabs{border-bottom:1px solid var(--paper-edge);gap:0;margin:8px 0;display:flex}.poem-tab{cursor:pointer;font-family:var(--font-text);color:var(--ink-500);letter-spacing:4px;transition:all var(--dur-fast) var(--ease-smooth);background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:8px 12px;font-size:13px;position:relative}.poem-tab:hover{color:var(--ink-900);background:#a8740a0f}.poem-tab.active{color:var(--verm-700);font-weight:600}.poem-tab.active:after{content:"";background:linear-gradient(90deg, var(--verm-700), var(--verm-500), var(--verm-700));border-radius:2px;width:24px;height:3px;position:absolute;bottom:-2px;left:50%;transform:translate(-50%);box-shadow:0 1px 2px #b53a2666}.poem-body.pinyin{color:var(--ink-soft);letter-spacing:.5px;font-family:Songti SC,serif;font-size:13px;line-height:1.9}.poem-body.translation{color:var(--ink);font-family:Songti SC,serif;font-size:13px;font-style:normal;line-height:1.9}.poem-notes{margin:6px 0 0;padding:0;list-style:none}.poem-notes li{border-bottom:1px dashed var(--paper-edge);grid-template-columns:60px 1fr;gap:8px;padding:4px 0;font-size:12px;line-height:1.6;display:grid}.poem-notes li strong{color:var(--vermilion);font-weight:700}.poem-notes li span{color:var(--ink)}.poem-audio{width:100%;height:32px;margin:8px 0 0}.poem-foot{border-top:1px dotted var(--paper-edge);flex-direction:column;gap:2px;margin-top:6px;padding-top:4px;display:flex}.poem-year{color:var(--ink-light);font-size:10px;font-style:italic}.poem-context{color:var(--ink-soft);font-size:11px}
