:root{color:#557d9d;background:#fff;font-family:STKaiti,KaiTi,Microsoft YaHei,serif}*{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0;overflow:hidden}button,a{-webkit-tap-highlight-color:transparent}button{font:inherit}.screen-shell{width:100vw;height:100vh;overflow:hidden;background:#fff}.portfolio-shell{position:relative;width:100vw;height:100vh;overflow:hidden;background:#fff}.archive-background{position:absolute;z-index:0;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:fill}.archive-pages-background{position:absolute;z-index:1;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:fill}.folder-content,.folder-page{position:absolute;z-index:2;top:0;right:0;bottom:0;left:0}.folder-content:has(.poster-lightbox){z-index:25}.folder-nav{position:absolute;z-index:10;top:1.45%;left:41.5%;width:53.8%;aspect-ratio:852 / 118;height:auto}.folder-nav-art{position:absolute;top:0;right:0;bottom:0;left:0;display:block;width:100%;height:100%;object-fit:contain}.nav-hotspots{position:absolute;top:0;right:0;bottom:0;left:0}.nav-hotspots button{position:absolute;top:15%;height:58%;overflow:hidden;border:0;background:transparent;clip-path:polygon(0 0,86% 0,100% 100%,16% 100%);cursor:pointer}.nav-hotspots button:nth-child(1){left:6.7%;width:22.2%}.nav-hotspots button:nth-child(2){left:29.5%;width:20.8%}.nav-hotspots button:nth-child(3){left:52%;width:20.5%}.nav-hotspots button:nth-child(4){left:74.2%;width:20%}.nav-hotspots button:after{position:absolute;top:0;right:0;bottom:0;left:0;background:transparent;content:""}.nav-hotspots button:focus-visible{outline:2px solid rgba(64,107,133,.7);outline-offset:-3px}.picture-button{position:absolute;z-index:7;border:0;padding:0;background:transparent;cursor:pointer}.picture-button:before{position:absolute;z-index:0;content:""}.picture-button img{position:relative;z-index:1;display:block;width:100%;height:100%}.resume-button{top:14.55%;left:54.8%;width:15.5%;height:13%}.resume-button:before{top:14%;right:10.5%;bottom:17%;left:8.5%;border-radius:8%;background:#a8c6e2}.contact-button{top:14.55%;left:73.5%;width:15.5%;height:13%}.contact-button:before{display:none}.intro-bubble{position:absolute;z-index:5;top:22%;left:7.2%;width:31.95%;height:35.89%;transform-origin:88% 72%;animation:bubble-wiggle .8s ease-in-out infinite alternate}.profile-note{position:absolute;z-index:3;top:24.75%;left:54.2%;width:39.96%;height:75.22%;opacity:0;transform:translate(-52%);transition:opacity .16s steps(2,end),transform .56s cubic-bezier(.24,.83,.33,1)}.profile-note.is-visible{opacity:1;transform:translate(0)}.portrait-trigger{position:absolute;z-index:6;top:33.5%;left:23.8%;width:32.3%;height:58.5%;outline:none}.portrait-outline,.portrait-image{position:absolute;display:block;width:100%;height:100%;object-fit:contain}.portrait-outline{z-index:1;top:-1.3%;right:-1.4%;bottom:-1%;left:-1.4%;width:102.8%;height:102.3%}.portrait-image{z-index:2;top:0;right:0;bottom:0;left:0}.portrait-hint{position:absolute;z-index:4;top:57.2%;left:63%;margin:0;color:#b29e7e;font-size:clamp(16px,1.65vw,29px);transition:opacity .14s ease}.portrait-hint.is-hidden{opacity:0}.welcome-mark{position:absolute;z-index:9;bottom:0;left:41.5%;width:15.67%;height:16.33%;transition:opacity .16s ease}.portfolio-shell:has(.poster-lightbox) .welcome-mark{opacity:0}.works-page{overflow:hidden}.work-filter-list{position:absolute;z-index:7;top:18.6%;left:3.8%;display:flex;flex-direction:column;gap:5.7vh;width:14.6%}.work-filter-list button{position:relative;display:flex;align-items:center;justify-content:center;width:92%;min-height:clamp(48px,6.8vh,72px);border:0;padding:0 5%;background:#fff7bcdb;border-radius:50%;box-shadow:0 8px 13px #a2894121,inset 0 -6px #efdb8657;color:#efc11d;cursor:pointer;filter:drop-shadow(2px 4px 2px rgba(112,122,124,.15));font-family:Comic Sans MS,STKaiti,KaiTi,cursive;font-size:clamp(20px,2.85vw,45px);font-weight:700;letter-spacing:.08em;line-height:1;transform:rotate(calc((var(--button-index) - 1.5) * -1.5deg));transition:transform .15s ease,filter .15s ease}.work-filter-list button:nth-child(4){font-size:clamp(15px,1.75vw,30px);letter-spacing:.01em}.work-filter-list button:hover,.work-filter-list button.is-selected{filter:drop-shadow(3px 6px 2px rgba(112,122,124,.17));transform:translateY(2px) rotate(calc((var(--button-index) - 1.5) * -1.5deg)) scale(1.04)}.work-filter-list span{position:relative;z-index:1;display:block;width:100%;text-align:center;transform:translateY(-2%)}.works-sea{position:absolute;z-index:3;right:7.5%;bottom:8%;left:8.4%;height:auto;pointer-events:none}.wave{position:absolute;right:-4%;left:3.3%;border-radius:50% 48% 0 0/34% 34% 0 0;transform-origin:center bottom;will-change:transform}.wave:before,.wave:after{position:absolute;top:-15%;width:42%;height:42%;border-radius:50%;content:""}.wave:before{left:-4%}.wave:after{right:5%}.wave-back{z-index:1;bottom:25%;height:45%;background:#d6effdc7;animation:wave-drift-soft 4.2s ease-in-out infinite alternate}.wave-back:before,.wave-back:after{background:#d6effdc7}.wave-light{z-index:4;bottom:19%;height:34%;background:#9ed8f9db;animation:wave-drift-top 2.8s ease-in-out infinite alternate;transition:bottom .68s cubic-bezier(.18,.84,.28,1),height .68s cubic-bezier(.18,.84,.28,1)}.wave-light:before,.wave-light:after{background:#9ed8f9db}.wave-mid{z-index:3;bottom:9%;height:31%;background:#6fc3f4e6;animation:wave-drift-mid 3.4s ease-in-out infinite alternate-reverse}.wave-mid:before,.wave-mid:after{background:#6fc3f4e6}.wave-front{z-index:5;bottom:0;height:23%;background:#3aa9ed;animation:wave-drift-front 2.6s ease-in-out infinite alternate}.wave-front:before,.wave-front:after{background:#3aa9ed}.paper-boat{position:absolute;z-index:6;top:13%;left:51.5%;width:13%;height:26%;transform-origin:50% 82%;transition:opacity .26s ease,transform .52s ease;animation:boat-float 2.8s ease-in-out infinite alternate}.boat-hull{position:absolute;right:0;bottom:0;left:0;height:50%;background:#9f8154;border-radius:10% 10% 48% 48%/18% 18% 72% 72%;clip-path:polygon(2% 15%,98% 0,82% 73%,28% 96%);filter:drop-shadow(3px 5px 3px rgba(99,78,48,.2))}.boat-mast{position:absolute;bottom:40%;left:50%;width:4%;height:54%;background:#8b744f;transform:rotate(1deg)}.boat-flag{position:absolute;top:4%;left:51%;width:28%;height:25%;background:#bb4d38;clip-path:polygon(0 0,100% 48%,0 100%);filter:drop-shadow(2px 2px 1px rgba(96,60,42,.18))}.poster-gallery{position:absolute;z-index:5;top:14%;right:6.5%;bottom:13.5%;left:16%;opacity:0;pointer-events:none;transition:opacity .36s ease .12s}.poster-frame{position:absolute;margin:0;padding:1.1%;border:0;background:#ffffffeb;box-shadow:0 13px 20px #5287a621;cursor:pointer;opacity:0;transform-origin:50% 50%;transition:filter .18s ease,scale .18s ease,translate .18s ease,box-shadow .18s ease}.poster-frame img{display:block;width:100%;height:100%;object-fit:cover}.poster-1{top:9%;left:1.5%;width:13.8%;height:43%;transform:rotate(4deg);animation:poster-float-a 2.8s ease-in-out infinite alternate}.poster-2{top:44%;left:14.5%;width:13.4%;height:42%;transform:rotate(-1.5deg);animation:poster-float-b 2.6s ease-in-out infinite alternate}.poster-3{top:7%;left:28.2%;width:14.2%;height:44%;transform:rotate(-4deg);animation:poster-float-c 3s ease-in-out infinite alternate}.poster-4{top:39%;left:42.2%;width:13.8%;height:43%;transform:rotate(.5deg);animation:poster-float-b 2.7s ease-in-out infinite alternate-reverse}.poster-5{top:8%;left:55.6%;width:13.7%;height:43%;transform:rotate(-6deg);animation:poster-float-a 2.9s ease-in-out infinite alternate-reverse}.poster-6{top:43%;left:68.2%;width:13.5%;height:42%;transform:rotate(3.5deg);animation:poster-float-c 2.6s ease-in-out infinite alternate-reverse}.poster-7{top:10%;left:80.5%;width:13.1%;height:41%;transform:rotate(-2.8deg);animation:poster-float-b 3s ease-in-out infinite alternate}.poster-8{top:49%;left:87.7%;width:12.4%;height:39%;transform:rotate(5.5deg);animation:poster-float-a 2.7s ease-in-out infinite alternate}.poster-frame:hover,.poster-frame:focus-visible{z-index:8;filter:saturate(1.05);outline:none;scale:1.12;translate:0 -7%;box-shadow:0 22px 30px #2d678b40}.works-page.is-poster-open .wave-light{bottom:47%;height:24%}.works-page.is-poster-open .paper-boat{opacity:0;transform:translateY(-26%) scale(.9);animation-play-state:paused}.works-page.is-poster-open .poster-gallery{opacity:1;pointer-events:auto}.works-page.is-poster-open .poster-frame{opacity:1}.design-gallery{position:absolute;z-index:5;top:14%;right:6.2%;bottom:9%;left:16%;opacity:0;pointer-events:none;transition:opacity .82s cubic-bezier(.18,.84,.28,1)}.design-gallery.is-visible{opacity:1;pointer-events:none}.tweet-fish-school{position:absolute;z-index:5;top:18%;right:5.6%;bottom:13%;left:17%;opacity:0;pointer-events:none;transition:opacity .32s ease}.tweet-fish-school.is-visible{opacity:1;pointer-events:auto;transition-duration:.46s;transition-delay:.12s}.tweet-fish{--fish-color: #f8e88d;--fish-accent: #f2be2a;--fish-direction: 1;--fish-travel-x: 32px;--fish-travel-y: 12px;position:absolute;width:clamp(54px,6.8vw,116px);aspect-ratio:2.1 / 1;border:0;padding:0;background:transparent;cursor:pointer;color:#486a7f;text-decoration:none;filter:drop-shadow(0 7px 5px rgba(27,99,147,.16));transform:translate(-50%,-50%) scale(var(--fish-scale, 1)) rotate(var(--fish-rotate, 0deg));transition:filter .16s ease,scale .16s ease;animation:fish-swim var(--fish-duration, 4.2s) ease-in-out infinite alternate;animation-delay:calc(var(--fish-index) * -.19s)}.tweet-fish:hover,.tweet-fish:focus-visible{outline:none;filter:drop-shadow(0 11px 7px rgba(27,99,147,.2)) saturate(1.08);scale:1.08}.fish-shape{position:absolute;top:0;right:0;bottom:0;left:0;transform:scaleX(var(--fish-direction));transform-origin:center}.fish-body{position:absolute;top:13%;right:18%;bottom:11%;left:11%;border-radius:58% 48% 48% 58%/58% 50% 50% 58%;background:radial-gradient(circle at 72% 37%,rgba(255,255,255,.76) 0 7%,transparent 8%),linear-gradient(135deg,rgba(255,255,255,.45),transparent 48%),var(--fish-color);box-shadow:inset -8px -6px #eeb62424;animation:fish-body-bob .92s ease-in-out infinite alternate}.fish-tail{position:absolute;top:21%;left:0;width:27%;height:58%;background:var(--fish-accent);clip-path:polygon(100% 50%,0 0,20% 50%,0 100%);transform-origin:100% 50%;animation:fish-tail-wag .42s ease-in-out infinite alternate}.fish-eye{position:absolute;top:34%;right:25%;width:6%;aspect-ratio:1;border-radius:50%;background:#3e5c68b8}.tweet-fish-card{position:absolute;z-index:4;bottom:calc(100% + 9px);left:50%;display:grid;width:clamp(220px,22vw,340px);gap:5px;border:1px solid rgba(79,132,161,.22);border-radius:8px;padding:13px 15px;background:#fffff8e6;box-shadow:0 14px 24px #265d7e2e;color:#486a7f;font-family:Microsoft YaHei,sans-serif;font-size:clamp(14px,1.15vw,18px);line-height:1.42;opacity:0;pointer-events:none;text-align:left;transform:translate(-50%) translateY(6px);transition:opacity .15s ease,transform .15s ease}.tweet-fish-card:after{position:absolute;bottom:-6px;left:50%;width:11px;height:11px;background:#fffff8e6;border-right:1px solid rgba(79,132,161,.18);border-bottom:1px solid rgba(79,132,161,.18);content:"";transform:translate(-50%) rotate(45deg)}.tweet-fish:hover .tweet-fish-card,.tweet-fish:focus-visible .tweet-fish-card{opacity:1;transform:translate(-50%) translateY(0)}.tweet-fish-title{overflow:hidden;color:#315f83;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.tweet-fish-1{--fish-accent: #f2be2a;--fish-color: #f8e88d;--fish-duration: 4.1s;--fish-scale: .96;--fish-travel-x: 42px;--fish-travel-y: 14px;--fish-rotate: -6deg;top:18%;left:15%}.tweet-fish-2{--fish-accent: #ef8f75;--fish-color: #ffd1bd;--fish-duration: 3.4s;--fish-direction: -1;--fish-scale: .78;--fish-travel-x: 36px;--fish-travel-y: 18px;--fish-rotate: 7deg;top:29%;left:33%}.tweet-fish-3{--fish-accent: #78b7cf;--fish-color: #bfeaf2;--fish-duration: 4.8s;--fish-scale: 1.08;--fish-travel-x: 50px;--fish-travel-y: 10px;--fish-rotate: 3deg;top:18%;left:53%}.tweet-fish-4{--fish-accent: #f0b442;--fish-color: #ffe7a6;--fish-duration: 3.7s;--fish-direction: -1;--fish-scale: .86;--fish-travel-x: 40px;--fish-travel-y: 16px;--fish-rotate: -8deg;top:31%;left:73%}.tweet-fish-5{--fish-accent: #8ec86f;--fish-color: #d8f2b5;--fish-duration: 4.5s;--fish-scale: .72;--fish-travel-x: 34px;--fish-travel-y: 20px;--fish-rotate: -2deg;top:43%;left:20%}.tweet-fish-6{--fish-accent: #d989c6;--fish-color: #f5c6ea;--fish-duration: 3.9s;--fish-direction: -1;--fish-scale: .98;--fish-travel-x: 48px;--fish-travel-y: 13px;--fish-rotate: 5deg;top:50%;left:43%}.tweet-fish-7{--fish-accent: #6fb7e7;--fish-color: #c9ecff;--fish-duration: 4.6s;--fish-scale: .76;--fish-travel-x: 38px;--fish-travel-y: 17px;--fish-rotate: -5deg;top:45%;left:62%}.tweet-fish-8{--fish-accent: #f29a4a;--fish-color: #ffd8a8;--fish-duration: 3.5s;--fish-direction: -1;--fish-scale: 1.02;--fish-travel-x: 52px;--fish-travel-y: 15px;--fish-rotate: 8deg;top:55%;left:84%}.tweet-fish-9{--fish-accent: #e7c84c;--fish-color: #fff2a8;--fish-duration: 4.4s;--fish-scale: .9;--fish-travel-x: 44px;--fish-travel-y: 18px;--fish-rotate: 4deg;top:70%;left:28%}.tweet-fish-10{--fish-accent: #7fc0af;--fish-color: #c8f0e4;--fish-duration: 3.6s;--fish-direction: -1;--fish-scale: .74;--fish-travel-x: 36px;--fish-travel-y: 22px;--fish-rotate: -7deg;top:77%;left:49%}.tweet-fish-11{--fish-accent: #9b9adf;--fish-color: #d9d8ff;--fish-duration: 4.9s;--fish-scale: .88;--fish-travel-x: 46px;--fish-travel-y: 12px;--fish-rotate: 2deg;top:69%;left:68%}.tweet-fish-12{--fish-accent: #ed7f92;--fish-color: #ffc5cf;--fish-duration: 3.8s;--fish-direction: -1;--fish-scale: .7;--fish-travel-x: 42px;--fish-travel-y: 16px;--fish-rotate: -4deg;top:80%;left:88%}.ai-sticker-board{position:absolute;z-index:5;top:18%;right:10.5%;bottom:13.5%;left:20%;opacity:0;pointer-events:none;transition:opacity .26s ease}.ai-sticker-board.is-visible{opacity:1;pointer-events:auto;transition-delay:.18s}.ai-sticker{position:absolute;aspect-ratio:var(--sticker-ratio);margin:0;border:0;border-radius:6px;padding:clamp(4px,.38vw,7px);background:#fffdf3;box-shadow:0 13px 22px #285e802e,inset 0 0 0 1px #f4e09699;cursor:pointer;opacity:0;transform:translateY(-95%) rotate(var(--sticker-rotate, 0deg)) scale(.92);transform-origin:50% 12%;transition:box-shadow .18s ease,filter .18s ease,scale .18s ease,translate .18s ease;animation:sticker-fall .76s cubic-bezier(.18,.94,.18,1.04) both;animation-delay:calc(.18s + var(--sticker-index) * 92ms)}.ai-sticker img{display:block;width:100%;height:100%;border-radius:3px;object-fit:contain}.sticker-pin{position:absolute;z-index:2;top:clamp(-7px,-.62vw,-4px);left:50%;width:clamp(14px,1.45vw,24px);aspect-ratio:1;border-radius:50%;background:radial-gradient(circle at 36% 31%,rgba(255,255,255,.85) 0 16%,transparent 17%),var(--pin-color);box-shadow:0 4px #465c6829,0 7px 9px #465c6838;transform:translate(-50%);animation:pin-pop .36s cubic-bezier(.25,1.4,.42,1) both;animation-delay:calc(.62s + var(--sticker-index) * 92ms)}.sticker-pin:after{position:absolute;right:16%;bottom:-22%;width:20%;height:38%;border-radius:50%;background:#45505647;content:"";transform:rotate(-26deg)}.ai-sticker:hover,.ai-sticker:focus-visible{z-index:9;outline:none;filter:saturate(1.06);scale:1.055;translate:0 -4%;box-shadow:0 22px 34px #2356783d,inset 0 0 0 1px #f4e096b3}.ai-sticker-1:hover,.ai-sticker-1:focus-visible,.ai-sticker-2:hover,.ai-sticker-2:focus-visible,.ai-sticker-8:hover,.ai-sticker-8:focus-visible,.ai-sticker-9:hover,.ai-sticker-9:focus-visible{scale:1.035}.ai-sticker-1{--sticker-rotate: -7deg;top:4%;left:4%;width:12.2%}.ai-sticker-2{--sticker-rotate: 4.5deg;top:46%;left:8%;width:11.8%}.ai-sticker-3{--sticker-rotate: 7deg;top:9%;left:24%;width:11.8%}.ai-sticker-4{--sticker-rotate: -3deg;top:50%;left:30%;width:11%}.ai-sticker-5{--sticker-rotate: 5.8deg;top:5%;left:45%;width:11.2%}.ai-sticker-6{--sticker-rotate: -6deg;top:48%;left:50%;width:10.9%}.ai-sticker-7{--sticker-rotate: 3deg;top:10%;left:64%;width:11.4%}.ai-sticker-8{--sticker-rotate: -4.6deg;top:51%;left:67%;width:11.4%}.ai-sticker-9{--sticker-rotate: 6.4deg;top:27%;left:82%;width:10.8%}.works-page.is-ai-open .works-sea{filter:saturate(1.05)}.design-frame{position:absolute;margin:0;border:4px solid #fff;padding:0;background:transparent;box-shadow:0 14px 22px #5287a624;cursor:pointer;overflow:hidden;pointer-events:auto;transition:box-shadow .18s ease,scale .18s ease,translate .18s ease}.design-1,.design-2,.design-3,.design-4{aspect-ratio:1;border-radius:50%}.design-frame:after{position:absolute;top:0;right:0;bottom:0;left:0;background:#fff0;content:"";pointer-events:none;transition:background .16s ease}.design-gallery:hover .design-frame:not(:hover):after{background:#ffffff4d}.design-frame:hover,.design-frame:focus-visible{z-index:8;outline:none;scale:1.035;translate:0 -2%;box-shadow:0 22px 34px #2d678b33}.design-frame img{display:block;width:100%;height:100%;object-fit:contain}.design-1 img,.design-2 img,.design-3 img,.design-4 img{padding:0}.design-5 img{object-fit:cover}.design-1{top:18.5%;left:8.2%;width:9.2%;height:auto;animation:design-bubble-float-a 3.2s ease-in-out infinite alternate}.design-2{top:14%;left:30.2%;width:10.6%;height:auto;animation:design-bubble-float-b 3.6s ease-in-out infinite alternate-reverse}.design-3{top:16.8%;left:53.8%;width:8.8%;height:auto;animation:design-bubble-float-c 3.4s ease-in-out infinite alternate}.design-4{top:13.8%;left:76.2%;width:9.8%;height:auto;animation:design-bubble-float-a 3.8s ease-in-out infinite alternate-reverse}.poster-lightbox{position:absolute;z-index:30;top:0;right:0;bottom:0;left:0;display:grid;padding:6vh 6vw;place-items:center;background:#254e6a47;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.poster-lightbox img{display:block;max-width:min(86vw,1080px);max-height:90vh;border:10px solid rgba(255,255,255,.95);background:#fff;box-shadow:0 28px 60px #1e435b52;object-fit:contain;animation:poster-lightbox-enter .18s ease both}.poster-lightbox.is-transparent-preview img{border:0;background:transparent;box-shadow:none}.poster-lightbox-close{position:absolute;top:8%;right:11%;width:42px;height:42px;border:0;border-radius:50%;background:#ffffffe0;color:#477397;cursor:pointer;font-family:Arial,sans-serif;font-size:30px;line-height:1;box-shadow:0 10px 24px #2d678b2e}.works-page .works-sea{z-index:3;top:18.7%;right:1.15%;bottom:7.7%;left:1.25%;height:auto;overflow:hidden}.works-page.is-design-open .works-sea{pointer-events:auto}.works-frame-overlay{position:absolute;z-index:6;top:0;right:0;bottom:0;left:0;display:block;width:100%;height:100%;object-fit:fill;pointer-events:none}.wave-image{position:absolute;bottom:0;left:-2%;width:104%;height:26%;object-fit:fill;border-radius:0;background:transparent;pointer-events:none;will-change:transform}.wave-image.wave-back{z-index:1;bottom:27%;height:41%;animation:image-wave-back 5s ease-in-out infinite alternate}.wave-image.wave-light{z-index:3;bottom:15%;height:34%;animation:image-wave-light 3.4s ease-in-out infinite alternate;transition:opacity .26s ease,transform .34s ease}.wave-image.wave-mid{z-index:4;bottom:7%;height:29%;animation:image-wave-mid 3.8s ease-in-out infinite alternate-reverse}.wave-image.wave-front{z-index:6;bottom:0;height:25%;animation:image-wave-front 3.1s ease-in-out infinite alternate}.wave-image.poster-curtain{z-index:2;bottom:0;height:180%;opacity:0;transform:translateY(47%);transition:opacity .16s ease,transform .72s cubic-bezier(.2,.82,.24,1)}.works-page .paper-boat{z-index:2;top:60.5%;left:51.5%;width:9.4%;height:17.8%;animation:boat-float-with-third-wave 3.9s ease-in-out infinite alternate-reverse}.design-feature{position:absolute;z-index:3;left:34%;bottom:8.5%;width:36%;aspect-ratio:2200 / 1037;border:4px solid #fff;padding:0;background:transparent;box-shadow:0 14px 22px #5287a624;cursor:pointer;overflow:hidden;pointer-events:auto;transition:box-shadow .18s ease,scale .18s ease,translate .18s ease}.design-feature:hover,.design-feature:focus-visible{outline:none;scale:1.025;translate:0 -1.5%;box-shadow:0 22px 34px #2d678b33}.design-feature img{display:block;width:100%;height:100%;object-fit:cover}.works-page.is-poster-open .wave-image.wave-back{opacity:0}.works-page.is-poster-open .wave-image.poster-curtain{opacity:1;transform:translateY(0)}.works-page.is-poster-open .wave-image.wave-light,.works-page.is-poster-open .wave-image.wave-mid,.works-page.is-poster-open .wave-image.wave-front{animation:none;transform:none}.works-page.is-poster-open .paper-boat{opacity:0;transform:translateY(-16%) scale(.9);animation-play-state:paused}.works-page.is-poster-open .poster-gallery{transition-delay:.32s}.wave-layer{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:fill;pointer-events:none;transform-origin:center bottom;will-change:transform}.wave-layer.wave-bottom{z-index:1;animation:user-wave-bottom 4.5s ease-in-out infinite alternate}.wave-layer.wave-third{z-index:2;animation:user-wave-third 3.9s ease-in-out infinite alternate-reverse}.wave-layer.wave-second{z-index:4;animation:user-wave-second 3.5s ease-in-out infinite alternate}.wave-layer.wave-top{z-index:5;animation:user-wave-top 3.1s ease-in-out infinite alternate-reverse}.works-page.is-layer-open .wave-layer{animation:none;transform:none}.works-page.is-layer-open .wave-layer.is-expanded{animation:wave-rise-to-filter .82s cubic-bezier(.18,.84,.28,1) both}.works-page.is-layer-open .works-sea{top:3.5%;right:1.15%;bottom:7.7%;left:1.25%;height:auto}.works-page.is-layer-open .paper-boat,.paper-boat.is-hidden{opacity:0;transform:translateY(-16%) scale(.9);animation-play-state:paused}.works-page.is-layer-open .poster-gallery{transition-delay:.32s}.skills-page{overflow:hidden}.skills-desk{position:absolute;z-index:1;right:0;bottom:0;left:0;width:100%;height:28%;object-fit:fill;pointer-events:none}.stationery-cup-button{position:absolute;z-index:6;top:auto;bottom:calc(28% - 50px);left:50%;margin:0;width:auto;height:clamp(330px,46vh,470px);aspect-ratio:520 / 920;border:0;padding:0;background:transparent;cursor:pointer;filter:drop-shadow(0 9px 7px rgba(57,100,128,.1));transform:translate(-50%);transform-origin:50% 100%;animation:stationery-cup-idle 2.6s ease-in-out infinite alternate;transition:filter .18s ease,scale .18s ease}.stationery-cup-button:hover,.stationery-cup-button:focus-visible{outline:none;filter:drop-shadow(0 11px 8px rgba(57,100,128,.16));scale:1.025}.stationery-cup-button:active{scale:.985}.stationery-cup-button img{display:block;width:100%;height:100%;object-fit:contain}.skills-page.is-open .stationery-cup-button{animation:stationery-cup-click .52s cubic-bezier(.2,.82,.24,1) both}.skill-labels{position:absolute;z-index:5;top:15%;right:5.5%;bottom:8%;left:5.5%;pointer-events:none}.skill-label{--label-delay: 0ms;--label-rotate: 0deg;--label-x: 0px;--label-y: 0px;position:absolute;display:grid;min-width:clamp(112px,10.5vw,184px);min-height:clamp(42px,5.5vh,62px);place-items:center;border:4px solid var(--label-dot, #5c9fbe);border-radius:48% 52% 46% 54%/18% 13% 17% 12%;padding:7px 20px;background:#ffffffd6;box-shadow:2px 3px #ffffffb8,4px 5px color-mix(in srgb,var(--label-dot, #5c9fbe) 52%,transparent);color:#557d9d;font-family:STKaiti,KaiTi,Microsoft YaHei,serif;font-size:clamp(18px,1.55vw,27px);font-weight:700;letter-spacing:0;line-height:1.05;opacity:0;text-align:center;transform:translate(var(--label-x),var(--label-y)) rotate(var(--label-rotate)) scale(.45);transform-origin:center;transition:opacity .21s ease var(--label-delay),transform .62s cubic-bezier(.16,.88,.22,1.08) var(--label-delay)}.skill-label:before{position:absolute;top:50%;width:clamp(40px,5vw,88px);height:5px;border-radius:50%;background:repeating-linear-gradient(90deg,var(--label-dot, #5c9fbe) 0 10px,transparent 10px 14px);filter:drop-shadow(0 2px 0 color-mix(in srgb,var(--label-dot, #5c9fbe) 35%,transparent));content:""}.skill-label:after{position:absolute;top:8px;width:9px;height:9px;border-radius:50%;border:4px solid var(--label-dot, #5c9fbe);background:#ffffffb3;box-shadow:2px 2px color-mix(in srgb,var(--label-dot, #5c9fbe) 38%,transparent);content:""}.skill-label-left{left:39%}.skill-label-left:before{left:calc(100% - 2px);transform-origin:left center}.skill-label-left:after{right:9px}.skill-label-right{right:39%}.skill-label-right:before{right:calc(100% - 2px);transform-origin:right center}.skill-label-right:after{left:9px}.skills-page.is-open .skill-label{opacity:1;transform:translate(0) rotate(var(--label-rotate)) scale(1)}.skill-label-left-1{--label-delay: 60ms;--label-dot: #ef8f75;--label-rotate: -3deg;top:6%;left:17%}.skill-label-left-2{--label-delay: .12s;--label-dot: #f2be2a;--label-rotate: 2deg;top:19%;left:22%}.skill-label-left-3{--label-delay: .18s;--label-dot: #69b5dd;--label-rotate: -1.5deg;top:32%;left:15%}.skill-label-left-4{--label-delay: .24s;--label-dot: #79be83;--label-rotate: 3.2deg;top:45%;left:23%}.skill-label-left-5{--label-delay: .3s;--label-dot: #c887e8;--label-rotate: -2.2deg;top:57%;left:17%}.skill-label-left-6{--label-delay: .36s;--label-dot: #ef7aa6;--label-rotate: 1.2deg;top:68%;left:24%;min-width:clamp(140px,12vw,210px)}.skill-label-right-1{--label-delay: 90ms;--label-dot: #54c4b7;--label-rotate: 2.5deg;top:10%;right:16%}.skill-label-right-2{--label-delay: .16s;--label-dot: #8b95f2;--label-rotate: -2deg;top:25%;right:22%;min-width:clamp(150px,13vw,225px)}.skill-label-right-3{--label-delay: .23s;--label-dot: #ff9a4f;--label-rotate: 3.2deg;top:40%;right:15%}.skill-label-right-4{--label-delay: .3s;--label-dot: #ef8f75;--label-rotate: -1deg;top:54%;right:24%}.skill-label-right-5{--label-delay: .37s;--label-dot: #69b5dd;--label-rotate: 2deg;top:67%;right:16%;min-width:clamp(160px,14vw,240px)}.skills-page:not(.is-open) .skill-label-left{--label-x: clamp(230px, 27vw, 480px);--label-y: 16px}.skills-page:not(.is-open) .skill-label-right{--label-x: clamp(-480px, -27vw, -230px);--label-y: 16px}.skills-frame-overlay{position:absolute;z-index:8;top:0;right:0;bottom:0;left:0;display:block;width:100%;height:100%;object-fit:fill;pointer-events:none}.projects-page{overflow:hidden}.project-canvas{position:absolute;z-index:0;top:0;right:0;bottom:0;left:0;width:100%;height:100%;overflow:hidden;pointer-events:none}.project-canvas canvas{display:block;width:100%!important;height:100%!important}.project-line-map{position:absolute;z-index:3;top:23%;right:7.5%;bottom:12%;left:8.5%}.project-line-art{position:absolute;top:0;right:0;bottom:0;left:0;display:block;width:100%;height:100%;overflow:visible}.project-pencil-line{fill:none;stroke-linecap:round;stroke-linejoin:round;vector-effect:non-scaling-stroke}.project-pencil-line-base{stroke:#4389b8b8;stroke-width:5.5}.project-pencil-line-light{stroke:#74b8da75;stroke-dasharray:22 5 8 4;stroke-width:2.5}.project-pencil-line-grain{stroke:#2b74a657;stroke-dasharray:3 7 17 5;stroke-width:1.8}.project-drop{position:absolute;width:clamp(52px,5.2vw,82px);aspect-ratio:.78;border:0;padding:0;background:transparent;color:#3f779d;cursor:pointer;filter:drop-shadow(0 8px 8px rgba(69,128,164,.16));transform:translate(-50%,-50%);transition:filter .18s ease,scale .18s ease}.project-drop:hover,.project-drop:focus-visible{z-index:7;outline:none;filter:drop-shadow(0 13px 11px rgba(69,128,164,.24));scale:1.07}.project-drop-shape{position:absolute;top:8%;right:4%;bottom:5%;left:4%;border:4px solid rgba(55,132,181,.82);border-radius:50% 50% 50% 0;background:repeating-linear-gradient(16deg,#6bb9dc80 0,#6bb9dc80 3px,#96d3eb61 3px,#96d3eb61 7px,#fff3 7px,#fff3 9px);box-shadow:inset 3px -2px #307eb12e,2px 2px #59a4cc3d;transform:rotate(135deg)}.project-number{position:absolute;z-index:1;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:#39759c;font-family:Microsoft YaHei,sans-serif;font-size:clamp(13px,1.15vw,18px);font-weight:700;letter-spacing:0;transform:translateY(8%)}.project-drop-1{top:29%;left:24.4%}.project-drop-2{top:68%;left:46.3%}.project-drop-3{top:20.5%;left:68.2%}.project-popover{position:absolute;z-index:8;display:grid;width:clamp(300px,26vw,410px);gap:8px;border:1px solid rgba(87,151,190,.32);border-radius:8px;padding:18px 20px;background:#f8fdffd1;box-shadow:0 18px 34px #3670952e;color:#527c98;font-family:Microsoft YaHei,sans-serif;opacity:0;pointer-events:none;text-align:left;transform:translateY(10px) scale(.97);transition:opacity .18s ease,transform .22s ease;-webkit-backdrop-filter:blur(7px);backdrop-filter:blur(7px)}.project-popover strong{color:#356d95;font-size:clamp(18px,1.45vw,24px);letter-spacing:0;line-height:1.25}.project-popover em{width:max-content;border-radius:3px;padding:3px 9px;background:#fbde6885;color:#8b7745;font-size:clamp(12px,.9vw,15px);font-style:normal;font-weight:700;letter-spacing:0}.project-popover>span{color:#52758d;font-size:clamp(13px,1vw,16px);letter-spacing:0;line-height:1.72}.project-drop-1 .project-popover{top:calc(100% + 16px);left:8%}.project-drop-2 .project-popover{right:8%;bottom:calc(100% + 16px)}.project-drop-3 .project-popover{top:calc(100% + 18px);right:calc(100% + 18px);transform:translate(10px) scale(.97)}.project-drop:hover .project-popover,.project-drop:focus-visible .project-popover{opacity:1;transform:translateY(0) scale(1)}.project-drop-3:hover .project-popover,.project-drop-3:focus-visible .project-popover{transform:translate(0) scale(1)}.project-frame-overlay{position:absolute;z-index:4;top:0;right:0;bottom:0;left:0;display:block;width:100%;height:100%;object-fit:fill;pointer-events:none}.archive-page{display:grid;padding-top:9%;place-items:center}.archive-card{width:min(760px,70%);border:2px dashed #a8c8df;padding:4% 6%;background:#fff9e1e0;color:#65859d;text-align:center}.archive-card h1{margin:0 0 2%;color:#477397;font-size:clamp(42px,5vw,76px);font-weight:400}.archive-card p,.archive-card span{font-size:clamp(18px,1.7vw,28px);line-height:1.6}.archive-card span{color:#a99370}.contact-popover{position:absolute;z-index:20;top:26.5%;left:73.5%;width:min(380px,23%);border:1px solid rgba(91,128,157,.3);border-radius:10px;padding:2.2% 2.7%;background:#ffffff80;box-shadow:0 10px 28px #3c5e781f;color:#315f83;font-family:Microsoft YaHei,sans-serif;animation:popover-enter .18s ease both}.contact-popover a,.contact-popover p{display:block;margin:8px 0;color:#315f83;cursor:text;font-size:clamp(13px,1.15vw,18px);text-decoration:none;-webkit-user-select:text;user-select:text}.close-button{position:absolute;top:4px;right:9px;border:0;background:transparent;color:#315f83;cursor:pointer;font-size:25px}.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}@keyframes bubble-wiggle{0%{transform:translateY(-18px) rotate(-3.5deg)}to{transform:translateY(18px) rotate(3.5deg)}}@keyframes popover-enter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes poster-lightbox-enter{0%{opacity:0;transform:translateY(18px) scale(.96) rotate(-1deg)}to{opacity:1;transform:translateY(0) scale(1) rotate(0)}}@keyframes design-bubble-float-a{0%{translate:-3% 3.2%}to{translate:3.4% -4.4%}}@keyframes design-bubble-float-b{0%{translate:2.8% -3.2%}to{translate:-3.2% 4.8%}}@keyframes design-bubble-float-c{0%{translate:-2.4% -2.8%}to{translate:3% 4.2%}}@keyframes fish-swim{0%{transform:translate(-50%,-50%) translate(calc(var(--fish-direction) * var(--fish-travel-x) * -.5)) translateY(calc(var(--fish-travel-y) * -.5)) scale(var(--fish-scale, 1)) rotate(calc(var(--fish-rotate, 0deg) - 3deg))}to{transform:translate(-50%,-50%) translate(calc(var(--fish-direction) * var(--fish-travel-x) * .5)) translateY(calc(var(--fish-travel-y) * .5)) scale(var(--fish-scale, 1)) rotate(calc(var(--fish-rotate, 0deg) + 3deg))}}@keyframes fish-tail-wag{0%{transform:rotate(-15deg) scaleX(.92)}to{transform:rotate(17deg) scaleX(1.06)}}@keyframes fish-body-bob{0%{translate:0 -1px}to{translate:0 1px}}@keyframes wave-drift-soft{0%{transform:translate(-1.5%) translateY(0)}to{transform:translate(1.5%) translateY(-4%)}}@keyframes wave-drift-top{0%{transform:translate(-2.4%) translateY(-2%)}to{transform:translate(2.4%) translateY(3%)}}@keyframes wave-drift-mid{0%{transform:translate(2%) translateY(0)}to{transform:translate(-2%) translateY(5%)}}@keyframes wave-drift-front{0%{transform:translate(-1%) translateY(1%)}to{transform:translate(1.6%) translateY(-3%)}}@keyframes image-wave-back{0%{transform:translate(-2.2%) translateY(0)}to{transform:translate(2.4%) translateY(-3.2%)}}@keyframes image-wave-light{0%{transform:translate(-3.2%) translateY(-2.6%)}to{transform:translate(3.2%) translateY(3.8%)}}@keyframes image-wave-mid{0%{transform:translate(2.6%) translateY(1.6%)}to{transform:translate(-2.6%) translateY(-3.2%)}}@keyframes image-wave-front{0%{transform:translate(-2.2%) translateY(.8%)}to{transform:translate(2.6%) translateY(-3.8%)}}@keyframes boat-float{0%{transform:translate(-5%) translateY(-8%) rotate(-2deg)}to{transform:translate(5%) translateY(9%) rotate(2deg)}}@keyframes boat-float-with-wave{0%{transform:translate(-5%) translateY(-5%) rotate(-2deg)}to{transform:translate(5%) translateY(6%) rotate(2deg)}}@keyframes boat-float-with-third-wave{0%{transform:translate(-34%) translateY(1.4%) rotate(-2.4deg)}to{transform:translate(36%) translateY(-3.2%) rotate(2.4deg)}}@keyframes wave-rise-to-filter{0%{transform:translateY(47%)}to{transform:translateY(0)}}@keyframes user-wave-bottom{0%{transform:translate(-2.2%) translateY(.8%)}to{transform:translate(2.4%) translateY(-3.6%)}}@keyframes user-wave-third{0%{transform:translate(2.3%) translateY(1.4%)}to{transform:translate(-2.2%) translateY(-3.2%)}}@keyframes user-wave-second{0%{transform:translate(-2.8%) translateY(-2.6%)}to{transform:translate(2.8%) translateY(3.8%)}}@keyframes user-wave-top{0%{transform:translate(2.4%) translateY(1.8%)}to{transform:translate(-2.6%) translateY(-3.8%)}}@keyframes poster-float-a{0%{translate:0 -3.2%}to{translate:0 4%}}@keyframes poster-float-b{0%{translate:0 3.6%}to{translate:0 -4%}}@keyframes poster-float-c{0%{translate:0 -4.2%}to{translate:0 3.4%}}@keyframes sticker-fall{0%{opacity:0;transform:translateY(-95%) rotate(calc(var(--sticker-rotate) - 16deg)) scale(.88)}68%{opacity:1;transform:translateY(5.5%) rotate(calc(var(--sticker-rotate) + 2.4deg)) scale(1.015)}84%{opacity:1;transform:translateY(-1.8%) rotate(calc(var(--sticker-rotate) - .7deg)) scale(1)}to{opacity:1;transform:translateY(0) rotate(var(--sticker-rotate)) scale(1)}}@keyframes pin-pop{0%{opacity:0;transform:translate(-50%) translateY(-12px) scale(1.35)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}@keyframes stationery-cup-idle{0%{transform:translate(-50%) rotate(-.55deg)}to{transform:translate(-50%) rotate(.55deg)}}@keyframes stationery-cup-click{0%{transform:translate(-50%) rotate(0)}35%{transform:translate(-50%) rotate(-3deg) scale(.98)}68%{transform:translate(-50%) rotate(2.4deg) scale(1.015)}to{transform:translate(-50%) rotate(0) scale(1)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media(max-width:768px),(pointer:coarse){.project-line-map{top:29%;right:7%;bottom:10%;left:7%}.project-line-art{display:none}.project-drop{position:relative;top:auto;left:auto;display:block;width:48px;margin:0 0 19vh 18%;transform:none}.project-drop:nth-of-type(3){margin-left:64%}.project-drop:nth-of-type(4){margin-left:30%}.project-popover,.project-drop-1 .project-popover,.project-drop-2 .project-popover,.project-drop-3 .project-popover{top:50%;right:auto;bottom:auto;left:calc(100% + 12px);width:min(68vw,330px);transform:translateY(-50%) translate(8px) scale(.97)}.project-drop:hover .project-popover,.project-drop:focus-visible .project-popover,.project-drop-3:hover .project-popover,.project-drop-3:focus-visible .project-popover{transform:translateY(-50%) translate(0) scale(1)}}
