@font-face{font-family:CatWarm;src:local("LXGW WenKai"),local("PingFang SC"),local("Microsoft YaHei")}:root{color:#5a4632;background:#9ed7f3;font-family:CatWarm,system-ui,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0;overflow:hidden}button,input{font:inherit}button{border:0;cursor:pointer}.world-canvas{position:fixed;inset:0;width:100vw;height:100vh}.ending-credits{position:fixed;inset:0;z-index:200;width:100vw;height:100vh;overflow:hidden;background:#000}.ending-credits-canvas{display:block;width:100vw;height:100vh}.ending-credits-video{display:none}.main-menu{position:fixed;inset:0;overflow:hidden;background:#fff7e8;cursor:pointer;-webkit-user-select:none;user-select:none;z-index:30}.menu-comic-stage{position:absolute;inset:0;background:#fff7e8;transition:filter .26s ease,transform .52s cubic-bezier(.22,1,.36,1)}.menu-comic-board{position:absolute;top:50%;left:50%;width:max(100vw,calc(100vh * 1672 / 941));height:max(100vh,calc(100vw * 941 / 1672));transform:translate(-50%,-50%)}.main-menu.title-ready{animation:menu-impact-shake .54s linear both}.main-menu.title-ready .menu-comic-stage{filter:brightness(.74) saturate(.95);transform:scale(1.018)}.menu-comic-panel{--from-x: 0;--from-y: 0;--from-r: 0deg;--x: 0%;--y: 0%;--w: 100%;--h: 100%;position:absolute;left:var(--x);top:var(--y);width:var(--w);height:var(--h);object-fit:fill;object-position:center;opacity:0;pointer-events:none;will-change:transform,opacity;filter:drop-shadow(0 12px 0 rgba(0,0,0,.18)) drop-shadow(0 22px 24px rgba(0,0,0,.18));animation:menu-panel-fly-in .78s cubic-bezier(.18,1.1,.28,1) forwards}.menu-comic-panel.panel-a{--x: .8%;--y: 0%;--w: 50.8%;--h: 40%;--from-x: -112vw;--from-y: -24vh;--from-r: -7deg;z-index:7;animation-delay:.12s}.menu-comic-panel.panel-b{--x: 49%;--y: 1.3%;--w: 49.8%;--h: 35.6%;--from-x: 112vw;--from-y: -22vh;--from-r: 8deg;z-index:3;animation-delay:.7s}.menu-comic-panel.panel-c{--x: .6%;--y: 32.8%;--w: 48.3%;--h: 35.8%;--from-x: 0;--from-y: -108vh;--from-r: 3deg;z-index:4;animation-delay:1.28s}.menu-comic-panel.panel-d{--x: 47%;--y: 32%;--w: 51.8%;--h: 35.8%;--from-x: 118vw;--from-y: 6vh;--from-r: -4deg;z-index:5;animation-delay:1.86s}.menu-comic-panel.panel-e{--x: .8%;--y: 62.7%;--w: 98.6%;--h: 38.7%;--from-x: -110vw;--from-y: 30vh;--from-r: 6deg;z-index:6;animation-delay:2.44s}.menu-title-stage{position:absolute;inset:0;display:grid;place-items:center;transform:translateY(-9vh);pointer-events:none}.menu-title-logo{width:min(78vw,960px);max-height:48vh;object-fit:contain;filter:drop-shadow(0 12px 0 rgba(0,0,0,.28)) drop-shadow(0 22px 24px rgba(0,0,0,.28));animation:menu-title-slam .62s cubic-bezier(.15,1.12,.22,1) both}.menu-title-stage p{position:absolute;top:calc(50% + min(22vw,230px));margin:0;padding:10px 22px 12px;border:4px solid #1f1710;border-radius:999px;background:#fff8e8;color:#1f1710;font-size:clamp(22px,3.2vw,38px);font-weight:900;letter-spacing:0;box-shadow:0 0 0 5px #fff,0 10px #0003;animation:menu-start-hint-pop .36s .56s cubic-bezier(.18,1.4,.24,1) both,menu-start-hint-bounce 1.7s .98s ease-in-out infinite}.puzzle-card button,.letter-book button,.item-detail button{min-height:44px;padding:0 20px;border-radius:8px;background:#a6c36f;color:#fff;box-shadow:0 8px 20px #52712c38}@keyframes menu-panel-fly-in{0%{opacity:0;transform:translate3d(var(--from-x),var(--from-y),0) rotate(var(--from-r)) scale(.94)}76%{opacity:1;transform:translate3d(calc(var(--from-x) * -.025),calc(var(--from-y) * -.025),0) rotate(0) scale(1.018)}to{opacity:1;transform:translateZ(0) rotate(0) scale(1)}}@keyframes menu-title-slam{0%{opacity:0;transform:translate3d(0,-118vh,0) rotate(-8deg) scale(1.25)}68%{opacity:1;transform:translate3d(0,3.8vh,0) rotate(1.5deg) scale(.92)}82%{transform:translate3d(0,-1.3vh,0) rotate(-.7deg) scale(1.07)}to{opacity:1;transform:translateZ(0) rotate(0) scale(1)}}@keyframes menu-start-hint-pop{0%{opacity:0;transform:translateY(18px) scale(.72)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes menu-start-hint-bounce{0%,to{opacity:.72;transform:translateY(0) scale(1)}46%{opacity:1;transform:translateY(-8px) scale(1.045)}62%{transform:translateY(-4px) scale(1.02)}}@keyframes menu-impact-shake{0%,to{transform:translateZ(0) rotate(0)}10%{transform:translate3d(-12px,8px,0) rotate(-.4deg)}22%{transform:translate3d(14px,-9px,0) rotate(.45deg)}34%{transform:translate3d(-10px,-6px,0) rotate(-.28deg)}48%{transform:translate3d(8px,5px,0) rotate(.2deg)}64%{transform:translate3d(-4px,3px,0) rotate(-.12deg)}80%{transform:translate3d(2px,-2px,0) rotate(.06deg)}}.gift-progress{position:fixed;right:108px;bottom:82px;width:132px;padding:8px 10px;border-radius:8px;background:#fff6e4f0;color:#5a4632;border:1.5px solid #e8b98a;text-align:left;z-index:10}.gift-progress div,.mini-progress{height:6px;margin-top:6px;border-radius:10px;background:#ead8b8;overflow:hidden}.gift-progress i,.mini-progress i{display:block;height:100%;background:#e89b7a}.time-slider{position:fixed;bottom:28px;right:108px;display:flex;align-items:center;gap:6px;width:min(300px,calc(100vw - 300px));padding:7px 8px;border:1.5px solid #d7c5a0;border-radius:8px;background:#fff6e4f0;z-index:10}.letter-ready{position:fixed;right:22px;top:82px;min-height:40px;padding:0 16px;border-radius:8px;background:#e89b7a;color:#fff6e4;border:1.5px solid #fff1d4;box-shadow:0 10px 24px #b4644e38;z-index:10}.time-slider button,.bag-button{width:34px;height:34px;border-radius:999px;background:#fff6e4;border:1.5px solid #d7c5a0}.time-slider input{flex:1}.interaction-hint{position:fixed;left:50%;bottom:31vh;transform:translate(-50%);max-width:min(640px,calc(100vw - 32px));padding:12px 20px;border-radius:999px;background:#5a4632c7;color:#fff6e4;z-index:10}.control-guide{position:fixed;right:108px;bottom:128px;max-width:min(300px,calc(100vw - 340px));padding:6px 10px;border-radius:8px;background:#fff6e4bd;border:1px solid rgba(215,197,160,.78);color:#6f5842;font-size:12px;line-height:1.35;z-index:10;pointer-events:none}.equipped{position:fixed;left:24px;bottom:28px;display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:8px;background:#fff6e4f2;border:1.5px solid #d7c5a0;z-index:10}.equipped img{width:34px;height:34px;object-fit:contain}.equipped small{color:#7b6650}.compass-button{position:fixed;left:24px;bottom:92px;z-index:12;display:grid;place-items:center;width:54px;height:54px;padding:0;border-radius:999px;background:#fff6e4eb;border:1.5px solid #d7c5a0;box-shadow:0 10px 24px #5a463229}.compass-face{position:relative;display:block;width:40px;height:40px;border-radius:999px;background:radial-gradient(circle,#fff9ec 0 42%,#f5dcae 43% 61%,#b98a58 62% 66%,#fff6e4 67%);box-shadow:inset 0 0 0 2px #7b665038}.compass-face:before,.compass-face:after{content:"";position:absolute;left:50%;top:50%;width:3px;height:32px;border-radius:999px;background:#5a46325c;transform:translate(-50%,-50%)}.compass-face:after{width:32px;height:3px}.compass-face i{position:absolute;left:50%;top:50%;width:8px;height:30px;transform:translate(-50%,-55%) rotate(28deg);transform-origin:50% 58%}.compass-face i:before,.compass-face i:after{content:"";position:absolute;left:0;width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent}.compass-face i:before{top:0;border-bottom:17px solid #e89b7a}.compass-face i:after{bottom:0;border-top:15px solid #8fc6e8}.bag-button{position:fixed;right:28px;bottom:28px;width:64px;height:64px;font-size:30px;z-index:12;box-shadow:0 10px 24px #5a46322e}.restart-button{position:fixed;right:30px;bottom:108px;z-index:10;min-height:24px;padding:2px 8px;border-radius:8px;background:#fff6e46b;border:1px solid rgba(123,102,80,.22);color:#5a463280;font-size:12px;box-shadow:none}.restart-button:hover{background:#fff6e4c7;color:#6f5842}.cheat-button{position:fixed;left:10px;bottom:10px;z-index:13;width:24px;height:24px;min-height:0;padding:0;border-radius:999px;background:#fff6e414;border:1px solid rgba(90,70,50,.12);color:#5a46322e;font-size:11px;line-height:1;box-shadow:none}.cheat-button:hover{background:#fff6e47a;border-color:#5a463257;color:#5a4632b8}.scene-map-overlay{position:fixed;inset:0;z-index:46;display:grid;place-items:center;padding:18px;overflow:auto;background:#261e187a;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.scene-map-paper{position:relative;width:min(940px,calc(100vw - 28px));min-height:min(720px,calc(100vh - 36px));padding:54px 58px 48px;border-radius:8px;background:radial-gradient(circle at 20% 18%,rgba(255,246,228,.72),transparent 0 22%),linear-gradient(90deg,rgba(155,112,62,.12),transparent 17%,transparent 83%,rgba(155,112,62,.12)),#f4dfad;box-shadow:0 24px 64px #251c1452;color:#5a4632}.scene-map-paper header{display:flex;align-items:baseline;justify-content:space-between;gap:20px;margin-bottom:16px}.scene-map-paper header span{color:#9b7040;font-size:15px}.scene-map-paper h2{margin:0;font-size:clamp(28px,4vw,44px)}.scene-map-close{position:absolute;right:28px;top:24px;width:42px;height:42px;padding:0;border-radius:999px;background:#fff6e4bd;border:1.5px solid rgba(123,102,80,.22);color:#5a4632;font-size:30px;line-height:1}.scene-map-board{position:relative;width:100%;aspect-ratio:1 / .72;overflow:hidden;border-radius:8px;border:1.5px solid rgba(123,102,80,.18);background:#fff6e447}.scene-map-board.world img{display:block;width:100%;height:100%;object-fit:cover}.map-marker{position:absolute;display:flex;align-items:center;gap:4px;padding:3px 7px 3px 5px;border-radius:999px;transform:translate(-50%,-50%);color:#4f3d2b;font-size:clamp(11px,1.15vw,14px);line-height:1;white-space:nowrap;background:#fff6e4b8;filter:drop-shadow(0 2px 3px rgba(90,70,50,.18))}.map-marker b{display:block;width:9px;height:9px;border-radius:999px;background:#a6c36f;box-shadow:0 0 0 2px #fff6e4cc}.map-marker.npc{color:#6a3c2b;background:#ffdfd3d1}.map-marker.npc b{width:12px;height:12px;background:#e89b7a}.scene-map-board.diagram{display:grid;place-items:center;background:radial-gradient(circle at 50% 48%,#fff6e4a8,#fff6e43d),#fff6e45c}.scene-map-board.diagram svg{width:100%;height:100%}.map-room,.map-zone{fill:#fff6e4b8;stroke:#9b7040;stroke-width:4}.map-zone{fill:#e8b98a38;stroke-width:3}.map-zone.highlight{fill:#ffd76057}.map-zone.rug{fill:#f5b7c85c}.map-door{fill:none;stroke:#77b9d8;stroke-width:9;stroke-linecap:round}.scene-map-board text{fill:#5a4632;font-size:25px;font-weight:800;text-anchor:middle;dominant-baseline:middle}.scene-map-board.dark{background:#050713}.map-glass{fill:#ffffff2e;stroke:#ffffffb8;stroke-width:4}.map-ring{fill:none;stroke:#ffffff6b;stroke-width:3}.map-slot{fill:#fff6e4d1;stroke:#ffd760;stroke-width:4}.map-screen{fill:#8fc6e857;stroke:#ffffffb8;stroke-width:4}.map-envelope{fill:#fff1c8d6;stroke:#e8b98a;stroke-width:4}.scene-map-board.dark text{fill:#fff6e4}.reward-meteor{position:fixed;left:0;top:0;width:48px;height:48px;display:grid;place-items:center;border-radius:999px;color:#fff8c8;font-size:38px;line-height:1;text-shadow:0 0 8px #fff6a8,0 0 18px #ffd760,0 0 34px #f2a84f,0 0 58px rgba(255,188,65,.72);background:radial-gradient(circle,#ffffdcfa 0 16%,#ffd760db 36%,#ffd76000 72%);pointer-events:none;z-index:75;will-change:transform,opacity}.reward-meteor:before{content:"";position:absolute;right:32px;top:50%;width:156px;height:22px;border-radius:999px;transform:translateY(-50%);background:radial-gradient(circle at 12% 50%,rgba(255,247,180,.88) 0 3px,transparent 5px),radial-gradient(circle at 31% 47%,rgba(255,215,96,.78) 0 4px,transparent 7px),radial-gradient(circle at 52% 52%,rgba(255,246,200,.72) 0 3px,transparent 6px),linear-gradient(90deg,#ffd76000,#ffc23e6b,#fffacff0);filter:drop-shadow(0 0 12px rgba(255,215,96,.92));opacity:.96;transform-origin:right center}.reward-meteor span{position:absolute;left:50%;top:50%;width:5px;height:5px;border-radius:999px;background:#fff6a8;box-shadow:0 0 10px #ffd760,0 0 18px #ffbf48db;transform:rotate(var(--spark-angle)) translate(24px);animation:reward-meteor-twinkle .72s ease-in-out var(--spark-delay) infinite alternate}.reward-trail-spark{position:fixed;left:0;top:0;width:9px;height:9px;border-radius:999px;background:radial-gradient(circle,#fff9c8 0 24%,#ffd760 42%,#ffd76000 74%);filter:drop-shadow(0 0 8px rgba(255,215,96,.92));pointer-events:none;z-index:74;transform:translate3d(calc(var(--spark-x) - 4px),calc(var(--spark-y) - 4px),0) scale(var(--spark-scale));animation:reward-trail-fade .76s ease-out forwards}.reward-burst{position:fixed;left:0;top:0;width:1px;height:1px;pointer-events:none;z-index:76;transform:translate3d(var(--burst-x),var(--burst-y),0) scale(var(--burst-scale))}.reward-burst span{position:absolute;left:-4px;top:-4px;width:8px;height:8px;border-radius:999px;background:radial-gradient(circle,#fffde0 0 28%,#ffd760 54%,#ffd76000 76%);box-shadow:0 0 10px #ffd760e6;transform:rotate(var(--burst-angle)) translate(0);animation:reward-burst-pop .82s ease-out forwards}@keyframes reward-meteor-twinkle{0%{opacity:.24;transform:rotate(var(--spark-angle)) translate(16px) scale(.55)}to{opacity:1;transform:rotate(var(--spark-angle)) translate(34px) scale(1.28)}}@keyframes reward-trail-fade{0%{opacity:1}to{opacity:0;transform:translate3d(calc(var(--spark-x) - 4px),calc(var(--spark-y) - 4px),0) scale(.18)}}@keyframes reward-burst-pop{0%{opacity:0;transform:rotate(var(--burst-angle)) translate(0) scale(.35)}18%{opacity:1}to{opacity:0;transform:rotate(var(--burst-angle)) translate(var(--burst-distance)) scale(1.25)}}.toast-stack{position:fixed;right:24px;top:92px;display:grid;gap:8px;z-index:50}.toast{width:280px;padding:12px 14px;border-radius:8px;background:#fff6e4;border:1.5px solid #e8b98a;box-shadow:0 8px 24px #b482502e}.fade-overlay{position:fixed;inset:0;z-index:80;display:grid;place-content:center;gap:14px;text-align:center;color:#5a4632;background:linear-gradient(#fff6e4f0,#ffeecff5),repeating-linear-gradient(45deg,rgba(232,185,138,.12) 0 2px,transparent 2px 16px);opacity:0;pointer-events:none;transition:opacity .3s ease}.fade-overlay.is-visible{opacity:1;pointer-events:auto}.fade-overlay strong{font-size:24px;letter-spacing:0}.fade-overlay span{color:#7b6650}.fade-paw{width:72px;height:72px;margin:0 auto;display:grid;place-items:center;border-radius:999px;background:#fff6e4;border:2px solid #e8b98a;color:transparent;position:relative;animation:fade-paw-spin .9s linear infinite}.fade-paw:before{content:"";width:22px;height:18px;border-radius:50% 50% 45% 45%;background:#e89b7a;box-shadow:-18px -16px 0 -4px #e89b7a,-6px -22px 0 -5px #e89b7a,8px -22px 0 -5px #e89b7a,20px -14px 0 -5px #e89b7a}@keyframes fade-paw-spin{to{transform:rotate(360deg)}}.dialogue-layer{position:fixed;inset:0;z-index:20;pointer-events:none}.npc-portrait{position:absolute;left:18vw;bottom:calc(22vh + 20px);width:min(290px,24vw);height:42vh;min-height:300px;transform:translate(-50%);border-radius:8px;opacity:.96;pointer-events:none;filter:drop-shadow(0 18px 20px rgba(90,70,50,.22));animation:portrait-in .28s ease-out}.npc-portrait.speaking{animation:portrait-in .28s ease-out,speaking .6s infinite ease-in-out}.npc-portrait img{width:100%;height:100%;object-fit:contain;object-position:bottom center}.portrait-head{display:grid;place-items:center;height:72%;font-size:82px;color:#fff}.portrait-name{text-align:center;color:#fff;font-size:24px;font-weight:800}.speech-bubble{position:absolute;left:18vw;bottom:5vh;width:60vw;height:22vh;min-height:170px;padding:40px 34px 28px;border-radius:32px;background:#fff6e4f5;border:1.5px solid #e8b98a;box-shadow:0 8px 24px #b482502e;pointer-events:auto;animation:bubble-in .2s ease-out}.speaker-tag{position:absolute;top:-16px;left:24px;padding:8px 18px;border-radius:999px;background:#e89b7a;color:#fff;font-size:18px;font-weight:800}.speech-bubble p{margin:0;font-size:24px;line-height:1.7}.next-indicator{position:absolute;right:28px;bottom:18px;color:#e89b7a;animation:blink 1.2s infinite}.choice-panel{position:absolute;left:70vw;top:32vh;display:grid;gap:12px;pointer-events:auto}.choice-panel button{display:grid;grid-template-columns:30px 1fr 28px;align-items:center;width:20vw;min-width:230px;height:56px;padding:0 18px;border-radius:28px;background:#fff6e4;color:#5a4632;border:1.5px solid #d7c5a0;text-align:left;transition:transform .16s ease,background .16s ease}.choice-panel button:hover{transform:scale(1.03);background:#a6c36f;color:#fff}.scholar-gift-panel{position:absolute;left:70vw;top:28vh;width:360px;padding:16px;border:1.5px solid rgba(215,197,160,.88);border-radius:8px;background:#fff6e4f5;box-shadow:0 14px 34px #5a46322e;pointer-events:auto}.scholar-gift-title{margin-bottom:12px;color:#5a4632;font-size:18px;font-weight:800}.scholar-gift-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.scholar-gift-grid button{min-height:94px;padding:8px;border:1.5px solid #d7c5a0;border-radius:8px;background:#ffffff7a;color:#5a4632}.scholar-gift-grid button:not(:disabled):hover{border-color:#a6c36f;background:#f1f7df}.scholar-gift-grid button:disabled{opacity:.42}.scholar-gift-grid img{width:38px;height:38px;object-fit:contain}.scholar-gift-grid strong,.scholar-gift-grid span,.scholar-gift-grid em{display:block;font-style:normal;font-size:13px}.scholar-gift-close{margin-top:12px;width:100%;height:38px;border:1.5px solid #d7c5a0;border-radius:999px;background:#fff6e4;color:#5a4632}.key-hints{position:fixed;left:50%;bottom:1.5vh;transform:translate(-50%);display:flex;gap:14px;color:#7b6650;font-size:14px}.key-hints b{display:inline-grid;place-items:center;width:24px;height:24px;border-radius:999px;background:#a6c36f;color:#fff}.startup-error{position:fixed;left:50%;top:50%;z-index:60;display:grid;gap:8px;width:min(520px,calc(100vw - 32px));padding:18px 20px;transform:translate(-50%,-50%);border:1.5px solid #e89b7a;border-radius:8px;background:#fff6e4fa;color:#5a4632;box-shadow:0 16px 42px #5a463238;pointer-events:auto}.startup-error strong{font-size:20px}.startup-error span{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;line-height:1.5}.note-overlay,.puzzle-overlay,.letter-overlay{position:fixed;inset:0;display:grid;place-items:center;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:40}.parchment{position:relative;width:min(650px,calc(100vw - 120px));min-height:440px;padding:52px 64px;border-radius:8px;background:linear-gradient(90deg,rgba(155,112,62,.08),transparent 18%,transparent 82%,rgba(155,112,62,.08)),#f7e5bc;box-shadow:0 22px 60px #00000047}.parchment h2{margin:0 0 26px;font-size:34px}.parchment p{white-space:pre-line;font-size:26px;line-height:1.9}.parchment footer{position:absolute;left:42px;bottom:28px;padding:0;background:transparent;color:#9b7040;text-shadow:0 1px 0 rgba(255,246,228,.65)}.dry-flower{position:absolute;width:28px;height:28px;border-radius:50%;background:#f0b5c5}.dry-flower.tl{left:24px;top:24px}.dry-flower.tr{right:24px;top:24px;background:#efcf72}.dry-flower.br{right:30px;bottom:26px;background:#91bb6d}.note-side{position:fixed;right:calc(50vw - 475px);top:24vh;display:grid;gap:12px;width:180px;padding:0;background:transparent;color:#fff6e4;text-shadow:0 2px 8px rgba(0,0,0,.45)}.note-side button{min-height:40px;background:transparent;color:#fff6e4;text-align:left;text-shadow:0 2px 8px rgba(0,0,0,.45)}.close-button{min-height:40px;border-radius:8px;background:#e89b7a;color:#fff}.note-keys{position:fixed;bottom:6vh;color:#fff6e4}.drawer-scrim{position:fixed;inset:0;background:transparent;z-index:24}.inventory-drawer{position:fixed;top:0;right:0;width:min(35vw,560px);min-width:420px;height:100vh;display:grid;grid-template-rows:auto auto 1fr 240px;transform:translate(100%);transition:transform .28s cubic-bezier(.22,1,.36,1);background:#fff9ebfa;border-left:1.5px solid #d7c5a0;box-shadow:-18px 0 36px #5a46322e;z-index:25}.inventory-drawer.open{transform:translate(0)}.inventory-tabs{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;padding:18px}.inventory-tabs button{height:48px;border-radius:8px;background:#fff6e4;border:1.5px solid #d7c5a0;color:#5a4632}.inventory-tabs button.active{background:#a6c36f;color:#fff;transform:translateY(4px)}.inventory-summary{padding:0 22px 16px}.inventory-grid{display:grid;grid-template-columns:repeat(4,96px);align-content:start;gap:12px;padding:0 22px 22px;overflow:auto}.item-slot{position:relative;width:96px;height:96px;display:grid;place-items:center;border-radius:8px;background:#fff6e4;border:1.5px solid #d7c5a0;color:#5a4632}.item-slot span{display:grid;place-items:center;width:54px;height:54px;font-size:32px}.item-slot span img{width:100%;height:100%;object-fit:contain}.item-slot small{position:absolute;bottom:7px;width:90%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.item-slot em{position:absolute;right:8px;bottom:24px;font-style:normal;font-weight:800}.item-slot i,.item-slot b{position:absolute;top:8px;right:8px;width:12px;height:12px;border-radius:999px}.item-slot i{background:#e95a5a}.item-slot b{background:#a6c36f}.item-slot.locked{filter:grayscale(1);opacity:.55}.equipped-slot{border-color:#a6c36f}.item-detail{padding:18px 22px 26px;border-top:1.5px solid #d7c5a0;background:#fff6e4;overflow:auto}.item-detail blockquote{margin:12px 0 0;padding-left:12px;border-left:3px solid #e89b7a;color:#7b6650}.item-detail strong{display:flex;align-items:center;gap:10px}.item-detail strong img{width:42px;height:42px;object-fit:contain}.jiojio-letter-overlay,.treasure-map-overlay{position:fixed;inset:0;z-index:45;display:grid;place-items:center;padding:18px;overflow:auto;background:#261e1880;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.jiojio-letter-paper,.treasure-map-paper{position:relative;width:min(620px,calc(100vw - 28px));aspect-ratio:.74;max-height:calc(100vh - 36px);overflow:auto;background-image:url(/assets/ui/dialog/jiojio_letter_paper.png);background-size:contain;background-position:center;background-repeat:no-repeat;filter:drop-shadow(0 24px 34px rgba(37,28,20,.28))}.jiojio-letter-paper{display:flex;justify-content:center;align-items:flex-start;padding:min(12vh,122px) min(9vw,104px) min(10vh,96px)}.treasure-map-paper{width:min(690px,calc(100vw - 28px));padding:min(10vw,86px) min(9vw,76px)}.jiojio-letter-paper p{margin:0 auto;width:min(360px,66%);white-space:pre-wrap;font-family:LXGW WenKai,Caveat,Georgia,serif;font-size:clamp(16px,1.85vw,20px);line-height:1.72;color:#5b4630}.treasure-map-paper{display:grid;place-items:center;padding:min(8vw,70px) min(8vw,66px)}.treasure-map-sketch{display:grid;place-items:center;width:min(470px,86%);color:#5b4630;font-family:LXGW WenKai,Georgia,serif}.treasure-map-sketch h2{margin:0 0 6px;font-size:clamp(24px,3.4vw,38px);font-weight:800;letter-spacing:0}.treasure-map-sketch svg{width:100%;height:auto;overflow:visible}.treasure-map-sketch p{margin:-4px 0 0;font-size:clamp(17px,2.2vw,24px);color:#6b4d2e}.treasure-map-sketch path{fill:none;stroke:#6b4d2e;stroke-linecap:round;stroke-linejoin:round;stroke-width:7}.treasure-map-sketch text{fill:#6b4d2e;font-size:28px;font-weight:700}.treasure-map-sketch .map-coast{stroke:#5d8f9a;stroke-width:8}.treasure-map-sketch .map-wave{stroke:#68a9b7;stroke-width:5}.treasure-map-sketch .map-dune{stroke:#b89154;stroke-width:5;opacity:.72}.treasure-map-sketch .map-ship path{stroke:#5f3f28;stroke-width:8}.treasure-map-sketch .map-ship path:first-child{fill:#80542f29}.treasure-map-sketch .map-trail{stroke:#8c6040;stroke-dasharray:8 15;stroke-width:5}.treasure-map-sketch .map-x path{stroke:#b7372e;stroke-width:12}@media(max-width:560px){.jiojio-letter-paper{padding:74px 48px 62px}.treasure-map-paper{padding:54px 42px}.jiojio-letter-paper p{width:70%;font-size:13px;line-height:1.52}}.jiojio-letter-close,.treasure-map-close{position:fixed;right:max(24px,4vw);top:max(24px,4vh);width:auto;padding:10px 20px;border-radius:999px;border:1.5px solid #e8b98a;background:#fff6e4eb;color:#5a4632}.letter-book,.puzzle-card{position:relative;width:min(840px,calc(100vw - 42px));max-height:calc(100vh - 50px);overflow:auto;padding:30px;border-radius:8px;background:#fff6e4;border:1.5px solid #e8b98a;box-shadow:0 22px 60px #00000047}.close-button{position:absolute;right:18px;top:18px;width:40px;padding:0}.fragment-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.fragment-bank{display:flex;flex-wrap:wrap;gap:10px;margin:14px 0 18px}.fragment-bank button{min-height:40px;background:#d7c5a0;color:#6a563d;opacity:.62}.fragment-bank button.available{background:#a6c36f;color:#fff;opacity:1}.fragment-grid article{min-height:96px;padding:14px;border-radius:8px;background:#ead8b8;opacity:.72}.fragment-grid article.ready{outline:2px dashed #e8b98a;background:#fff3d6;opacity:.92}.fragment-grid article.filled{background:#fff9ee;opacity:1}.final-letter{margin-top:18px;padding:18px;border-radius:8px;background:#f7e5bc;font-size:20px;line-height:1.8}.final-notebook-letter{position:relative;width:min(760px,calc(100vw - 44px));max-height:calc(100vh - 52px);overflow:auto;padding:72px 78px 64px;border-radius:8px;color:#4d3a2b;background:linear-gradient(90deg,rgba(91,132,180,.18) 0 2px,transparent 2px 100%) 42px 0 / 42px 100% no-repeat,repeating-linear-gradient(#fffdf5 0 42px,#d9ecff 43px 44px),#fffdf5;border:1.5px solid rgba(125,161,196,.7);box-shadow:0 28px 80px #1c283a47}.final-notebook-letter:before{content:"";position:absolute;left:26px;top:30px;bottom:30px;width:10px;border-radius:999px;background:repeating-linear-gradient(#f5b7c8 0 12px,transparent 12px 28px);opacity:.72}.final-notebook-letter h2{margin:0 0 24px;color:#5a4632;font-size:34px}.final-notebook-letter p{margin:0;white-space:pre-line;font-size:23px;line-height:1.9}.fireworks{display:flex;gap:18px;justify-content:center}.fireworks i{width:28px;height:28px;border-radius:999px;background:#e89b7a;animation:pop .9s infinite alternate}.fireworks i:nth-child(2){background:#a6c36f;animation-delay:.16s}.fireworks i:nth-child(3){background:#8fc6e8;animation-delay:.32s}.sliding-grid{display:grid;grid-template-columns:repeat(4,72px);gap:8px;margin:18px 0}.sliding-grid.size-3{grid-template-columns:repeat(3,82px)}.sliding-grid button,.piano-topdown button,.star-grid button,.tap-counter button{width:72px;height:72px;border-radius:8px;background:#f7e5bc;color:#5a4632;font-size:22px}.sliding-grid.size-3 button{width:82px;height:82px;font-size:26px}.sliding-grid button.empty{background:transparent;box-shadow:inset 0 0 0 1.5px #d7c5a0}.riddle-cabinet{position:relative;width:min(440px,88vw);height:260px;margin:18px auto;perspective:900px}.cabinet-shadow{position:absolute;left:9%;right:9%;bottom:0;height:28px;border-radius:999px;background:#4f301e33;filter:blur(10px)}.cabinet-inside{position:absolute;inset:26px 40px 34px;border-radius:8px;background:radial-gradient(circle at 50% 62%,#ffd7602e,#0000 38%),linear-gradient(145deg,#0e0c12,#25202a 56%,#08070a);border:4px solid #5d3f2c;box-shadow:inset 0 18px 30px #000000b8}.cabinet-door{position:absolute;top:22px;bottom:30px;width:calc(50% - 40px);border:4px solid #6b452c;background:linear-gradient(90deg,#ffffff1a,#fff0),#b47846;box-shadow:inset 0 0 0 10px #5e37202e,0 10px 24px #462b1c3d;transition:transform .78s cubic-bezier(.22,1,.36,1)}.cabinet-door.left{left:40px;border-radius:12px 4px 4px 12px;transform-origin:left center}.cabinet-door.right{right:40px;border-radius:4px 12px 12px 4px;transform-origin:right center}.cabinet-door:after{content:"";position:absolute;top:50%;width:12px;height:12px;border-radius:999px;background:#f7d56d;box-shadow:0 0 12px #f7d56dbf}.cabinet-door.left:after{right:16px}.cabinet-door.right:after{left:16px}.riddle-cabinet.open .cabinet-door.left{transform:rotateY(-76deg)}.riddle-cabinet.open .cabinet-door.right{transform:rotateY(76deg)}.cabinet-gift{position:absolute;left:50%;top:58%;z-index:3;font-size:54px;opacity:0;transform:translate(-50%,-50%) scale(.45);filter:drop-shadow(0 0 18px rgba(255,215,96,.78))}.cabinet-gift.jump{animation:cabinet-gift-jump .9s cubic-bezier(.2,.9,.2,1.25) forwards}.riddle-lock{display:grid;justify-items:center;gap:12px}.password-display{display:grid;grid-template-columns:repeat(3,58px);gap:10px;padding:10px 12px;border-radius:8px;background:#5a4632;box-shadow:inset 0 2px 8px #00000059}.password-display span{display:grid;place-items:center;height:62px;border-radius:6px;background:#1e1a18;color:#ffd760;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:38px;text-shadow:0 0 12px rgba(255,215,96,.8)}.riddle-keypad{display:grid;grid-template-columns:repeat(3,58px);gap:8px}.riddle-keypad button{width:58px;height:48px;border-radius:8px;background:#f7e5bc;color:#5a4632;font-weight:800}.riddle-keypad button:last-child{background:#a6c36f;color:#fff}.firefly-field{position:relative;width:min(680px,88vw);height:min(420px,54vh);margin:18px auto;overflow:hidden;border-radius:8px;background:radial-gradient(circle at 50% 38%,#fff6e424,#fff6e400 42%),linear-gradient(180deg,#182336d1,#234a3de0);box-shadow:inset 0 0 52px #070c1575,0 16px 34px #1e191433}.firefly-grass-bg{position:absolute;inset:auto -8% -6%;height:44%;background:repeating-linear-gradient(74deg,rgba(143,207,138,.2) 0 2px,transparent 2px 13px),linear-gradient(180deg,#69a3685c,#4c7e489e);filter:blur(3px)}.ambient-firefly,.catchable-firefly{position:absolute;width:14px;height:14px;border:0;border-radius:999px;padding:0;background:#fffbe6;box-shadow:0 0 12px #fffbe6,0 0 24px #fffbe6b8}.ambient-firefly{opacity:.52;pointer-events:none;animation:ambient-firefly-pulse 2.8s ease-in-out infinite}.catchable-firefly{z-index:2;cursor:pointer;animation:firefly-five-flashes 5.8s ease-in-out infinite}.catchable-firefly span{position:absolute;left:50%;top:18px;min-width:46px;transform:translate(-50%);color:#fff6e4;font-size:12px;text-shadow:0 2px 8px rgba(0,0,0,.42);opacity:.84}.catchable-firefly.caught{opacity:.2;pointer-events:none;animation:none;box-shadow:none}.catchable-firefly.caught span{text-decoration:line-through}.firefly-skill-field{display:flex;align-items:flex-end;justify-content:center;padding:26px}.firefly-skill-field .ambient-firefly{z-index:1}.wandering-firefly{position:absolute;z-index:2;width:24px;height:24px;border-radius:999px;background:#fff7a6;box-shadow:0 0 14px #fff7a6,0 0 36px #ffe05ae0;animation:firefly-wander 5.2s ease-in-out infinite}.wandering-firefly:before,.wandering-firefly:after{content:"";position:absolute;top:7px;width:14px;height:9px;border-radius:999px 999px 40% 40%;background:#fff6e46b}.wandering-firefly:before{right:14px;transform:rotate(-26deg)}.wandering-firefly:after{left:14px;transform:rotate(26deg)}.bug-net-hand{position:absolute;right:42px;bottom:72px;z-index:4;width:156px;height:136px;transform-origin:78% 92%;animation:bug-net-ready 5.2s ease-in-out infinite}.bug-net-palm{position:absolute;right:4px;bottom:0;width:50px;height:42px;border-radius:38% 42% 46% 34%;background:#f1b67e;border:4px solid #7b5133;transform:rotate(-18deg)}.bug-net-handle{position:absolute;right:36px;bottom:28px;width:102px;height:10px;border-radius:999px;background:linear-gradient(90deg,#7b5133,#c68a4a);border:3px solid #5a3823;transform:rotate(-36deg);transform-origin:right center}.bug-net-ring{position:absolute;left:2px;top:12px;width:72px;height:54px;border-radius:50%;border:7px solid #7aa7bd;background:#d2f1f933;transform:rotate(-24deg);box-shadow:inset 0 0 12px #ffffff85}.bug-net-mesh{position:absolute;left:9px;top:20px;width:60px;height:40px;border-radius:50%;background:repeating-linear-gradient(25deg,rgba(255,255,255,.38) 0 2px,transparent 2px 10px),repeating-linear-gradient(-25deg,rgba(255,255,255,.28) 0 2px,transparent 2px 10px);transform:rotate(-24deg)}.firefly-skill-panel{position:relative;z-index:5;width:min(560px,76vw);display:grid;gap:12px;padding:16px 18px;border-radius:8px;background:#fff6e4e6;box-shadow:0 12px 28px #08101847}.firefly-skill-meta{display:flex;justify-content:space-between;gap:12px;color:#5a4632;font-weight:900}.firefly-round-pips{display:flex;justify-content:center;gap:10px}.firefly-round-pips i{width:14px;height:14px;border-radius:999px;background:#5a463238}.firefly-round-pips i.active{background:#ffd760;box-shadow:0 0 0 4px #ffd76038}.firefly-round-pips i.complete{background:#8ccf72;box-shadow:0 0 0 4px #8ccf7233}.firefly-skill-bar{position:relative;height:34px;border-radius:999px;overflow:visible;background:linear-gradient(180deg,#232c3af0,#101620f5),#1f2a38;box-shadow:inset 0 3px 8px #00000073}.firefly-green-zone{position:absolute;top:5px;bottom:5px;border-radius:2px;background:linear-gradient(90deg,#65bd58,#b7ec75,#65bd58);box-shadow:0 0 14px #b1f26fd1}.firefly-runner-ball{position:absolute;top:50%;width:20px;height:20px;border-radius:999px;background:radial-gradient(circle at 34% 28%,#fff,#ffd760 42%,#f59c49 78%);box-shadow:0 0 16px #ffd760cc,0 4px 10px #00000047;transform:translate(-50%,-50%)}.firefly-paused .firefly-runner-ball{box-shadow:0 0 0 4px #fff6e4e0,0 0 22px #ffd760f2,0 4px 10px #00000047}.firefly-stop-button{justify-self:center;min-width:150px;border-radius:999px;background:#a6c36f;color:#fff;font-weight:900;box-shadow:0 8px 16px #617c3d38}.firefly-stop-button:disabled{cursor:default;opacity:.72;transform:none}.firefly-result-hit .firefly-skill-panel{outline:3px solid rgba(166,195,111,.7)}.firefly-result-miss .firefly-skill-panel{outline:3px solid rgba(232,155,122,.72)}.firefly-result-done .firefly-skill-panel{outline:3px solid rgba(255,215,96,.82)}.tap-counter,.piano-topdown,.star-grid{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin:16px 0}.piano-topdown{position:relative;width:min(620px,86vw);aspect-ratio:5 / 2;padding:0;display:block;border-radius:8px;overflow:hidden;background:#f6dcaa;box-shadow:0 14px 30px #3d2a1c38}.piano-topdown img{width:100%;height:100%;display:block}.piano-topdown button.piano-key-hotspot{position:absolute;z-index:2;display:grid;place-items:center;padding:0;border:0;border-radius:6px 6px 12px 12px;background:transparent;color:#5a4632;font-size:28px;box-shadow:none;transform:translate(-50%,-50%);overflow:visible;outline:none;appearance:none}.piano-topdown button.piano-key-hotspot:before{content:"";position:absolute;inset:-3px 1px -2px;border-radius:6px 6px 12px 12px;background:#fff6e470;box-shadow:inset 0 -3px #d7c5a066,0 0 0 1.5px #fff6e41a;opacity:.2;transition:opacity .14s ease,transform .14s ease,box-shadow .14s ease}.piano-topdown button.piano-key-hotspot span{position:relative;z-index:1;display:grid;place-items:center;width:42px;height:42px;border-radius:999px;text-shadow:0 0 8px rgba(255,255,238,.95),0 0 18px rgba(255,215,96,.86);filter:drop-shadow(0 5px 8px rgba(90,70,50,.18))}.piano-topdown button.played{color:#6a4e12}.piano-topdown button.played:before{opacity:.86;box-shadow:inset 0 -4px #d7c5a070,0 0 18px #ffd760db}.piano-topdown button.pressed{animation:piano-key-hop .3s ease-out}.piano-topdown button.pressed:before{opacity:1;animation:piano-key-glow .42s ease-out}.piano-note-rise{position:absolute;z-index:3;width:44px;height:44px;display:grid;place-items:center;border-radius:999px;pointer-events:none;color:#fffbea;font-size:34px;text-shadow:0 0 8px #fffdea,0 0 18px #ffd760,0 0 34px rgba(255,215,96,.84);transform:translate(-50%,-50%);animation:piano-note-rise .96s ease-out forwards}.piano-note-rise:before,.piano-note-rise:after{content:"";position:absolute;inset:10px;border-radius:999px;background:radial-gradient(circle,#fffbd6f2,#ffd76085 44%,#ffd76000 72%);z-index:-1}.piano-note-rise:after{inset:2px;border:1.5px solid rgba(255,241,184,.8);background:transparent}.piano-topdown.mistake{animation:shake .24s ease-in-out}.piano-topdown.locked{opacity:.58}.music-performance-overlay{position:fixed;inset:0;display:grid;place-items:center;background:#10142a9e;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:45}.moonbell-stage{position:relative;width:min(640px,90vw);aspect-ratio:1 / 1}.moonbell-stage img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 24px 42px rgba(0,0,0,.26))}.music-close{position:absolute;right:7%;top:8%;z-index:2;width:42px;height:42px;border-radius:999px;background:#fff6e4e6;color:#5a4632}.harp-strings{position:absolute;inset:0;pointer-events:none}.harp-strings i{position:absolute;width:3px;background:linear-gradient(#fffbe0,#f5cf6d);transform:translate(-50%) rotate(4deg);transform-origin:top center;opacity:.78}.harp-strings i:after{content:"";position:absolute;inset:0 -5px;opacity:0;background:#ffffff57;filter:blur(4px)}.harp-strings i.playing{animation:string-pluck .36s ease-in-out}.harp-strings i.playing:after{opacity:1}.harp-strings span{position:absolute;left:-22px;bottom:-10px;font-size:34px;opacity:0;transform:translateY(0) scale(.7)}.harp-strings i.playing span{animation:icon-rise .9s ease-out forwards}.tap-counter strong{min-width:60px;text-align:center;font-size:32px}.puzzle-card label{display:grid;gap:8px;max-width:420px;margin:14px 0}.fish-meter{width:44px;height:180px;display:flex;align-items:end;margin:16px 0;border:2px solid #d7c5a0;border-radius:999px;overflow:hidden;background:#e9f4fb}.fish-meter i{width:100%;background:#a6c36f}.fishing-scene-layer{position:fixed;inset:0;z-index:42;pointer-events:none}.fishing-close{position:fixed;right:28px;top:96px;width:42px;height:42px;border-radius:999px;background:#fff6e4f2;border:1.5px solid #d7c5a0;color:#5a4632;pointer-events:auto}.fishing-cast-line{position:fixed;left:50%;bottom:33vh;width:180px;height:2px;transform-origin:0 50%;transform:rotate(-22deg) scaleX(0);background:linear-gradient(90deg,#fff6e433,#fff6e4eb);filter:drop-shadow(0 0 6px rgba(255,246,228,.7))}.fishing-cast-line[data-stage=cast]{animation:cast-line .82s ease-out forwards}.fishing-cast-line[data-stage=caught]{animation:reel-line .62s ease-in forwards}.stardew-fishing{position:fixed;right:clamp(180px,24vw,360px);top:50%;width:164px;padding:12px 12px 14px;transform:translateY(-50%);border-radius:8px;border:2px solid #7b6650;background:#fff6e4eb;box-shadow:0 14px 34px #5a463233;color:#5a4632;pointer-events:none}.stardew-fishing strong{display:block;min-height:38px;margin-bottom:8px;font-size:14px;line-height:1.35}.fishing-timer{position:absolute;right:10px;top:44px;font-weight:800;color:#e89b7a}.fishing-track{position:relative;width:56px;height:220px;margin:8px auto 10px;border:2px solid #7b6650;border-radius:999px;overflow:hidden;background:linear-gradient(#d8f2ff,#8fd0e8)}.fish-icon{position:absolute;left:50%;z-index:2;transform:translate(-50%,50%);font-style:normal;filter:drop-shadow(0 2px 2px rgba(47,94,120,.28))}.catch-bar{position:absolute;left:6px;z-index:1;width:40px;height:42%;border-radius:999px;background:#a6c36fc7;border:2px solid rgba(82,113,44,.42);box-shadow:0 0 14px #a6c36f8c}.catch-progress{height:10px;overflow:hidden;border-radius:999px;background:#ead8b8}.catch-progress i{display:block;height:100%;background:linear-gradient(90deg,#a6c36f,#ffd760)}.stardew-fishing small{display:block;margin-top:8px;color:#7b6650;font-size:12px;line-height:1.35}@keyframes cast-line{0%{transform:rotate(-36deg) scaleX(0);opacity:0}45%{transform:rotate(-25deg) scaleX(1.15);opacity:1}to{transform:rotate(-22deg) scaleX(1);opacity:.82}}@keyframes reel-line{0%{transform:rotate(-22deg) scaleX(1);opacity:.82}to{transform:rotate(-40deg) scaleX(.08);opacity:0}}@keyframes bubble-in{0%{transform:translateY(16px);opacity:0}}@keyframes portrait-in{0%{transform:translate(-50%,24px);opacity:0}}@keyframes speaking{50%{margin-bottom:2px}}@keyframes blink{50%{opacity:.25}}@keyframes pop{0%{transform:scale(.45);opacity:.45}to{transform:scale(1.15);opacity:1}}@keyframes cabinet-gift-jump{0%{opacity:0;transform:translate(-50%,14%) scale(.45) rotate(-8deg)}42%{opacity:1;transform:translate(-50%,-94%) scale(1.18) rotate(7deg)}to{opacity:1;transform:translate(-50%,-52%) scale(1) rotate(0)}}@keyframes ambient-firefly-pulse{0%,to{opacity:.18;transform:translate3d(-8px,5px,0) scale(.62)}50%{opacity:.8;transform:translate3d(9px,-7px,0) scale(1.2)}}@keyframes firefly-five-flashes{0%,12%,24%,36%,48%{background:#fffbe6;box-shadow:0 0 12px #fffbe6,0 0 28px #fffbe6d1;transform:translate3d(-5px,5px,0) scale(.9)}6%,18%,30%,42%,54%{background:#fffbe6;box-shadow:0 0 4px #fffbe66b;transform:translate3d(5px,-4px,0) scale(.72)}72%,88%{background:var(--firefly-color);box-shadow:0 0 18px var(--firefly-color),0 0 42px var(--firefly-color);transform:translate3d(8px,-8px,0) scale(1.32)}}@keyframes firefly-wander{0%{left:12%;top:26%;transform:translateZ(0) scale(.82)}18%{left:72%;top:18%;transform:translate3d(8px,-12px,0) scale(1.16)}38%{left:54%;top:48%;transform:translate3d(-16px,10px,0) scale(.94)}58%{left:82%;top:36%;transform:translate3d(12px,-5px,0) scale(1.24)}78%{left:28%;top:56%;transform:translate3d(-12px,12px,0) scale(.9)}to{left:12%;top:26%;transform:translateZ(0) scale(.82)}}@keyframes bug-net-ready{0%{transform:translate3d(-18px,8px,0) rotate(-12deg)}18%{transform:translate3d(-88px,-24px,0) rotate(16deg)}38%{transform:translate3d(-54px,34px,0) rotate(-22deg)}58%{transform:translate3d(-118px,-2px,0) rotate(20deg)}78%{transform:translate3d(-30px,42px,0) rotate(-18deg)}to{transform:translate3d(-18px,8px,0) rotate(-12deg)}}@keyframes string-pluck{0%,to{transform:rotate(4deg) translate(0)}30%{transform:rotate(4deg) translate(-7px)}65%{transform:rotate(4deg) translate(5px)}}@keyframes icon-rise{0%{opacity:0;transform:translateY(12px) scale(.7);filter:drop-shadow(0 0 0 rgba(255,255,255,0))}18%{opacity:1}to{opacity:0;transform:translateY(-118px) scale(1.24);filter:drop-shadow(0 0 18px rgba(255,255,255,.95))}}@keyframes piano-key-hop{0%,to{transform:translate(-50%,-50%)}38%{transform:translate(-50%,calc(-50% + 9px)) scaleY(.94)}68%{transform:translate(-50%,calc(-50% - 5px)) scaleY(1.02)}}@keyframes piano-key-glow{0%{box-shadow:inset 0 -4px #d7c5a06b,0 0 #ffd76000}38%{box-shadow:inset 0 -2px #d7c5a05c,0 0 24px #ffd760f2}to{box-shadow:inset 0 -4px #d7c5a06b,0 0 10px #ffd76061}}@keyframes piano-note-rise{0%{opacity:0;transform:translate(-50%,-20%) scale(.62);filter:blur(1px)}18%{opacity:1;transform:translate(-50%,-55%) scale(1);filter:blur(0)}to{opacity:0;transform:translate(-50%,-190%) scale(1.38);filter:blur(2px)}}@media(max-width:1024px){.speech-bubble{left:4vw;width:92vw}.npc-portrait{left:22vw;height:32vh;min-height:220px}.choice-panel{left:6vw;top:auto;bottom:29vh}.choice-panel button{width:88vw}.scholar-gift-panel{left:6vw;top:auto;bottom:28vh;width:88vw}.inventory-drawer{width:100vw;min-width:0}.time-slider{width:calc(100vw - 124px);inset:auto auto 96px 22px}.gift-progress{inset:auto auto 148px 22px}.control-guide{inset:auto auto 200px 22px;max-width:calc(100vw - 44px)}.restart-button{right:30px;bottom:212px}.compass-button{left:22px;bottom:254px}.scene-map-paper{min-height:auto;padding:48px 24px 28px}.scene-map-board{aspect-ratio:1 / .92}.map-marker{max-width:86px;overflow:hidden;text-overflow:ellipsis}.inventory-grid{grid-template-columns:repeat(3,96px)}}
