:root{--bg:#fff;--text:#111;--muted:#1119;--border:#1111111f;--shadow:0 12px 30px #00000014;--container:1040px;--gutter:clamp(64px, 4vw, 44px);--header-h:64px;--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px);text-rendering:geometricprecision;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--text);background:var(--bg);font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Arial,sans-serif;font-size:14px;line-height:1.55}*,:before,:after{box-sizing:border-box}body{min-height:100svh;margin:0;overflow-x:hidden}a{color:inherit;text-decoration:none}:focus-visible{outline-offset:3px;outline:2px solid #1111118c}img,video{max-width:100%;display:block}#root{flex-direction:column;min-height:100svh;display:flex}.container{width:min(var(--container), 100%);padding:0 var(--gutter);margin:0 auto}.main{padding-top:calc(var(--header-h) + var(--safe-top) + 36px);flex:1;padding-bottom:72px}.home-mode .main{padding-top:0;padding-bottom:0}.home-mode .site-footer{display:none}.home-mode .site-header{-webkit-backdrop-filter:none;backdrop-filter:none;background:0 0}.home-mode .menu-toggle{color:#ffffffeb}.home-mode .nav-link{color:#ffffffb3}.home-mode .nav-link:hover{color:#fff}.home-mode .nav-link-active{background:#fff;color:#000!important}.home-mode .lang-switch{background:0 0;border-color:#ffffff26}.home-mode .lang-option{color:#ffffff80}.home-mode .lang-option+.lang-option{border-left-color:#ffffff26}.home-mode .lang-option-active{color:#fff;background:#ffffff1a}.home-mode .brand-mark,.home-mode .brand{color:#ffffffd9}.home-loading{z-index:9999;opacity:1;pointer-events:all;background:#000;place-items:center;transition:opacity .8s cubic-bezier(.16,1,.3,1);display:grid;position:fixed;inset:0}.home-loading.hidden{opacity:0;pointer-events:none}.lusion-loader-container{flex-direction:column;align-items:center;gap:20px;display:flex}.lusion-progress{color:#ffffff73;letter-spacing:.15em;font-family:monospace;font-size:11px;font-weight:300}.lusion-loader{justify-content:center;align-items:center;width:60px;height:60px;display:flex;position:relative}.lusion-loader:before{content:"";background:#fff;border-radius:50%;width:6px;height:6px;animation:2s cubic-bezier(.77,0,.175,1) infinite lusion-pulse-dot;position:absolute}.lusion-loader:after{content:"";border:1px solid #ffffff26;border-radius:50%;width:100%;height:100%;animation:2s cubic-bezier(.215,.61,.355,1) infinite lusion-pulse-ring;position:absolute}@keyframes lusion-pulse-dot{0%{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.5);box-shadow:0 0 15px #fffc}to{opacity:.3;transform:scale(.8)}}@keyframes lusion-pulse-ring{0%{opacity:0;border-width:2px;transform:scale(.1)}50%{opacity:1}to{opacity:0;border-width:.5px;transform:scale(1.2)}}.home-mode{--home-scroll:0;overflow:hidden}body.home-mode{overflow:hidden}html.home-mode,body.home-mode{background:#000}@media (width<=768px){.hidden-on-mobile{display:none!important}}.home-mode .site-header{transition:background .42s,-webkit-backdrop-filter .42s,backdrop-filter .42s,border-color .42s,box-shadow .42s}.home-mode.home-scrolled .site-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0000008c;border-bottom-color:#ffffff1f;box-shadow:0 10px 30px #00000059}.home-mode .particle-text{opacity:calc(1 - (var(--home-scroll) * .55));transition:opacity .5s}.home-mode .cursor-hint.visible{opacity:calc(1 - (var(--home-scroll) * .85))}.home-page{background:#000;display:block;position:fixed;inset:0;overflow:hidden}.home-mode .home-page{background:#000}.video-bg{object-fit:cover;z-index:0;pointer-events:none;background:#000;width:100%;height:100%;position:absolute;inset:0}.glass-cta-button{left:50%;bottom:calc(70px + var(--safe-bottom));opacity:0;-webkit-backdrop-filter:blur(25px)saturate(200%);cursor:pointer;z-index:25;pointer-events:none;background:linear-gradient(135deg,#fff3,#ffffff0d);border:.5px solid #fff3;padding:14px 40px;transition:opacity 1.2s cubic-bezier(.23,1,.32,1),transform 1.2s cubic-bezier(.23,1,.32,1),background .4s cubic-bezier(.23,1,.32,1),border-color .4s cubic-bezier(.23,1,.32,1);position:fixed;transform:translate(-50%)translateY(30px);box-shadow:0 12px 40px #0006,inset 0 0 0 1px #ffffff1a}.glass-cta-button.visible{opacity:1;pointer-events:auto;animation:1.4s cubic-bezier(.34,1.56,.64,1) glass-float-in,5s ease-in-out 3s infinite glass-jump;transform:translate(-50%)translateY(0)}@keyframes glass-jump{0%,to,80%{transform:translate(-50%)translateY(0)}85%{transform:translate(-50%)translateY(-10px)}90%{transform:translate(-50%)translateY(0)}95%{transform:translate(-50%)translateY(-4px)}}@keyframes glass-float-in{0%{opacity:0;transform:translate(-50%)translateY(40px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.glass-cta-text{color:#fff;letter-spacing:.08em;text-transform:uppercase;text-shadow:0 1px 2px #0003;font-size:15px;font-weight:600;transition:color .4s cubic-bezier(.23,1,.32,1)}.glass-cta-button:hover{background:#fff;border-color:#fff;box-shadow:0 15px 45px #00000080}.glass-cta-button:hover .glass-cta-text{color:#222;text-shadow:none}.home-logo .brand-mark{color:#fff;letter-spacing:.05em;text-align:center;font-size:clamp(28px,6vw,64px);font-weight:800;line-height:1.05}.site-header{height:calc(var(--header-h) + var(--safe-top));padding-top:var(--safe-top);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:20;background:#ffffffeb;border-bottom:1px solid #0000;position:fixed;top:0;left:0;right:0}.header-inner{height:var(--header-h);justify-content:space-between;align-items:center;gap:24px;display:flex;position:relative}.brand{letter-spacing:.05em;font-weight:800}.brand-hidden{opacity:0;pointer-events:none}.header-title{letter-spacing:.2px;color:var(--text);white-space:nowrap;pointer-events:none;font-size:14px;font-weight:500;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@media (width>=769px){.brand-hidden{opacity:1;pointer-events:auto}.header-title{display:none}}.brand-mark{white-space:nowrap;font-size:18px;line-height:1}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.nav{align-items:center;gap:52px;display:flex}.nav-list{align-items:center;gap:4px;margin:0;padding:0;list-style:none;display:flex}.nav-link{color:var(--muted);letter-spacing:.2px;border-radius:0;padding:3px 12px;font-size:14px;transition:all .2s}.nav-link:hover{color:var(--text)}.nav-link-active{background:#222;color:#fff!important}.lang-switch{-webkit-backdrop-filter:none;backdrop-filter:none;background:0 0;border:.5px solid #0000001a;align-items:center;margin-left:0;display:inline-flex;overflow:hidden}.lang-option{color:var(--muted);cursor:pointer;background:0 0;border:0;padding:4px 10px;transition:all .18s}.lang-option+.lang-option{border-left:.5px solid #0000001a}.lang-label{letter-spacing:.1px;white-space:nowrap;text-transform:uppercase;font-size:11px;line-height:1}.lang-option-active{color:var(--text);cursor:default;pointer-events:none;background:#0000000d}.menu-toggle{cursor:pointer;color:#8493b2;background:0 0;border:0;padding:8px;display:none}.menu-toggle-icon{width:22px;height:22px;display:block}.menu-toggle-bar{background:var(--text);width:18px;height:1px;display:block}.menu-toggle-bar+.menu-toggle-bar{margin-top:6px}.works-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:46px 28px;display:grid}.project-card-featured{grid-column:1/-1}.project-card-featured .project-media{aspect-ratio:21/9}.project-link{grid-template-columns:1fr;gap:14px;display:grid}.project-media{aspect-ratio:16/10;background:#f4f4f4;overflow:hidden}.project-media img{object-fit:cover;width:100%;height:100%;transition:transform .5s;transform:scale(1.01)}.project-card:hover .project-media img{transform:scale(1.04)}.project-title{letter-spacing:-.4px;margin:0;font-size:24px}.project-subtitle{color:var(--muted);letter-spacing:.2px;margin-top:6px;font-size:14px}.project{grid-template-columns:1fr;gap:32px;display:grid}.project-hero-bleed{border-block:1px solid var(--border);background:#fff;width:100vw;height:300px;margin-bottom:32px;margin-left:calc(50% - 50vw);overflow:hidden}.project-hero-bleed img{object-fit:cover;object-position:center;width:100%;height:100%}.project-body{text-align:left;max-width:760px;margin:0 auto}.project-page-title{letter-spacing:-.8px;margin:0;font-size:44px}.project-page-subtitle{color:var(--muted);letter-spacing:.2px;margin-top:10px;font-size:14px}.project-description{color:var(--muted);margin-top:18px}.project-gallery{grid-template-columns:1fr;gap:18px;margin-top:32px;display:grid}.media{background:0 0;border:0}.media video,.media img{width:100%;height:auto}.media video{aspect-ratio:16/9;background:#000}.media-button{cursor:zoom-in;background:0 0;border:0;width:100%;height:100%;padding:0;display:block}.lightbox{z-index:1000;background:#000000eb;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.lightbox-inner{max-width:min(1200px,92vw);max-height:92vh}.lightbox-inner img{object-fit:contain;width:100%;height:auto;max-height:92vh}.lightbox-close{color:#fff;cursor:pointer;letter-spacing:.2px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#00000059;border:1px solid #ffffff38;border-radius:999px;padding:8px 12px;font-size:13px;position:fixed;top:18px;right:18px}.lightbox-counter{color:#fff;letter-spacing:.2px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#00000059;border:1px solid #ffffff38;border-radius:999px;padding:8px 12px;font-size:13px;position:fixed;top:18px;left:18px}.lightbox-nav{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#00000059;border:1px solid #ffffff38;border-radius:999px;place-items:center;width:44px;height:44px;font-size:28px;line-height:1;transition:opacity .18s;display:grid;position:fixed;top:50%;transform:translateY(-50%)}.lightbox-prev{left:18px}.lightbox-next{right:18px}.lightbox-nav:disabled{opacity:.25;cursor:default}.project-awards{text-align:left;margin-top:34px}.awards-list{margin-top:2px}.awards-title{color:var(--text);font-size:14px;font-weight:400;line-height:2.4em}.award-item{color:var(--text);margin:0;font-size:10px;line-height:2.4em}.page{text-align:center;max-width:760px;margin:0 auto}.page-title{letter-spacing:-.8px;margin:0;font-size:44px}.page-body{color:var(--muted);margin-top:18px}.contact-page{text-align:center;max-width:760px;margin:0 auto}.contact-title{letter-spacing:-.8px;margin:0;font-size:44px}.contact-body{color:var(--muted);margin-top:18px}.contact-email{text-underline-offset:6px;margin-top:20px;font-size:18px;line-height:1.6;text-decoration:underline;text-decoration-thickness:1px;display:inline-block}.contact-socials{color:var(--muted);flex-wrap:wrap;justify-content:center;gap:14px;margin-top:18px;font-size:13px;display:flex}.contact-social-link:hover{color:var(--text)}.resume{text-align:left;max-width:760px;margin:0 auto}.resume-hero{grid-template-columns:240px 1fr;align-items:start;gap:32px;display:grid}.resume-photo{background:#fff;width:240px;overflow:hidden}.resume-photo img{aspect-ratio:4/5;object-fit:cover;width:100%}.resume-name{letter-spacing:-.8px;margin:0;font-size:30px}.resume-tagline{color:var(--muted);letter-spacing:.2px;margin-top:10px;font-size:14px}.resume-summary{color:var(--muted);margin-top:8px;line-height:1.6}.personal-tags{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.personal-tag{color:#fff;letter-spacing:.02em;text-transform:uppercase;cursor:default;background:#000;border-radius:0;padding:3px 8px;font-size:13px;font-weight:500;transition:transform .3s}.personal-tag:hover{transform:translateY(-2px)}.resume-section{margin-top:34px}.resume-section-title{color:var(--text);font-size:14px;font-weight:400;line-height:2.4em}.resume-items{display:grid}.resume-item{padding-top:14px}.resume-item-head{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:18px;display:flex}.resume-item-title-group{flex-wrap:wrap;align-items:baseline;gap:36px;display:flex}.resume-item-dept{color:var(--text);letter-spacing:-.1px;font-size:14px;font-weight:500}.resume-item-title{letter-spacing:-.1px;font-size:14px;font-weight:500}.resume-item-time{color:var(--muted);letter-spacing:.2px;font-size:13px}.resume-item-desc{color:var(--muted);margin-top:10px;line-height:1.6}.product-highlight{color:var(--text);text-underline-offset:4px;cursor:pointer;padding:0 2px;font-weight:500;-webkit-text-decoration:underline #0000001a;text-decoration:underline #0000001a;transition:all .3s;position:relative}.product-highlight:hover{-webkit-text-decoration-color:var(--text);text-decoration-color:var(--text);background:#0000000a}.product-tooltip{z-index:100;pointer-events:auto;background:0 0;width:280px;padding-bottom:12px;animation:.3s cubic-bezier(.23,1,.32,1) tooltip-fade-in;position:absolute;bottom:100%;left:50%;transform:translate(-50%)}.product-tooltip-content{-webkit-backdrop-filter:blur(20px)saturate(180%);background:#fffc;border:.5px solid #0000001a;border-radius:12px;overflow:hidden;box-shadow:0 10px 30px #0000001f}@keyframes tooltip-fade-in{0%{opacity:0;transform:translate(-50%)translateY(10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.product-tooltip-image{background:#f4f4f4;width:100%;height:140px;position:relative}.product-tooltip-image img{object-fit:cover;opacity:0;width:100%;height:100%;transition:opacity .6s;position:absolute;top:0;left:0}.product-tooltip-image img.active{opacity:1}.product-tooltip-dots{z-index:2;gap:4px;display:flex;position:absolute;bottom:8px;left:50%;transform:translate(-50%)}.product-tooltip-dots .dot{background:#ffffff80;border-radius:50%;width:4px;height:4px;transition:all .3s}.product-tooltip-dots .dot.active{background:#fff;border-radius:2px;width:10px}.product-tooltip-text{padding:16px}.product-tooltip-name{color:var(--text);margin-bottom:6px;font-size:14px;font-weight:600}.product-tooltip-info{color:var(--muted);font-size:12px;line-height:1.5}.product-tooltip-arrow{border-top:6px solid #fffc;border-left:6px solid #0000;border-right:6px solid #0000;position:absolute;top:calc(100% - 12px);left:50%;transform:translate(-50%)}.resume-item-bullets{margin:10px 0 0;padding-left:0;font-size:13px;line-height:1.9;list-style:none}.resume-item-bullets li+li{margin-top:8px}.form{text-align:left;gap:14px;margin-top:28px;display:grid}.field .label{color:var(--muted);margin-bottom:6px;font-size:13px}.input,.textarea{border:1px solid var(--border);width:100%;font:inherit;border-radius:0;outline:none;padding:12px}.input:focus,.textarea:focus{border-color:#11111159}.btn{border:1px solid var(--border);cursor:pointer;background:#fff;justify-content:center;align-items:center;padding:12px 16px;transition:transform .2s;display:inline-flex}.btn:hover{transform:translateY(-1px)}.cursor-hint{pointer-events:none;z-index:100;-webkit-backdrop-filter:blur(12px);color:#fffffff2;letter-spacing:.5px;opacity:0;visibility:hidden;white-space:nowrap;will-change:transform, opacity;background:#ffffff1f;border:1px solid #ffffff40;border-radius:999px;align-items:center;gap:8px;padding:8px 16px;font-size:14px;transition:opacity .8s,visibility .8s;display:flex;position:fixed;top:0;left:0;box-shadow:0 8px 24px #0003}.cursor-hint.visible{opacity:1;visibility:visible;animation:2s ease-in-out infinite alternate hint-pulse}.cursor-hint-icon{font-size:16px}@keyframes hint-pulse{0%{box-shadow:0 8px 24px #0003}to{box-shadow:0 8px 24px #ffffff26}}.hint{color:var(--muted);font-size:13px}.text-link{color:var(--text);text-underline-offset:3px;text-decoration:underline;text-decoration-thickness:1px}.site-footer{border-top:1px solid #0000;padding:26px 0 34px}.footer-inner{text-align:center;justify-items:center;gap:10px;display:grid}.footer-socials{color:var(--muted);gap:14px;font-size:13px;display:flex}.social-link{align-items:center;gap:8px;display:inline-flex}.social-icon{place-items:center;width:16px;height:16px;display:grid;overflow:visible}.social-icon-svg{width:16px;height:16px;display:block}.social-icon-douyin{transform-origin:50%;transform:scale(1.1)}.social-link:hover{color:var(--text)}.footer-copy{color:var(--muted);font-size:13px}.skeleton-block{background:linear-gradient(90deg,#0000000a 0%,#00000012 45%,#0000000a 100%) 0 0/240% 100%;width:100%;height:18px;margin:14px 0;animation:1.2s ease-in-out infinite shimmer}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-120% 0}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:1ms!important;animation-duration:1ms!important;animation-iteration-count:1!important}}@media screen and (width<=768px){:root{--gutter:18px;--header-h:56px;font-size:14px}.site-header{height:var(--header-h)}.header-inner{gap:16px}.brand{align-items:center;min-height:44px;display:inline-flex}.menu-toggle{justify-content:center;align-items:center;width:44px;height:44px;padding:0;display:inline-flex}.nav{top:var(--header-h);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);padding:12px var(--gutter);opacity:0;pointer-events:none;background:#fffffffa;gap:16px;transition:opacity .18s,transform .18s;display:grid;position:fixed;left:0;right:0;transform:translateY(-8px)}.nav-open{opacity:1;pointer-events:auto;transform:translateY(0)}.home-mode .nav{background:#000000d9;border-bottom:1px solid #ffffff1a}.nav-list{flex-direction:column;align-items:flex-start;gap:12px}.nav-link{align-items:center;min-height:44px;padding:10px 8px;display:inline-flex}.works-list{grid-template-columns:1fr;row-gap:34px}.project-link{gap:12px}.project-media{aspect-ratio:21/9}.lang-switch{justify-content:flex-start;place-self:start;margin-left:0}.lang-option{min-height:44px;padding:10px 12px}.project-title,.project-page-title,.page-title,.resume-name{font-size:26px}.project-subtitle,.project-page-subtitle,.page-body,.contact-body,.resume-tagline,.resume-summary,.resume-item-time{font-size:13px}.btn{min-height:44px;padding:12px 16px}.social-link{min-height:44px;padding:10px 6px}.lightbox{padding:16px}.lightbox-close{min-height:44px;padding:12px 16px}.resume-hero{grid-template-columns:1fr;gap:22px}.resume-photo{width:100%}.resume-photo img{aspect-ratio:16/9}.cursor-hint{padding:10px 16px;font-size:13px}.brand-mark{transform-origin:0;font-size:36px;line-height:1;display:inline-block;transform:scale(.5)}}
