:root{--bg:#fff;--text:#111;--muted:#1119;--border:#1111111f;--shadow:0 12px 30px #00000014;--container:1040px;--gutter:clamp(64px, 4vw, 44px);--header-h:64px;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) + 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-bar{background:#fff}.home-mode .nav-link{color:#ffffffb3}.home-mode .nav-link:hover,.home-mode .nav-link-active{color:#fff}.home-mode .lang-switch{background:#00000059;border-color:#ffffff38}.home-mode .lang-option{color:#ffffffb3}.home-mode .lang-option+.lang-option{border-left-color:#ffffff38}.home-mode .lang-option-active{color:#000;background:#fff}.home-mode .brand-mark,.home-mode .brand{color:#ffffffd9}.home-page{background:#000;display:block;position:fixed;inset:0;overflow:hidden}.video-bg{object-fit:cover;z-index:-1;pointer-events:none;--spotlight-radius:150px;--spotlight-solid:120px;width:100%;height:100%;-webkit-mask-image:radial-gradient(circle var(--spotlight-radius) at var(--mouse-x,50vw) var(--mouse-y,50vh), black var(--spotlight-solid), #00000080 var(--spotlight-radius), #00000080 100%);-webkit-mask-image:radial-gradient(circle var(--spotlight-radius) at var(--mouse-x,50vw) var(--mouse-y,50vh), black var(--spotlight-solid), #00000080 var(--spotlight-radius), #00000080 100%);mask-image:radial-gradient(circle var(--spotlight-radius) at var(--mouse-x,50vw) var(--mouse-y,50vh), black var(--spotlight-solid), #00000080 var(--spotlight-radius), #00000080 100%);will-change:mask-image, -webkit-mask-image;transition:--spotlight-radius .8s,--spotlight-solid .8s;position:absolute;top:0;left:0;transform:translateZ(0)}.video-bg.full-illumination{--spotlight-radius:150vmax;--spotlight-solid:150vmax}.video-bg.full-illumination.effect-ripple{transition:none;animation:1.8s ease-in-out forwards ripple-expand}@keyframes ripple-expand{0%{--spotlight-radius:150px;--spotlight-solid:120px}30%{--spotlight-radius:40vmax;--spotlight-solid:30vmax}45%{--spotlight-radius:35vmax;--spotlight-solid:25vmax}to{--spotlight-radius:150vmax;--spotlight-solid:150vmax}}.video-bg.full-illumination.effect-cinematic{transition:--spotlight-radius 1.2s cubic-bezier(.65,0,.35,1),--spotlight-solid 1.2s cubic-bezier(.65,0,.35,1)}.video-bg.full-illumination.effect-burst{transition:--spotlight-radius .25s cubic-bezier(.1,.9,.2,1),--spotlight-solid .25s cubic-bezier(.1,.9,.2,1)}@property --spotlight-radius{syntax:"<length>";inherits:true;initial-value:150px}@property --spotlight-solid{syntax:"<length>";inherits:true;initial-value:120px}.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:var(--header-h);-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{justify-content:space-between;align-items:center;gap:24px;height:100%;display:flex}.brand{letter-spacing:.05em;font-weight:800}.brand-mark{white-space:nowrap;font-size:22px;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:18px;display:flex}.nav-list{align-items:center;gap:18px;margin:0;padding:0;list-style:none;display:flex}.nav-link{color:var(--muted);letter-spacing:.2px;font-size:14px;transition:color .2s}.nav-link:hover,.nav-link-active{color:var(--text)}.lang-switch{border:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffe6;border-radius:999px;align-items:center;margin-left:10px;display:inline-flex;overflow:hidden}.lang-option{color:var(--muted);cursor:pointer;background:0 0;border:0;padding:6px 12px;transition:background-color .18s,color .18s}.lang-option+.lang-option{border-left:1px solid var(--border)}.lang-label{letter-spacing:.2px;white-space:nowrap;font-size:13px;line-height:1}.lang-option-active{color:#fff;cursor:default;pointer-events:none;background:#222}.menu-toggle{cursor:pointer;background:0 0;border:0;padding:8px;display:none}.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:1fr;gap:56px;display:grid}.project-link{grid-template-columns:1fr;gap:18px;display:grid}.project-media{aspect-ratio:21/9;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:30px}.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;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%;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{border:1px solid var(--border);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:18px}.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{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}.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 (width<=860px){:root{font-size:16px}.menu-toggle{display:inline-flex}.nav{top:var(--header-h);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);padding:16px 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}.lang-switch{justify-content:flex-start;place-self:start;margin-left:0}.project-title,.project-page-title,.page-title,.resume-name{font-size:30px}.resume-hero{grid-template-columns:1fr;gap:22px}.resume-photo{width:100%}.resume-photo img{aspect-ratio:16/9}.cursor-hint{padding:6px 14px;font-size:13px}.brand-mark{font-size:20px}}
