@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600&family=Noto+Serif+SC:wght@300;400;500;600&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&display=swap";:root{--color-bg:#fafafa;--color-bg-alt:#f0f0f0;--color-surface:#fff;--color-text:#1a1a1a;--color-text-secondary:#666;--color-text-muted:#999;--color-border:#e5e5e5;--color-border-light:#efefef;--color-accent:#333;--color-overlay:#000000d9;--color-overlay-light:#0000000a;--font-heading:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-body:"Cormorant Garamond", "Georgia", serif;--font-cn:"Noto Serif SC", "SimSun", serif;--font-mono:"SF Mono", "Consolas", monospace;--text-xs:.75rem;--text-sm:.8125rem;--text-base:1rem;--text-md:1.0625rem;--text-lg:1.25rem;--text-xl:1.5rem;--text-2xl:2rem;--text-3xl:2.5rem;--text-4xl:3.5rem;--leading-tight:1.2;--leading-normal:1.6;--leading-relaxed:1.8;--tracking-tight:-.02em;--tracking-normal:0;--tracking-wide:.05em;--tracking-wider:.1em;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--space-32:8rem;--sidebar-width:280px;--content-max-width:960px;--content-padding:var(--space-10);--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-in-out:cubic-bezier(.65, 0, .35, 1);--duration-fast:.2s;--duration-normal:.4s;--duration-slow:.6s;--duration-slower:.8s;--radius-sm:2px;--radius-md:4px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-body);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text);background-color:var(--color-bg);overflow-x:hidden}img{max-width:100%;height:auto;display:block}a{color:inherit;transition:opacity var(--duration-fast) var(--ease-out);text-decoration:none}a:hover{opacity:.6}button{font:inherit;color:inherit;cursor:pointer;background:0 0;border:none}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:400;line-height:var(--leading-tight)}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInOnly{0%{opacity:0}to{opacity:1}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.animate-fade-in{animation:fadeIn var(--duration-slow) var(--ease-out) both}.animate-fade-in-up{animation:fadeInUp var(--duration-slow) var(--ease-out) both}.animate-slide-in{animation:slideInLeft var(--duration-normal) var(--ease-out) both}.stagger-children>:first-child{animation-delay:0s}.stagger-children>:nth-child(2){animation-delay:60ms}.stagger-children>:nth-child(3){animation-delay:.12s}.stagger-children>:nth-child(4){animation-delay:.18s}.stagger-children>:nth-child(5){animation-delay:.24s}.stagger-children>:nth-child(6){animation-delay:.3s}.stagger-children>:nth-child(7){animation-delay:.36s}.stagger-children>:nth-child(8){animation-delay:.42s}.reveal{opacity:0;transition:opacity var(--duration-slow) var(--ease-out), transform var(--duration-slow) var(--ease-out);transform:translateY(16px)}.reveal.visible{opacity:1;transform:translateY(0)}.text-cn{font-family:var(--font-cn)}.text-heading{font-family:var(--font-heading);letter-spacing:var(--tracking-tight)}.text-meta{font-family:var(--font-heading);font-size:var(--text-sm);color:var(--color-text-muted);letter-spacing:var(--tracking-wide);text-transform:uppercase}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}::selection{background-color:var(--color-text);color:var(--color-bg)}#app{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--color-bg);border-right:1px solid var(--color-border-light);z-index:100;height:100vh;padding:var(--space-8) var(--space-6) var(--space-6);flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow:hidden auto}.sidebar::-webkit-scrollbar{width:0}.sidebar__brand{margin-bottom:var(--space-10)}.sidebar__brand a{font-family:var(--font-heading);font-size:var(--text-lg);letter-spacing:var(--tracking-tight);color:var(--color-text);font-weight:400;line-height:var(--leading-tight);display:block}.sidebar__brand-cn{font-family:var(--font-cn);font-size:var(--text-base);color:var(--color-text-secondary);margin-top:var(--space-1);font-weight:400;display:block}.sidebar__nav{flex:1}.nav-section{margin-bottom:var(--space-6)}.nav-section__title{font-family:var(--font-heading);font-size:var(--text-sm);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--color-text-muted);margin-bottom:var(--space-3);cursor:pointer;align-items:center;gap:var(--space-2);transition:color var(--duration-fast) var(--ease-out);-webkit-user-select:none;user-select:none;font-weight:500;display:flex}.nav-section__title:hover{color:var(--color-text)}.nav-section__title-cn{font-family:var(--font-cn);font-size:var(--text-xs);letter-spacing:0;text-transform:none;font-weight:400}.nav-section__arrow{transition:transform var(--duration-fast) var(--ease-out);opacity:.5;font-size:.6em}.nav-section.expanded .nav-section__arrow{transform:rotate(90deg)}.nav-section__items{max-height:0;transition:max-height var(--duration-normal) var(--ease-out);overflow:hidden}.nav-section.expanded .nav-section__items{max-height:500px}.nav-item{padding:var(--space-2) 0;padding-left:var(--space-4);font-family:var(--font-heading);font-size:var(--text-sm);color:var(--color-text-secondary);transition:color var(--duration-fast) var(--ease-out), padding-left var(--duration-fast) var(--ease-out);border-left:1px solid #0000;font-weight:300;display:block}.nav-item:hover{color:var(--color-text);opacity:1;padding-left:calc(var(--space-4) + 4px)}.nav-item.active{color:var(--color-text);border-left-color:var(--color-text);font-weight:400}.nav-item__cn{font-family:var(--font-cn);font-size:var(--text-xs);color:var(--color-text-muted);margin-top:1px;display:block}.sidebar__footer{padding-top:var(--space-6);border-top:1px solid var(--color-border-light);font-family:var(--font-heading);font-size:var(--text-xs);color:var(--color-text-muted);letter-spacing:var(--tracking-wide)}.mobile-header{background:var(--color-bg);border-bottom:1px solid var(--color-border-light);height:64px;padding:0 var(--content-padding);z-index:200;justify-content:space-between;align-items:center;display:none;position:fixed;top:0;left:0;right:0}.mobile-header__brand a{font-family:var(--font-heading);font-size:var(--text-base);color:var(--color-text);font-weight:500;line-height:1.1}.mobile-header__brand-cn{font-family:var(--font-cn);font-size:var(--text-xs);color:var(--color-text-secondary);font-weight:300;display:block}.menu-toggle{background:0 0;border:none;justify-content:center;align-items:center;width:44px;height:44px;margin-right:-10px;display:flex;position:relative}.menu-toggle__bar{background:var(--color-text);width:18px;height:1.5px;transition:transform var(--duration-fast) var(--ease-out), opacity var(--duration-fast) var(--ease-out);display:block;position:absolute}.menu-toggle__bar:first-child{transform:translateY(-5px)}.menu-toggle__bar:nth-child(2){transform:translateY(0)}.menu-toggle__bar:nth-child(3){transform:translateY(5px)}.menu-toggle.active .menu-toggle__bar:first-child{transform:rotate(45deg)}.menu-toggle.active .menu-toggle__bar:nth-child(2){opacity:0}.menu-toggle.active .menu-toggle__bar:nth-child(3){transform:rotate(-45deg)}.sidebar-overlay{z-index:90;opacity:0;width:100%;height:100%;transition:opacity var(--duration-normal) var(--ease-out);background:#0000004d;display:none;position:fixed;top:0;left:0}.sidebar-overlay.visible{opacity:1}.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh}.page-container{max-width:var(--content-max-width);padding:var(--space-16) var(--content-padding) var(--space-20);animation:fadeInOnly var(--duration-normal) var(--ease-out) both;margin:0 auto}.footer{padding:var(--space-12) var(--content-padding) var(--space-8);font-family:var(--font-heading);font-size:var(--text-xs);color:var(--color-text-muted);letter-spacing:var(--tracking-wide);max-width:var(--content-max-width);margin:0 auto}.home-grid{gap:var(--space-2);display:grid}.home-grid--single{flex-direction:column;align-items:center;display:flex}.home-item{cursor:pointer;background:var(--color-bg-alt);aspect-ratio:16/10;position:relative;overflow:hidden}.home-item__image{object-fit:cover;width:100%;height:100%;transition:transform var(--duration-slow) var(--ease-out), filter var(--duration-slow) var(--ease-out)}.home-item:hover .home-item__image{transform:scale(1.03)}.home-item__overlay{padding:var(--space-8) var(--space-6) var(--space-6);opacity:0;transition:opacity var(--duration-normal) var(--ease-out);background:linear-gradient(#0000 0%,#0009 100%);position:absolute;bottom:0;left:0;right:0}.home-item:hover .home-item__overlay{opacity:1}.home-item__title{font-family:var(--font-heading);font-size:var(--text-lg);color:#fff;letter-spacing:var(--tracking-tight);font-weight:400}.home-item__title-cn{font-family:var(--font-cn);font-size:var(--text-sm);color:#ffffffb3;margin-top:var(--space-1)}.home-item__meta{font-family:var(--font-heading);font-size:var(--text-xs);color:#ffffff80;letter-spacing:var(--tracking-wide);text-transform:uppercase;margin-top:var(--space-2)}.home-item--full-res{aspect-ratio:auto;background:0 0;display:block;overflow-x:auto}.home-item--full-res .home-item__image{object-fit:contain;width:auto;max-width:none;height:auto}.home-item--full-res .home-item__overlay{background:linear-gradient(#0000 0%,#0006 100%);width:100%;position:sticky;left:0}.home-item--centered{aspect-ratio:auto;cursor:pointer;color:var(--color-text);background:0 0;flex-direction:column;justify-content:flex-start;align-items:flex-start;text-decoration:none;display:flex}.home-item--centered .home-item__image-container{width:100%;overflow:hidden}.home-item--centered .home-item__image{object-fit:contain;width:100%;height:auto;transition:transform .8s cubic-bezier(.16,1,.3,1)}.home-item--centered:hover .home-item__image{transform:scale(1.02)}.home-item--centered .home-item__info{text-align:left;width:100%;padding:2rem 0}.home-item--centered .home-item__title{font-family:var(--font-heading);font-size:var(--text-lg);letter-spacing:var(--tracking-tight);color:var(--color-text);margin-bottom:var(--space-2);font-weight:300}.home-item--centered .home-item__title-cn{font-family:var(--font-cn);font-size:var(--text-base);color:var(--color-text-secondary);margin-bottom:var(--space-4);font-weight:300}.home-item--centered .home-item__meta{font-family:var(--font-heading);font-size:var(--text-sm);color:var(--color-text-muted);letter-spacing:var(--tracking-wide);text-transform:uppercase}.home-item__placeholder{background:var(--color-bg-alt);justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative}.home-item__placeholder-text{font-family:var(--font-heading);font-size:var(--text-2xl);color:var(--color-text-muted);letter-spacing:var(--tracking-tight);text-align:center;padding:var(--space-6);transition:color var(--duration-normal) var(--ease-out);font-weight:300}.home-item:hover .home-item__placeholder-text{color:var(--color-text)}.home-section-label{font-family:var(--font-heading);font-size:var(--text-xs);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--color-text-muted);margin-top:var(--space-12);margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border-light);font-weight:500}.home-section-label:first-child{margin-top:0}.work-header{margin-bottom:var(--space-12)}.work-header__title{font-family:var(--font-heading);font-size:var(--text-3xl);letter-spacing:var(--tracking-tight);font-weight:300;line-height:var(--leading-tight)}.work-header__title-cn{font-family:var(--font-cn);font-size:var(--text-xl);color:var(--color-text-secondary);margin-top:var(--space-2);font-weight:300}.work-header__meta{margin-top:var(--space-6);font-family:var(--font-heading);font-size:var(--text-sm);color:var(--color-text-muted);letter-spacing:var(--tracking-wide);gap:var(--space-6);flex-wrap:wrap;display:flex}.work-header__meta span{align-items:center;gap:var(--space-2);display:inline-flex}.work-description{margin-bottom:var(--space-12);max-width:720px}.work-description__en{font-family:var(--font-body);font-size:var(--text-md);line-height:var(--leading-relaxed);color:var(--color-text);margin-bottom:var(--space-8)}.work-description__cn{font-family:var(--font-cn);font-size:var(--text-base);line-height:var(--leading-relaxed);color:var(--color-text-secondary)}.work-description__en p,.work-description__cn p{margin-bottom:var(--space-4)}.work-description__en p:last-child,.work-description__cn p:last-child{margin-bottom:0}.work-links{margin-bottom:var(--space-12);gap:var(--space-3);flex-wrap:wrap;display:flex}.work-link{font-family:var(--font-heading);font-size:var(--text-sm);letter-spacing:var(--tracking-wide);padding:var(--space-2) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:all var(--duration-fast) var(--ease-out)}.work-link:hover{opacity:1;background:var(--color-text);color:var(--color-bg);border-color:var(--color-text)}.work-gallery{gap:var(--space-3);flex-direction:column;display:flex}.work-gallery__item{background:var(--color-bg-alt);cursor:pointer;position:relative;overflow:hidden}.work-gallery__item img{width:100%;transition:transform var(--duration-slow) var(--ease-out);display:block}.work-gallery__item:hover img{transform:scale(1.01)}.work-gallery__caption{padding:var(--space-3) 0 var(--space-2);font-family:var(--font-heading);font-size:var(--text-sm);color:var(--color-text-muted);letter-spacing:var(--tracking-wide)}.work-gallery__item--full-res{justify-content:center;display:flex;overflow:auto}.work-gallery__item--full-res img{width:auto;max-width:none}.video-embed{margin:var(--space-6) 0;background:var(--color-bg-alt);border-radius:var(--radius-sm);height:0;padding-bottom:56.25%;position:relative;overflow:hidden}.video-embed iframe{border:0;width:100%;height:100%;position:absolute;top:0;left:0}.video-embed__caption{margin-top:var(--space-3);font-family:var(--font-heading);font-size:var(--text-xs);color:var(--color-text-muted);letter-spacing:var(--tracking-wide)}.info-page{max-width:800px}.info-bio{margin-bottom:var(--space-16)}.info-bio__en{font-family:var(--font-body);font-size:var(--text-md);line-height:var(--leading-relaxed);margin-bottom:var(--space-6)}.info-bio__cn{font-family:var(--font-cn);font-size:var(--text-base);line-height:var(--leading-relaxed);color:var(--color-text-secondary)}.info-section{margin-bottom:var(--space-12)}.info-section__title{font-family:var(--font-heading);font-size:var(--text-xs);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--color-text-muted);margin-bottom:var(--space-6);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border-light);font-weight:500}.home-grid{gap:var(--space-4);margin-top:var(--space-8);grid-template-columns:repeat(2,1fr);display:grid}.home-grid--single{flex-direction:column;grid-template-columns:none;align-items:center;display:flex}.info-entry{gap:var(--space-3);margin-bottom:var(--space-3);font-family:var(--font-heading);font-size:var(--text-sm);line-height:var(--leading-normal);grid-template-columns:60px 1fr;display:grid}.info-entry__year{color:var(--color-text-muted);font-variant-numeric:tabular-nums}.info-entry__content{color:var(--color-text-secondary)}.info-entry__content a{border-bottom:1px solid var(--color-border);padding-bottom:1px}.contact-link{font-family:var(--font-heading);font-size:var(--text-base);align-items:center;gap:var(--space-3);color:var(--color-text-secondary);transition:color var(--duration-fast) var(--ease-out);display:flex}.contact-link:hover{color:var(--color-text);opacity:1}.contact-link__label{font-size:var(--text-xs);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--color-text-muted);min-width:80px}.lightbox{background:var(--color-overlay);z-index:1000;opacity:0;pointer-events:none;width:100%;height:100%;transition:opacity var(--duration-normal) var(--ease-out);justify-content:center;align-items:center;display:flex;position:fixed;top:0;left:0}.lightbox.active{opacity:1;pointer-events:all}.lightbox__image{object-fit:contain;max-width:90vw;max-height:90vh;animation:scaleIn var(--duration-normal) var(--ease-out) both}.lightbox__close{top:var(--space-6);right:var(--space-6);color:#fff;width:44px;height:44px;font-size:var(--text-xl);cursor:pointer;opacity:.6;transition:opacity var(--duration-fast);justify-content:center;align-items:center;display:flex;position:absolute}.lightbox__close:hover{opacity:1}.lightbox__nav{color:#fff;width:48px;height:48px;font-size:var(--text-xl);cursor:pointer;opacity:.5;transition:opacity var(--duration-fast);justify-content:center;align-items:center;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.lightbox__nav:hover{opacity:1}.lightbox__nav--prev{left:var(--space-4)}.lightbox__nav--next{right:var(--space-4)}.lightbox__counter{bottom:var(--space-6);color:#ffffff80;font-family:var(--font-heading);font-size:var(--text-sm);letter-spacing:var(--tracking-wide);position:absolute;left:50%;transform:translate(-50%)}.lightbox--full-res{padding:var(--space-12) var(--space-6);text-align:center;display:block;overflow:auto}.lightbox--full-res .lightbox__image{cursor:default;width:auto;max-width:none;height:auto;max-height:none;margin:0 auto;display:block}.lightbox--full-res .lightbox__close,.lightbox--full-res .lightbox__nav,.lightbox--full-res .lightbox__counter{position:fixed}.lightbox--zoomed{cursor:zoom-out;display:block;overflow:auto}.lightbox--zoomed .lightbox__image{cursor:zoom-out;width:200vw;max-width:none;max-height:none;margin:0}.lightbox--zoomed .lightbox__close,.lightbox--zoomed .lightbox__nav,.lightbox--zoomed .lightbox__counter{position:fixed}.lightbox--zoomed .lightbox__nav{top:50vh}.lightbox:not(.lightbox--zoomed) .lightbox__image{cursor:zoom-in}.info-bio{max-width:720px;line-height:1.8}.info-bio p{margin-bottom:var(--space-6)}.info-bio p:last-child{margin-bottom:0}.info-bio__cn{margin-top:var(--space-12);font-family:var(--font-cn);color:var(--color-text-muted);font-weight:300}.info-section{margin-top:var(--space-16);max-width:900px}.info-section__title{font-family:var(--font-heading);font-size:var(--text-sm);text-transform:uppercase;letter-spacing:var(--tracking-widest);margin-bottom:var(--space-8);color:var(--color-text-muted)}.info-entry{gap:var(--space-4);margin-bottom:var(--space-4);font-size:var(--text-sm);grid-template-columns:80px 1fr;display:grid}.info-entry__year{font-family:var(--font-heading);color:var(--color-text-muted)}.info-entry__content{line-height:1.6}.contact-links{gap:var(--space-4);flex-direction:column;display:flex}.contact-link{padding:var(--space-4) 0;border-bottom:1px solid var(--color-border-light);transition:padding var(--duration-fast);justify-content:space-between;display:flex}.contact-link:hover{padding-left:var(--space-2);color:var(--color-primary)}.contact-link__label{font-family:var(--font-heading);text-transform:uppercase;font-size:var(--text-xs);letter-spacing:var(--tracking-widest);color:var(--color-text-muted)}@media (width<=1023px){:root{--sidebar-width:260px;--content-padding:var(--space-8)}.sidebar{width:var(--sidebar-width)}.work-gallery__item--full-res img,.home-item--full-res .home-item__image{margin:0 auto;width:auto!important;max-width:100%!important;height:auto!important;max-height:80vh!important}.lightbox--full-res:not(.lightbox--zoomed) .lightbox__image{width:auto!important;max-width:90vw!important;height:auto!important;max-height:82vh!important}}@media (width<=767px){:root{--content-padding:var(--space-5)}.mobile-header{display:flex}.sidebar{transition:transform var(--duration-normal) var(--ease-out);width:280px;box-shadow:none;transform:translate(-100%)}.sidebar.open{transform:translate(0);box-shadow:8px 0 30px #0000001a}.sidebar-overlay{display:block}.main-content{padding-top:var(--space-16);margin-left:0}.page-container{padding-top:var(--space-8);padding-bottom:var(--space-12)}.work-header__title{font-size:var(--text-2xl)}.work-header__title-cn{font-size:var(--text-lg)}.home-item{aspect-ratio:auto}.home-item__info{padding:var(--space-4) 0!important}.home-item__title{font-size:var(--text-base)!important}.home-item__title-cn{font-size:var(--text-xs)!important}.home-item__meta{opacity:.8;font-size:var(--text-xs)!important}.home-grid{gap:var(--space-8);grid-template-columns:1fr}.info-entry{font-size:var(--text-sm);line-height:var(--leading-normal);grid-template-columns:50px 1fr}.work-header__meta{gap:var(--space-1);font-size:var(--text-xs);flex-direction:column}.lightbox__nav--prev{left:var(--space-2)}.lightbox__nav--next{right:var(--space-2)}}@media (width<=400px){:root{--content-padding:var(--space-4)}.work-header__title{font-size:var(--text-xl)}}
