:root{--c-bg:#FAF7F2;--c-bg-warm:#F3EDE4;--c-bg-hero:#2C2825;--c-text:#2C2825;--c-text-muted:#7A7067;--c-text-light:#F5F1EC;--c-accent:#C2785C;--c-accent-dark:#A8603F;--c-border:#E2DCD4;--c-border-dark:#4A4440;--c-card-bg:rgba(255, 255, 255, 0.6);--f-display:'Fraunces', serif;--f-body:'Outfit', sans-serif;--s-section:clamp(5rem, 10vw, 9rem);--s-gap:clamp(1.5rem, 3vw, 3rem);--max-w:1120px;--nav-h:64px;--ease:cubic-bezier(0.25, 0.46, 0.45, 0.94)}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--f-body);font-weight:400;font-size:1rem;line-height:1.7;color:var(--c-text);background:var(--c-bg)}a{color:var(--c-accent);text-decoration:none;transition:color .2s var(--ease)}a:hover{color:var(--c-accent-dark)}img{max-width:100%;display:block}strong{font-weight:600}::selection{background:var(--c-accent);color:#fff}.container{max-width:var(--max-w);margin:0 auto;padding:0 clamp(1.5rem,4vw,3rem)}.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--f-body);font-size:.875rem;font-weight:500;letter-spacing:.02em;padding:.75rem 1.75rem;border-radius:100px;border:1.5px solid transparent;cursor:pointer;transition:all .25s var(--ease);text-decoration:none}.btn--primary{background:var(--c-accent);color:#fff;border-color:var(--c-accent)}.btn--primary:hover{background:var(--c-accent-dark);border-color:var(--c-accent-dark);color:#fff;transform:translateY(-1px);box-shadow:0 4px 20px rgba(194,120,92,.3)}.btn--outline{background:0 0;color:var(--c-text-light);border-color:rgba(245,241,236,.3)}.btn--outline:hover{border-color:var(--c-accent);color:var(--c-accent)}.btn--text{background:0 0;border:none;color:var(--c-text-light);padding:.5rem 0;font-size:.813rem;opacity:.7}.btn--text:hover{opacity:1;color:var(--c-accent)}.btn--text svg{width:14px;height:14px}.nav{position:fixed;top:0;left:0;right:0;z-index:1000;height:calc(var(--nav-h) + env(safe-area-inset-top,0px));padding-top:env(safe-area-inset-top,0px);background:var(--c-bg-hero);transition:background .3s var(--ease),box-shadow .3s var(--ease),backdrop-filter .3s var(--ease)}.nav--scrolled{background:rgba(250,247,242,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--c-border)}.nav__inner{max-width:var(--max-w);margin:0 auto;padding:0 clamp(1.5rem,4vw,3rem);display:flex;align-items:center;justify-content:space-between;height:100%}.nav__logo{font-family:var(--f-display);font-size:1.25rem;font-weight:600;color:var(--c-text-light);letter-spacing:.02em;transition:color .3s var(--ease)}.nav--scrolled .nav__logo{color:var(--c-text)}.nav__links{list-style:none;display:flex;gap:2rem}.nav__links a{font-size:.8125rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:rgba(245,241,236,.65);transition:color .2s var(--ease);position:relative}.nav__links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--c-accent);transition:width .3s var(--ease)}.nav__links a:hover::after{width:100%}.nav--scrolled .nav__links a{color:var(--c-text-muted)}.nav__links a:hover,.nav--scrolled .nav__links a:hover{color:var(--c-accent)}.nav__toggle{display:none;flex-direction:column;gap:5px;background:0 0;border:none;cursor:pointer;padding:4px}.nav__toggle span{display:block;width:22px;height:1.5px;background:var(--c-text-light);transition:all .3s var(--ease)}.nav--scrolled .nav__toggle span{background:var(--c-text)}.nav__toggle.active span:nth-child(1){transform:translateY(6.5px)rotate(45deg)}.nav__toggle.active span:nth-child(2){opacity:0}.nav__toggle.active span:nth-child(3){transform:translateY(-6.5px)rotate(-45deg)}.page--inner .nav{background:rgba(250,247,242,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--c-border)}.page--inner .nav__logo{color:var(--c-text)}.page--inner .nav__links a{color:var(--c-text-muted)}.page--inner .nav__links a:hover{color:var(--c-accent)}.page--inner .nav__toggle span{background:var(--c-text)}.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;background:var(--c-bg-hero);overflow:hidden}.hero__bg{position:absolute;inset:0;background:radial-gradient(ellipse at 20% 50%,rgba(194,120,92,8%) 0%,transparent 60%),radial-gradient(ellipse at 80% 30%,rgba(194,120,92,5%) 0%,transparent 50%)}.hero::after{content:'';position:absolute;inset:0;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");pointer-events:none}.hero__content{position:relative;z-index:1;padding:2rem}@keyframes heroFadeIn{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.hero__greeting,.hero__name,.hero__role,.hero__affiliation,.hero__actions{animation:heroFadeIn .8s var(--ease)both}.hero__greeting{font-family:var(--f-body);font-size:.8125rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--c-accent);margin-bottom:1rem;animation-delay:0s}.hero__name{font-family:var(--f-display);font-size:clamp(3rem,7vw,5.5rem);font-weight:400;color:var(--c-text-light);line-height:1.1;margin-bottom:1rem;letter-spacing:-.02em;animation-delay:.12s}.hero__chinese{font-weight:300;color:rgba(245,241,236,.35);margin-left:.25em;font-size:.7em}.hero__role{font-family:var(--f-body);font-size:1.125rem;color:rgba(245,241,236,.7);font-weight:400;margin-bottom:.25rem;animation-delay:.24s}.hero__affiliation{font-family:var(--f-body);font-size:.9375rem;color:rgba(245,241,236,.45);font-weight:300;margin-bottom:2.5rem;animation-delay:.36s}.hero__actions{display:flex;flex-direction:column;align-items:center;gap:1rem;animation-delay:.48s}.hero__actions>:first-child,.hero__actions>:nth-child(2){display:inline-flex}.hero__actions>:first-child{margin-right:.75rem}.hero__resume-group{display:flex;align-items:center;gap:.5rem}.hero__resume-sep{color:rgba(245,241,236,.25);font-size:.8rem}.hero__scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;z-index:1}.hero__scroll span{font-size:.6875rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(245,241,236,.3)}.hero__scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--c-accent),transparent);animation:scrollPulse 2s var(--ease)infinite}@keyframes scrollPulse{0%,100%{opacity:1;transform:scaleY(1)}50%{opacity:.4;transform:scaleY(.6)}}.section{padding:var(--s-section)0}.section__header{margin-bottom:var(--s-gap)}.section__number{display:block;font-family:var(--f-body);font-size:.75rem;font-weight:500;letter-spacing:.15em;color:var(--c-accent);margin-bottom:.5rem}.section__title{font-family:var(--f-display);font-size:clamp(2rem,4vw,3rem);font-weight:400;color:var(--c-text);letter-spacing:-.02em;line-height:1.15}.about{background:var(--c-bg)}.about__grid{display:grid;grid-template-columns:280px 1fr;gap:clamp(2rem,5vw,4rem);align-items:start}.about__photo-frame{position:relative;border-radius:12px;overflow:hidden;aspect-ratio:3/4;background:var(--c-bg-warm)}.about__photo-frame::after{content:'';position:absolute;inset:0;border-radius:12px;border:1px solid rgba(0,0,0,6%);pointer-events:none}.about__photo{width:100%;height:100%;object-fit:cover}.about__lead{font-size:1.0625rem;line-height:1.8;color:var(--c-text);margin-bottom:2rem}.about__details{display:flex;flex-direction:column;gap:1rem;padding-top:1.5rem;border-top:1px solid var(--c-border)}.about__detail{display:grid;grid-template-columns:120px 1fr;gap:1rem;font-size:.9375rem}.about__detail-label{font-weight:500;color:var(--c-text-muted);font-size:.8125rem;text-transform:uppercase;letter-spacing:.06em}.about__detail-value{color:var(--c-text)}.about__detail-value a{text-decoration:underline;text-underline-offset:2px}.education{background:var(--c-bg-warm)}.timeline{position:relative;padding-left:2rem}.timeline::before{content:'';position:absolute;left:5px;top:8px;bottom:8px;width:1px;background:var(--c-border)}.timeline__item{position:relative;padding-bottom:2.5rem}.timeline__item:last-child{padding-bottom:0}.timeline__marker{position:absolute;left:-2rem;top:8px;width:11px;height:11px;border-radius:50%;background:var(--c-bg-warm);border:2px solid var(--c-accent);z-index:1}.timeline__date{display:block;font-size:.75rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--c-accent);margin-bottom:.35rem}.timeline__heading{font-family:var(--f-display);font-size:1.375rem;font-weight:500;color:var(--c-text);margin-bottom:.2rem}.timeline__sub{font-size:.9375rem;color:var(--c-text-muted);margin-bottom:.5rem}.timeline__desc{font-size:.9375rem;line-height:1.7;color:var(--c-text-muted)}.timeline__desc a{text-decoration:underline;text-underline-offset:2px}.timeline__desc em{font-style:italic;color:var(--c-text)}.experience{background:var(--c-bg)}.experience .timeline__marker{background:var(--c-bg)}.publications{background:var(--c-bg-warm)}.pub-group{margin-bottom:2.5rem}.pub-group:last-child{margin-bottom:0}.pub-group__title{font-family:var(--f-display);font-size:1.125rem;font-weight:500;color:var(--c-text);padding-bottom:.75rem;border-bottom:1px solid var(--c-border);margin-bottom:1.5rem}.pub{display:flex;gap:1rem;margin-bottom:1.75rem}.pub:last-child{margin-bottom:0}.pub__accent{flex-shrink:0;width:3px;border-radius:3px;background:var(--c-accent)}.pub__body{flex:1}.pub__title{font-family:var(--f-display);font-size:1.0625rem;font-weight:500;color:var(--c-text);margin-bottom:.35rem;line-height:1.4}.pub__authors{font-size:.875rem;color:var(--c-text-muted);margin-bottom:.25rem}.pub__venue{font-size:.8125rem;color:var(--c-text-muted);margin-bottom:.5rem}.pub__badge{display:inline-block;font-size:.75rem;font-weight:600;color:var(--c-accent-dark);background:rgba(194,120,92,.1);padding:.25rem .75rem;border-radius:100px;margin-bottom:.5rem}.pub__links{display:flex;gap:1rem}.pub__links a{font-size:.8125rem;font-weight:500;color:var(--c-accent);text-decoration:none;transition:color .2s var(--ease)}.pub__links a:hover{color:var(--c-accent-dark)}.awards{background:var(--c-bg)}.awards .timeline__marker{background:var(--c-bg)}.award__venue{font-size:.875rem;color:var(--c-text-muted);line-height:1.5}.contact{background:var(--c-bg-warm)}.contact__lead{font-size:1.0625rem;color:var(--c-text-muted);margin-bottom:2rem;max-width:520px}.contact__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.contact__card{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem 1rem;background:var(--c-card-bg);border:1px solid var(--c-border);border-radius:12px;text-align:center;transition:all .25s var(--ease);text-decoration:none}.contact__card:hover{border-color:var(--c-accent);box-shadow:0 4px 20px rgba(194,120,92,8%);transform:translateY(-2px)}.contact__icon{width:28px;height:28px;color:var(--c-accent)}.contact__label{font-size:.6875rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--c-text-muted)}.contact__value{font-size:.8125rem;color:var(--c-text);font-weight:500}.footer{padding:2rem 0;border-top:1px solid var(--c-border);background:var(--c-bg)}.footer__inner{display:flex;justify-content:space-between;align-items:center}.footer__copy{font-size:.8125rem;color:var(--c-text-muted)}.footer__copy a{text-decoration:underline;text-underline-offset:2px}.footer__links{display:flex;gap:1rem}.footer__links a{color:var(--c-text-muted);transition:color .2s var(--ease)}.footer__links a:hover{color:var(--c-accent)}.blog-list{min-height:calc(100vh - var(--nav-h) - 100px);padding-top:calc(var(--nav-h) + env(safe-area-inset-top,0px) + var(--s-section));background:var(--c-bg)}.blog-list__subtitle{font-size:1.0625rem;color:var(--c-text-muted);margin-top:.5rem}.blog-list__posts{margin-top:2rem}.blog-list__post{padding:1.5rem 0;border-bottom:1px solid var(--c-border)}.blog-list__post:first-child{border-top:1px solid var(--c-border)}.blog-list__date{font-size:.75rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--c-text-muted)}.blog-list__title{font-family:var(--f-display);font-size:1.375rem;font-weight:500;margin:.35rem 0}.blog-list__title a{color:var(--c-text);text-decoration:none;transition:color .2s var(--ease)}.blog-list__title a:hover{color:var(--c-accent)}.blog-list__excerpt{font-size:.9375rem;color:var(--c-text-muted);line-height:1.6}.blog-list__empty{margin-top:3rem;padding:3rem;text-align:center;color:var(--c-text-muted);font-size:1rem;border:1px dashed var(--c-border);border-radius:12px}.blog-post{padding-top:calc(var(--nav-h) + env(safe-area-inset-top,0px) + 3rem);padding-bottom:var(--s-section);background:var(--c-bg)}.blog-post__container{max-width:720px}.blog-post__back{display:inline-block;font-size:.8125rem;color:var(--c-text-muted);margin-bottom:2rem;transition:color .2s var(--ease)}.blog-post__back:hover{color:var(--c-accent)}.blog-post__date{display:block;font-size:.75rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--c-text-muted);margin-bottom:.75rem}.blog-post__title{font-family:var(--f-display);font-size:clamp(2rem,4vw,2.75rem);font-weight:400;line-height:1.2;color:var(--c-text);margin-bottom:.75rem}.blog-post__desc{font-size:1.125rem;color:var(--c-text-muted);line-height:1.5;margin-bottom:2.5rem;padding-bottom:2.5rem;border-bottom:1px solid var(--c-border)}.prose{font-size:1.0625rem;line-height:1.85;color:var(--c-text)}.prose h2{font-family:var(--f-display);font-size:1.75rem;font-weight:500;margin:2.5rem 0 1rem;color:var(--c-text)}.prose h3{font-family:var(--f-display);font-size:1.375rem;font-weight:500;margin:2rem 0 .75rem}.prose p{margin-bottom:1.25rem}.prose ul,.prose ol{margin-bottom:1.25rem;padding-left:1.5rem}.prose li{margin-bottom:.35rem}.prose a{color:var(--c-accent);text-decoration:underline;text-underline-offset:3px}.prose blockquote{border-left:3px solid var(--c-accent);padding-left:1.25rem;margin:1.5rem 0;color:var(--c-text-muted);font-style:italic}.prose code{font-size:.9em;background:rgba(0,0,0,5%);padding:.15em .4em;border-radius:4px}.prose pre{background:var(--c-bg-hero);color:var(--c-text-light);padding:1.25rem;border-radius:8px;overflow-x:auto;margin:1.5rem 0}.prose pre code{background:0 0;padding:0;color:inherit}.prose img{border-radius:8px;margin:1.5rem 0}.blog-post__footer{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--c-border)}.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s var(--ease),transform .6s var(--ease)}.reveal.revealed{opacity:1;transform:translateY(0)}.timeline__item.reveal:nth-child(2){transition-delay:.1s}.pub.reveal:nth-child(2){transition-delay:.1s}.pub.reveal:nth-child(3){transition-delay:.2s}.contact__card.reveal:nth-child(2){transition-delay:.05s}.contact__card.reveal:nth-child(3){transition-delay:.1s}.contact__card.reveal:nth-child(4){transition-delay:.15s}.contact__card.reveal:nth-child(5){transition-delay:.2s}@media(max-width:860px){.about__grid{grid-template-columns:200px 1fr;gap:2rem}.about__detail{grid-template-columns:1fr;gap:.25rem}.contact__grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}}@media(max-width:640px){.nav__toggle{display:flex}.nav__links{position:fixed;top:calc(var(--nav-h) + env(safe-area-inset-top,0px));left:0;right:0;flex-direction:column;background:rgba(250,247,242,.98);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:1.5rem 2rem;gap:1.25rem;border-bottom:1px solid var(--c-border);transform:translateY(-110%);visibility:hidden;transition:transform .3s var(--ease),visibility .3s;z-index:999}.nav__links.active{transform:translateY(0);visibility:visible}.nav__links a{color:var(--c-text)!important;font-size:.9375rem}.hero__name{font-size:clamp(2.5rem,12vw,3.5rem)}.hero__chinese{display:block;margin-left:0;margin-top:.25rem}.hero__actions{flex-direction:column}.hero__actions>:first-child{margin-right:0}.about__grid{grid-template-columns:1fr;text-align:center}.about__photo-frame{max-width:200px;margin:0 auto;aspect-ratio:1;border-radius:50%}.about__photo-frame::after{border-radius:50%}.about__details{text-align:left}.about__detail{grid-template-columns:1fr}.award{flex-direction:column;gap:.75rem}.footer__inner{flex-direction:column;gap:1rem;text-align:center}.contact__grid{grid-template-columns:1fr 1fr}}@media(max-width:400px){.contact__grid{grid-template-columns:1fr}}