@import"https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;1,500;1,600&family=Noto+Sans+SC:wght@300;400;500;700&family=Noto+Serif+SC:wght@300;400;500;600&family=Pixelify+Sans:wght@400;500;600;700&family=Playfair+Display:ital,wght@0,500;0,600;1,500&family=Space+Mono:wght@400;700&family=VT323&display=swap";:root{--blue-gray-1: #60798f;--blue-gray-2: #91aabd;--milk: rgba(255, 251, 245, .68);--milk-soft: rgba(255, 251, 245, .36);--lavender: #c9c4ff;--pink: #f4c3da;--cream: #fff3d7;--ink: rgba(72, 65, 84, .84);--ink-soft: rgba(72, 65, 84, .62);--line: rgba(255, 255, 255, .68);--glow: 0 0 42px rgba(255, 240, 255, .78);--shadow: 0 24px 70px rgba(47, 52, 78, .22)}*{box-sizing:border-box}html,body,#app{width:100vw;height:100vh;margin:0;overflow:hidden}#app{position:relative;isolation:isolate}body{width:100vw;height:100vh;margin:0;overflow:hidden;color:var(--ink);background:linear-gradient(145deg,#5f7c92,#a8b8c8 55%,#d0c3da);font-family:Space Mono,Noto Sans SC,monospace}button{color:inherit;font:inherit}.background-image-layer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-3;background-image:url(/background/bg1.jpg);background-size:cover;background-position:center;background-repeat:no-repeat;filter:blur(3px) brightness(.82) saturate(.9);opacity:.82;transform:scale(1.04)}.background-gradient-layer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-2;pointer-events:none;background:linear-gradient(180deg,#b4beff38,#ffdcf02e)}.background-particles-layer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none}.screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:5;width:100vw;height:100vh;overflow:hidden}.loading-screen{z-index:10}.world-screen{z-index:6}.is-hidden{opacity:0;pointer-events:none;visibility:hidden}.main-ui{position:absolute;left:50%;top:50%;z-index:8;display:flex;width:min(980px,calc(100vw - 48px));min-height:min(720px,calc(100vh - 72px));flex-direction:column;align-items:center;justify-content:center;gap:clamp(14px,2vh,24px);transform:translate(-50%,-50%);text-align:center}.world-ui{--parallax-x: 0px;--parallax-y: 0px;transform:translate(calc(-50% + var(--parallax-x)),calc(-50% + var(--parallax-y)));animation:uiFloat 6.5s ease-in-out infinite}.glass-card{border:1px solid var(--line);border-radius:30px;background:linear-gradient(135deg,#ffffff80,#fff5fc42);box-shadow:var(--shadow),var(--glow),inset 0 0 30px #ffffff47;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.loading-card{position:relative;width:min(860px,92vw);padding:clamp(36px,5vw,58px) clamp(30px,5vw,62px);opacity:0;filter:blur(14px)}.loading-card:after,.site-title:after,.bottom-copy:after{content:"";position:absolute;top:8px;right:8px;bottom:8px;left:8px;border:1px solid rgba(255,255,255,.38);border-radius:24px;pointer-events:none}.eyebrow{margin:0 0 18px;color:#fffcf8d6;font-family:Space Mono,monospace;font-size:13px;letter-spacing:.1em;text-transform:uppercase;text-shadow:0 0 16px rgba(255,255,255,.85)}.diary-heading{margin:0 0 22px;text-align:center}.diary-title{margin:0;color:#473d54db;font-family:Cormorant Garamond,Playfair Display,serif;font-size:clamp(48px,6.4vw,86px);font-style:italic;font-weight:600;line-height:.92;text-shadow:0 4px 0 rgba(255,255,255,.48),0 0 30px rgba(255,238,252,.76)}.diary-subtitle{margin:10px 0 0;color:#4841548f;font-family:"Noto Serif SC",serif;font-size:clamp(18px,2.2vw,30px);font-weight:400;letter-spacing:.16em}.typewriter{display:inline-block;max-width:none;margin:0 0 30px;overflow:visible;border-right:2px solid rgba(255,255,255,.78);color:var(--ink);font-family:VT323,Pixelify Sans,monospace;font-size:clamp(52px,5.2vw,78px);font-weight:400;line-height:1.1;white-space:nowrap;text-shadow:0 3px 0 rgba(255,255,255,.5),0 0 24px rgba(255,238,252,.68);animation:softTitleIn 2.2s ease-in-out .35s both,cursorBlink 1.3s ease-in-out infinite}.loading-title{width:auto}.progress-shell{height:20px;padding:4px;overflow:hidden;border:1px solid rgba(255,255,255,.72);border-radius:999px;background:#ffffff57;box-shadow:inset 0 2px 14px #4c426824,0 0 28px #c9c4ff80}.progress-fill{width:0%;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--lavender),var(--pink),var(--cream));box-shadow:0 0 24px #fff2fff2}.progress-percent{margin:18px 0 0;color:var(--ink-soft);font-family:VT323,monospace;font-size:38px}.loading-actions{display:flex;justify-content:center;gap:0;margin-top:20px;opacity:0;filter:blur(10px);transform:translateY(14px) scale(.96);pointer-events:none}.dream-button{min-width:166px;padding:15px 34px;border:1px solid rgba(255,255,255,.82);border-radius:999px;background:linear-gradient(180deg,#fffcefa8,#ffe8f575);box-shadow:0 16px 34px #393a5821,0 0 22px #ffeef87a,inset 0 0 20px #ffffff6b;color:var(--ink);cursor:pointer;font-family:Cormorant Garamond,Space Mono,serif;font-size:27px;font-style:italic;font-weight:600;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:transform 1.7s ease-in-out,box-shadow 1.7s ease-in-out,background 1.7s ease-in-out,filter 1.7s ease-in-out}.dream-button:hover{background:linear-gradient(180deg,#fffdf3c7,#ffe2f394);box-shadow:0 18px 42px #393a5824,0 0 34px #ffedfdc2,inset 0 0 26px #ffffff8a;filter:brightness(1.035);transform:translateY(-4px) scale(1.03)}.or-message{min-height:24px;margin:22px 0 0;opacity:0;color:var(--ink-soft);font-size:14px}.site-title{position:relative;width:min(620px,calc(100vw - 48px));padding:clamp(14px,2vw,20px)}.site-title h2{margin:0;color:var(--ink);font-family:Cormorant Garamond,Playfair Display,serif;font-size:clamp(40px,5vw,66px);font-style:italic;font-weight:600;line-height:.95;text-shadow:0 4px 0 rgba(255,255,255,.42),0 0 30px rgba(255,237,253,.68)}.cn-title,.cn-copy{font-family:"Noto Serif SC",Noto Sans SC,serif}.cn-title{margin:12px 0 0;color:var(--ink-soft);font-size:clamp(20px,2.1vw,32px);font-weight:400;letter-spacing:.12em}.earth-stage{position:relative;display:grid;width:min(440px,40vw,46vh);aspect-ratio:1;place-items:center;filter:drop-shadow(0 0 46px rgba(255,244,255,.6)) drop-shadow(0 26px 64px rgba(40,55,82,.2));animation:planetFloat 7.5s ease-in-out infinite}#earthCanvas{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;width:100%;height:100%;cursor:grab}#earthCanvas:active{cursor:grabbing}.earth-stage:before{content:"";position:absolute;border-radius:50%;pointer-events:none}.earth-stage:before{top:5%;right:5%;bottom:5%;left:5%;z-index:1;background:radial-gradient(circle at 42% 34%,rgba(255,255,255,.35),transparent 20%),radial-gradient(circle,rgba(230,245,255,.32),rgba(244,219,255,.2) 48%,transparent 76%);filter:blur(20px);animation:planetBreath 5.8s ease-in-out infinite}.world-screen:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:2;background:#363e5200;pointer-events:none;transition:background 2.4s ease-in-out}.world-screen.is-ending:before{background:#363e5229}.label-layer{position:absolute;top:0;right:0;bottom:0;left:0;z-index:5;pointer-events:none}.city-pin{position:absolute;width:0;height:0;padding:0;border:0;background:transparent;color:inherit;cursor:pointer;pointer-events:auto;transform-origin:center;transition:opacity 1.2s ease-in-out,transform 1.2s ease-in-out,filter 1.2s ease-in-out}.city-dot{position:absolute;left:0;top:0;width:12px;height:12px;border-radius:50%;background:#fff0a7;box-shadow:0 0 16px #fff0a7f2,0 0 30px #ffcfe2b8;transform:translate(-50%,-50%)}.city-dot:after{content:"";position:absolute;top:-9px;right:-9px;bottom:-9px;left:-9px;border-radius:50%;background:#ffddf047;animation:cityDotBreath 2.4s ease-in-out infinite}.city-pin-line{position:absolute;left:0;top:0;width:54px;height:1px;background:#fffaeead;box-shadow:0 0 7px #fff4e6ad;transform-origin:0 50%}.city-label{position:absolute;display:inline-flex;align-items:center;gap:8px;padding:7px 13px;border:1px solid rgba(255,255,255,.76);border-radius:999px;background:#fffbeea8;box-shadow:0 12px 28px #393a5824,0 0 22px #fff4d27a;color:var(--ink);font-family:Space Mono,monospace;font-size:14px;pointer-events:none;white-space:nowrap;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);transition:opacity 1.2s ease-in-out,filter 1.2s ease-in-out,box-shadow 1.2s ease-in-out,transform 1.2s ease-in-out}.city-guangzhou .city-pin-line{width:70px;transform:rotate(166deg)}.city-guangzhou .city-label{transform:translate(-178px,10px)}.city-zhuhai .city-pin-line{width:66px;transform:rotate(8deg)}.city-zhuhai .city-label{transform:translate(64px,-12px)}.city-qingdao .city-pin-line{width:64px;transform:rotate(-72deg)}.city-qingdao .city-label{transform:translate(20px,-104px)}.city-pin:hover .city-label{filter:brightness(1.06);box-shadow:0 16px 36px #393a5824,0 0 32px #ffedfde0}.city-pin.is-active .city-label{background:#fff6dac7;box-shadow:0 18px 40px #393a5829,0 0 36px #ffe8abd1,0 0 48px #ffdaf285;filter:brightness(1.08)}.city-pin.is-active .city-dot{box-shadow:0 0 20px #fff0a7,0 0 46px #ffcfe2e6}.bottom-copy{position:relative;width:min(740px,calc(100vw - 48px));padding:15px 24px;opacity:.78}.bottom-copy p{margin:0;color:var(--ink);font-size:clamp(15px,1.45vw,22px);line-height:1.4}.bottom-copy .cn-copy{margin-top:8px;color:var(--ink-soft);font-size:clamp(15px,1.2vw,19px)}.ending-moment{position:absolute;bottom:clamp(-6px,-1.5vh,-2px);left:50%;width:min(500px,calc(100vw - 48px));padding:13px 22px;opacity:0;pointer-events:none;transform:translate(-50%) translateY(14px);filter:blur(12px)}.ending-moment p{margin:0;color:#fffcf8e0;font-family:Space Mono,Noto Sans SC,monospace;font-size:clamp(13px,1.2vw,17px);line-height:1.55;text-shadow:0 0 18px rgba(255,245,255,.72)}.scrapbook-layer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9;pointer-events:none}.polaroid-card{--card-rotate: 0deg;--float-delay: 0s;position:absolute;width:clamp(150px,13vw,220px);padding:9px 9px 36px;border:1px solid rgba(255,255,255,.86);border-radius:13px;background:linear-gradient(180deg,#fffdf6f0,#fff6ecdb);box-shadow:0 22px 52px #36375033,0 0 28px #ffeffc61;cursor:pointer;pointer-events:auto;transform-origin:50% 88%;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.polaroid-card:before{content:"";position:absolute;left:18px;right:18px;top:-9px;height:22px;border-radius:5px;background:#fff4da80;box-shadow:0 4px 12px #453f5814;transform:rotate(-2deg)}.polaroid-card img{display:block;width:100%;aspect-ratio:1 / 1;border-radius:8px;background:radial-gradient(circle at 36% 28%,rgba(255,255,255,.82),transparent 20%),linear-gradient(135deg,#c9c4ff73,#f4c3da6b,#fff3d773);object-fit:cover;box-shadow:inset 0 0 0 1px #ffffff7a}.polaroid-card p{position:absolute;left:12px;right:12px;bottom:9px;margin:0;color:#484154a8;font-family:Pixelify Sans,Noto Sans SC,monospace;font-size:15px;line-height:1.15;text-align:center}.polaroid-card:hover{box-shadow:0 28px 64px #36375038,0 0 38px #ffeffca8;filter:brightness(1.04)}.polaroid-card.is-floating{animation:polaroidFloat 5.8s ease-in-out var(--float-delay) infinite}.polaroid-left{z-index:2}.polaroid-bottom{z-index:4}.polaroid-right{z-index:3}.final-ending{position:fixed;left:50%;top:50%;z-index:22;display:grid;width:min(720px,calc(100vw - 56px));min-height:260px;place-items:center;padding:52px 42px;opacity:0;pointer-events:none;transform:translate(-50%,-50%) scale(.94);filter:blur(18px);text-align:center}.final-ending p{margin:0;color:#fffaf6eb;font-family:"Noto Serif SC",Pixelify Sans,serif;font-size:clamp(30px,3.8vw,52px);font-weight:500;line-height:1.55;letter-spacing:.04em;text-shadow:0 4px 0 rgba(79,70,96,.12),0 0 28px rgba(255,232,248,.82)}.final-ending p span{display:block}.final-ending small{margin-top:22px;color:#fff5e8c7;font-family:Cormorant Garamond,Playfair Display,serif;font-size:clamp(22px,2.4vw,34px);font-style:italic;line-height:1.2;text-shadow:0 0 24px rgba(255,245,220,.62)}.atmosphere-layer,.snow-layer,.sparkle-layer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:3;pointer-events:none}.snow-layer{z-index:11}.sparkle-layer{z-index:4}.background-particles-layer.atmosphere-layer{z-index:-1}.floaty,.pixel-sparkle,.blur-dot,.snowflake,.burst-particle{position:absolute;-webkit-user-select:none;user-select:none;will-change:transform,opacity}.floaty{width:22px;height:22px;opacity:.34;filter:drop-shadow(0 0 14px rgba(255,255,255,.82))}.floaty.butterfly:before{content:"";position:absolute;top:1px;right:1px;bottom:1px;left:1px;border-radius:50%;background:radial-gradient(circle at 32% 34%,#f4b0cf 0 22%,transparent 24%),radial-gradient(circle at 68% 34%,#c9c4ff 0 22%,transparent 24%),radial-gradient(circle at 35% 70%,#ead6ff 0 18%,transparent 20%),radial-gradient(circle at 65% 70%,#ffd6ea 0 18%,transparent 20%)}.floaty.heart:before{content:"♥";color:#fff0f5b8;font-family:"Noto Serif SC",serif;font-size:24px;opacity:.7;text-shadow:0 0 12px rgba(255,255,255,.45),0 0 22px rgba(255,205,225,.38)}.floaty.star:before{content:"✧";color:#fff4c5d1;font-size:24px}.floaty.bubble{border:1px solid rgba(255,255,255,.72);border-radius:50%;background:radial-gradient(circle at 35% 30%,rgba(255,255,255,.86),rgba(204,198,255,.16) 58%,transparent)}.floaty.glow{border-radius:50%;background:#ffebfa4d;filter:blur(6px)}.pixel-sparkle{width:5px;height:5px;background:#ffffffeb;box-shadow:10px 5px #fff3bfb8,0 0 18px #ffffffd6}.blur-dot{width:20px;height:20px;border-radius:50%;background:#f1d3ff6b;filter:blur(5px)}.snowflake{width:var(--size);height:var(--size);pointer-events:none}.snowflake:before{content:"";width:100%;height:100%;border-radius:30% 70% 62% 38%;background:#ffffffeb;box-shadow:0 0 16px #ffffffe6,0 0 30px #e2daff94;transform:rotate(18deg)}.burst-particle{z-index:13;width:7px;height:7px;border-radius:50%;background:#fff8ccf0;box-shadow:0 0 18px #fffffff0;pointer-events:none}.note-pop{position:absolute;z-index:14;max-width:280px;padding:16px 18px;border:1px solid rgba(255,255,255,.76);border-radius:18px;background:#fffbe3b8;box-shadow:var(--shadow),0 0 28px #fff5db8a;color:var(--ink);font-family:Noto Sans SC,sans-serif;font-size:18px;pointer-events:none;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.memory-panel{display:none;position:absolute;right:30px;top:50%;z-index:14;width:min(360px,calc(100vw - 60px));max-height:calc(100vh - 88px);padding:24px 24px 26px;opacity:0;overflow:hidden;pointer-events:none;transform:translateY(-50%) translate(34px);filter:blur(12px)}.memory-panel:after{content:"";position:absolute;top:8px;right:8px;bottom:8px;left:8px;border:1px solid rgba(255,255,255,.34);border-radius:24px;pointer-events:none}.panel-close{position:absolute;right:16px;top:14px;display:grid;width:34px;height:34px;place-items:center;border:1px solid rgba(255,255,255,.72);border-radius:50%;background:#ffffff57;color:var(--ink);cursor:pointer;font-family:Pixelify Sans,monospace;font-size:25px;transition:transform 1.2s ease-in-out,box-shadow 1.2s ease-in-out}.panel-close:hover{box-shadow:0 0 20px #fff0fccc;transform:scale(1.06)}.panel-kicker{margin:0 42px 8px 0;color:#fffcf8d1;font-family:Space Mono,monospace;font-size:12px;letter-spacing:.1em;text-transform:uppercase}.memory-city{margin:0;color:var(--ink);font-family:Pixelify Sans,VT323,monospace;font-size:42px;font-weight:600;line-height:1;text-shadow:0 3px 0 rgba(255,255,255,.56)}.memory-cn{margin:6px 0 4px;color:var(--ink-soft);font-family:Noto Sans SC,sans-serif;font-size:22px}.memory-date{display:inline-flex;margin:0 0 18px;padding:5px 11px;border:1px solid rgba(255,255,255,.58);border-radius:999px;background:#ffffff3d;color:#4841548f;font-family:Space Mono,monospace;font-size:12px;letter-spacing:.04em}.memory-cover{display:block;width:100%;aspect-ratio:4 / 3;padding:9px 9px 18px;border:1px solid rgba(255,255,255,.78);border-radius:24px;background-color:#fffcf694;object-fit:cover;box-shadow:0 18px 46px #393a582e,0 0 30px #fff0fc75;transition:filter 1.4s ease-in-out,opacity 1.4s ease-in-out,transform 1.4s ease-in-out}.memory-cover.is-missing,.memory-gallery img.is-missing{background:radial-gradient(circle at 38% 28%,rgba(255,255,255,.78),transparent 18%),linear-gradient(135deg,#c9c4ff73,#f4c3da6b,#fff3d773)}.memory-gallery{display:flex;gap:10px;margin:14px 0;overflow-x:auto;padding:2px 2px 9px;scrollbar-width:thin}.memory-gallery img{width:74px;height:74px;flex:0 0 auto;border:1px solid rgba(255,255,255,.72);border-radius:16px;cursor:pointer;object-fit:cover;box-shadow:0 10px 22px #393a581f;transition:transform 1.2s ease-in-out,box-shadow 1.2s ease-in-out,filter 1.2s ease-in-out}.memory-gallery img:hover{transform:translateY(-5px) scale(1.035);filter:brightness(1.04);box-shadow:0 16px 30px #393a5829,0 0 20px #fff0fc80}.memory-text{position:relative;margin:6px 0 0;color:var(--ink);font-family:Noto Sans SC,Space Mono,sans-serif;font-size:16px;line-height:2;text-align:left;padding:14px 14px 0 18px;border-top:1px dashed rgba(255,255,255,.46)}.memory-text:before{content:"";position:absolute;left:3px;top:18px;width:5px;height:calc(100% - 22px);border-radius:999px;background:linear-gradient(180deg,#f4c3da94,#c9c4ff70)}@keyframes typeIn{0%{width:0}to{width:100%}}@keyframes softTitleIn{0%{opacity:0;filter:blur(10px);transform:translateY(8px) scale(.98)}to{opacity:1;filter:blur(0);transform:translateY(0) scale(1)}}@keyframes cursorBlink{0%,to{border-color:#fff3}50%{border-color:#ffffffd1}}@keyframes floating{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}@keyframes uiFloat{0%,to{margin-top:0}50%{margin-top:-7px}}@keyframes planetFloat{0%,to{margin-top:0}50%{margin-top:-9px}}@keyframes polaroidFloat{0%,to{transform:translateY(0) rotate(var(--card-rotate))}50%{transform:translateY(-9px) rotate(calc(var(--card-rotate) + 1.6deg))}}@keyframes cityDotBreath{0%,to{opacity:.28;transform:scale(.82)}50%{opacity:.58;transform:scale(1.18)}}@keyframes planetBreath{0%,to{transform:scale(.97);filter:brightness(.98)}50%{transform:scale(1.04);filter:brightness(1.08)}}@media (max-height: 760px){.main-ui{gap:16px;min-height:calc(100vh - 32px)}.site-title{padding:18px 24px}.earth-stage{width:min(410px,40vw,46vh)}.bottom-copy{padding:14px 20px}}@media (max-width: 760px){.main-ui{width:calc(100vw - 28px);min-height:calc(100vh - 28px)}.earth-stage{width:min(360px,78vw)}.loading-card{width:min(680px,92vw);padding-inline:22px}.diary-title{font-size:clamp(38px,12vw,58px)}.diary-subtitle{font-size:clamp(16px,5vw,22px);letter-spacing:.08em}.typewriter{font-size:clamp(38px,10vw,52px);line-height:1;white-space:normal}.memory-panel{left:14px;right:14px;top:auto;bottom:14px;width:auto;max-height:52vh;transform:translateY(22px)}.ending-moment{bottom:4px}}
