:root{--bg:#f7f6f2;--bg-soft:#ffffffd1;--panel:#ffffffb8;--panel-strong:#ffffffeb;--border:#27364a1f;--border-strong:#1b499338;--text:#445469;--text-muted:#6e7c90;--title:#1d2a3a;--accent:#1f4c8f;--accent-soft:#1f4c8f0f;--accent-strong:#16386a;--shadow:0 10px 26px #8591a014;--radius-lg:10px;--radius-md:8px;--radius-sm:6px;--content-width:972px;--font-sans:"Segoe UI Variable Text", "Bahnschrift", "Segoe UI", sans-serif;--font-serif:"Iowan Old Style", "Palatino Linotype", "Book Antiqua", Georgia, serif;--font-mono:"Cascadia Code", "SFMono-Regular", Consolas, monospace;font-family:var(--font-sans);color:var(--text);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(#fbfaf7 0%,#f6f4ef 100%);font-size:90%;font-weight:400;line-height:1.55}*{box-sizing:border-box}html{scroll-behavior:smooth;scrollbar-gutter:stable}body{min-width:320px;min-height:100vh;margin:0;overflow-y:scroll}button,a{-webkit-tap-highlight-color:transparent}button{font:inherit}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}#app{min-height:100vh}.app-shell{min-height:100vh;position:relative;overflow:visible}.backdrop{pointer-events:none;opacity:.8;background:linear-gradient(90deg,#1f4c8f08,#0000 24% 76%,#1f4c8f08);position:fixed;inset:0}.site-header__sentinel{pointer-events:none;width:1px;height:1px;position:absolute;top:0;left:0}.site-header{z-index:10;-webkit-backdrop-filter:blur();backdrop-filter:blur();width:100%;box-shadow:none;background:0 0;border-bottom:1px solid #0000;border-radius:0;padding:16px 0;transition:background-color .18s,border-color .18s,box-shadow .18s,-webkit-backdrop-filter .18s,backdrop-filter .18s,padding .18s;position:sticky;top:0}.site-header.is-pinned{border-bottom-color:var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#f7f6f2eb;box-shadow:0 6px 18px #8591a01f}.site-header__inner,.content-shell{width:min(calc(100% - 32px), var(--content-width));margin:0 auto}.site-header__inner{justify-content:space-between;align-items:center;gap:20px;display:flex}.site-header__main{align-items:center;gap:18px;min-width:0;display:flex}.site-header__brand{cursor:pointer;align-items:center;gap:14px;display:flex}.site-header__divider{background:var(--border);flex:none;width:1px;height:28px}.site-header__mark{border:1px solid var(--border);width:36px;height:36px;color:var(--title);font-family:var(--font-mono);background:#ffffffb3;border-radius:50%;place-items:center;font-size:.82rem;display:grid}.site-header__name,.site-header__meta,.eyebrow,.metric-card__label,.project-card__meta,.timeline__period,.status-pill,.project-list__meta,.resume-hero__facts span{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin:0;font-size:.72rem}.site-header__name{color:var(--title)}.site-header__nav{align-items:center;gap:18px;display:flex}.site-header__icons{align-items:center;gap:12px;display:flex}.site-header__lang{position:relative}.site-header__icon{min-height:34px;color:var(--text-muted);border-radius:999px;justify-content:center;align-items:center;gap:8px;padding:0 10px;display:inline-flex;overflow:visible}.site-header__icon svg{width:19px;height:19px;overflow:visible}.site-header__icon:hover{color:var(--title)}.site-header__icon span{letter-spacing:.04em;font-size:.84rem}.site-header__lang-trigger,.site-header__lang-option{font:inherit}.site-header__lang-trigger{border:1px solid var(--border);min-height:34px;color:var(--text-muted);cursor:pointer;background:#ffffffa8;border-radius:999px;align-items:center;gap:8px;padding:0 12px;transition:border-color .18s,background-color .18s,color .18s,transform .18s;display:inline-flex}.site-header__lang-trigger:hover{color:var(--title);border-color:var(--border-strong);background:#ffffffe6;transform:translateY(-1px)}.site-header__lang-flag{font-size:.96rem;line-height:1}.site-header__lang-label{letter-spacing:.04em;font-size:.84rem}.site-header__lang-caret{opacity:.7;font-size:.75rem}.site-header__lang-menu{border:1px solid var(--border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fffffff5;border-radius:12px;gap:6px;min-width:148px;padding:10px;display:grid;position:absolute;top:calc(100% + 10px);right:0;box-shadow:0 12px 28px #8591a029}.site-header__lang-option{min-height:38px;color:var(--text);text-align:left;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:10px;align-items:center;gap:10px;padding:0 12px;transition:border-color .18s,background-color .18s,color .18s;display:inline-flex}.site-header__lang-option:hover,.site-header__lang-option.is-active{border-color:var(--border);color:var(--title);background:#1f4c8f0f}.site-header__link,.button,.text-link,.project-list__item{transition:transform .18s,border-color .18s,background-color .18s,color .18s,box-shadow .18s}.site-header__link{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:0;padding:8px 0}.site-header__link:hover,.site-header__link.is-active{color:var(--title);background:0 0}.content-shell{padding:28px 0 56px;position:relative}.page{gap:34px;animation:.42s page-enter;display:grid}.page-project{gap:34px}@keyframes page-enter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.projects-fade-enter-active{transition:opacity .22s,transform .22s}.projects-fade-enter-from{opacity:0;transform:translateY(8px)}.projects-fade-leave-active{transition:none}.projects-fade-leave-to{opacity:1;transform:none}.panel{border-top:1px solid var(--border);box-shadow:none;background:0 0;border-radius:0}.hero-panel,.project-hero,.resume-hero,.contact-strip{gap:24px;padding:26px 0 0;display:grid}.hero-panel,.project-hero{grid-template-columns:1fr}.project-cover{border-top:none;width:100vw;margin-top:-28px;margin-left:calc(50% - 50vw)}.project-cover__image{object-fit:cover;cursor:zoom-in;width:100%;max-height:48vh}.hero-panel__body,.project-hero__body{flex-direction:column;align-items:flex-start;display:flex}h1,h2,h3,p,ol,ul{margin:0}h1,h2,h3{color:var(--title)}h1,h2{font-family:var(--font-serif);font-weight:500}h1{letter-spacing:-.045em;font-size:clamp(2.6rem,6vw,4.4rem);line-height:1.02}html[lang=zh-CN] .project-hero h1{font-family:var(--font-sans);letter-spacing:.01em;font-size:clamp(2.15rem,5vw,3.4rem);font-weight:600;line-height:1.18}h2{font-size:clamp(1.5rem,2.5vw,2.1rem);line-height:1.08}h3{font-size:1.15rem;font-weight:600;line-height:1.25}.hero-panel__title,.resume-hero__title{color:var(--accent);font-family:var(--font-mono);margin-top:14px;font-size:.86rem}.project-hero__subtitle{color:var(--accent);font-family:var(--font-mono), "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Noto Sans CJK SC", sans-serif;margin-top:14px;font-size:.86rem;font-weight:500;line-height:1.45}html[lang=zh-CN] .project-hero__subtitle,html[lang=zh-CN] .hero-panel__title,html[lang=zh-CN] .resume-hero__title{font-family:var(--font-sans);letter-spacing:.01em;font-weight:550;line-height:1.38}.project-hero__actions .button svg{flex:none;width:.95rem;height:.95rem}.hero-panel__intro,.project-hero__summary{max-width:42rem;color:var(--title);margin-top:18px;font-size:1.1rem}.hero-panel__statement,.detail-text,.timeline__item p,.side-card__content p,.resume-note p,.project-card__summary{color:var(--text-muted)}.hero-panel__statement{max-width:44rem;margin-top:14px}.hero-panel__actions,.project-hero__actions{flex-wrap:wrap;gap:14px;margin-top:30px;display:flex}.button,.text-link{border:1px solid var(--border);min-height:42px;color:var(--title);cursor:pointer;background:#ffffff8f;border-radius:999px;justify-content:center;align-items:center;gap:8px;padding:0 16px;display:inline-flex}.button:hover,.text-link:hover,.project-list__item:hover,.site-header__link:hover{transform:translateY(-1px)}.button:hover{background:#fffc}.button--primary{background:#1f4c8f0f;border-color:#1f4c8f2e}.metrics-grid,.resume-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px 28px;display:grid}.metric-card,.resume-card{padding:18px 0 0}.metric-card{border:1px solid var(--border);background:#ffffff75;border-radius:4px;padding:18px 18px 16px}.metric-card__value{color:var(--title);font-family:var(--font-serif);font-size:clamp(1.45rem,2.5vw,2.3rem)}.metric-card__label{margin-top:10px}.split-section{grid-template-columns:repeat(2,minmax(0,1fr));gap:30px;display:grid}.editorial-section{grid-template-columns:220px minmax(0,1fr);align-items:start;gap:28px;display:grid}.page-project .editorial-section{margin-top:18px}.page-project .editorial-section:first-of-type{margin-top:26px}.page-project .editorial-section+.editorial-section{margin-top:0}.page-project .editorial-section:first-of-type .section-label,.page-project .editorial-section:first-of-type .section-body{border-top:none;padding-top:0}.section-label{gap:8px;display:grid;position:sticky;top:92px}.section-body{min-width:0}.section-body--boxed{border:1px solid var(--border);background:#ffffff80;border-radius:4px;padding:22px 24px}.project-tabs{border-bottom:none;flex-wrap:wrap;gap:12px;margin-bottom:0;padding:0;display:flex}.project-tab{border:1px solid var(--border);min-height:42px;color:var(--text-muted);cursor:pointer;background:#fffc;border-radius:999px;padding:0 18px}.project-tab.is-active{border-color:var(--accent);color:var(--title);background:#1f4c8f14}.projects-toolbar{border:1px solid var(--border);background:#ffffff8a;border-radius:8px;gap:18px;margin-bottom:22px;padding:18px;display:grid}.projects-search{gap:10px;display:grid}.projects-search__label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);font-size:.8rem}.projects-search__input{border:1px solid var(--border);width:100%;min-height:46px;color:var(--title);font:inherit;background:#ffffffd1;border-radius:6px;padding:0 14px}.projects-search__input:focus{border-color:var(--accent);outline:none}.home-preview-grid{grid-template-columns:repeat(1,minmax(0,1fr));align-items:start;gap:18px;display:grid}.home-preview-grid__column{align-content:start;gap:18px;display:grid}.home-preview-card{border:1px solid var(--border);text-align:left;cursor:pointer;background:#ffffff9e;border-radius:8px;align-content:start;width:100%;padding:0;display:grid;overflow:hidden}.home-preview-card:hover{border-color:var(--border-strong);background:#ffffffd1}.home-preview-card__thumb{aspect-ratio:16/10;object-fit:cover;border-bottom:1px solid var(--border);width:100%}.home-preview-card__thumb--placeholder{color:var(--text-muted);background:linear-gradient(135deg,#1f4c8f0f,#ffffffe6),repeating-linear-gradient(-45deg,#1f4c8f0a,#1f4c8f0a 10px,#ffffffb3 10px 20px);place-items:center;padding:20px;display:grid}.home-preview-card__thumb--placeholder span{text-align:center;max-width:14ch;line-height:1.3}.home-preview-card__body{align-content:start;gap:8px;padding:16px;display:grid}.home-preview-card__summary{color:var(--text-muted)}.home-preview-card__tags{flex-wrap:wrap;gap:8px;margin-top:4px;display:flex}.home-preview-card__tags .tag{color:var(--text-muted);background:#ffffffb3;border-color:#27364a14;padding:5px 9px;font-size:.78rem}.home-preview-actions{margin-top:14px}.section-card,.resume-note{padding:22px 0 0}.section-heading{gap:8px;margin-bottom:18px;display:grid}.list-clean{margin:0;padding:0;list-style:none}.focus-list,.bullet-list{gap:14px;margin:0;padding:0;list-style:none;display:grid}.focus-list li,.bullet-list li{padding-left:24px;position:relative}.focus-list li:before,.bullet-list li:before{content:"";background:var(--accent-strong);width:8px;height:8px;box-shadow:0 0 0 6px var(--accent-soft);border-radius:999px;position:absolute;top:.59em;left:0}.timeline{gap:20px;display:grid}.timeline__item{border-top:1px solid var(--border);grid-template-columns:110px minmax(0,1fr);gap:18px;padding:16px 0;display:grid}.timeline__item:before{display:none}.timeline__content h3{margin-bottom:8px}.timeline__heading{justify-content:space-between;align-items:start;gap:20px;display:flex}.timeline__toggle{color:var(--accent);white-space:nowrap;flex:none}.education-panel{border:1px solid var(--border);background:#ffffff70;border-radius:8px;margin-top:14px;padding:14px 16px;overflow:hidden}.education-course-groups{gap:16px;display:grid}.education-course-group{border-top:1px solid var(--border);gap:10px;padding-top:16px;display:grid}.education-course-group:first-child{border-top:none;padding-top:0}.education-course-group__title{color:var(--accent);font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;margin:0;font-size:.82rem}.education-course-list{gap:10px;display:grid}.education-course-list__item{grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:8px 18px;display:grid}.education-course-list__main{grid-template-columns:auto minmax(0,1fr);align-items:start;gap:10px;min-width:0;display:grid}.education-course-list__main>*{align-self:start}a.education-course-list__main{color:inherit;text-decoration:none;transition:color .18s}a.education-course-list__main:hover{color:var(--accent)}.education-course-list__item span{margin:0}.education-course-list__code{color:var(--text-muted);font-family:var(--font-mono);letter-spacing:.06em;align-self:start;font-size:.82rem}.education-course-list__code--featured{color:var(--accent);letter-spacing:.08em;font-weight:700}.education-course-list__name{align-self:start;min-width:0;line-height:1.32;display:block;transform:translateY(-.1em)}.education-course-list__grade{color:var(--title);font-family:var(--font-mono);text-align:right;flex:none;place-self:start end;font-size:.86rem}.education-panel__notes{border-top:1px solid var(--border);gap:8px;margin-top:16px;padding-top:12px;display:grid}.education-panel__note{color:var(--text-muted);margin:0;font-size:.88rem}.education-panel-enter-active,.education-panel-leave-active{transition:opacity .22s,transform .22s,max-height .22s,margin-top .22s,padding-top .22s,padding-bottom .22s}.education-panel-enter-from,.education-panel-leave-to{opacity:0;max-height:0;margin-top:0;padding-top:0;padding-bottom:0;transform:translateY(-6px)}.education-panel-enter-to,.education-panel-leave-from{opacity:1;max-height:1200px;transform:translateY(0)}.section-stack{gap:18px;display:grid}.project-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:0 36px;display:grid}.project-listing,.side-listing{gap:16px;display:grid}.project-card,.side-card{overflow:visible}.project-hero__image{object-fit:cover;width:100%}.project-card__content,.side-card__content{padding:0}.project-card{border:1px solid var(--border);cursor:pointer;background:#ffffff9e;border-radius:8px;width:100%;padding:0}.project-card:hover{border-color:var(--border-strong);background:#ffffffd1}.project-card__content{text-align:left;background:0 0;grid-template-columns:180px minmax(280px,1.35fr) minmax(160px,.65fr) auto;align-items:start;gap:20px;padding:18px;display:grid}.project-card__head{gap:6px;min-width:0;display:grid}.project-card__head h3{-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}html[lang=zh-CN] .home-preview-card__body h3,html[lang=zh-CN] .project-card__head h3,html[lang=zh-CN] .project-list__item h3,html[lang=zh-CN] .timeline__content h3,html[lang=zh-CN] .resume-award-item h3{font-family:var(--font-sans);letter-spacing:.01em;font-weight:550;line-height:1.38}.project-card__thumb{aspect-ratio:4/3;object-fit:cover;border:1px solid var(--border);background:#fff;border-radius:4px;width:100%}.project-card__thumb--placeholder,.project-hero__image--placeholder{color:var(--text-muted);background:linear-gradient(135deg,#1f4c8f0f,#ffffffe6),repeating-linear-gradient(-45deg,#1f4c8f0a,#1f4c8f0a 10px,#ffffffb3 10px 20px);place-items:center;padding:20px;display:grid}.project-card__thumb--placeholder span,.project-hero__image--placeholder span{text-align:center;max-width:14ch;line-height:1.3}.project-card__subtitle{color:var(--title);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;margin-top:8px;display:-webkit-box;overflow:hidden}.project-card__summary{max-width:42rem}.project-card__summary-wrap{align-self:stretch;min-width:0;position:relative}.project-card__summary-wrap .project-card__summary{-webkit-line-clamp:5;line-clamp:5;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.project-card__more{color:var(--accent);white-space:nowrap;background:linear-gradient(90deg,#fff0,#fffffff5 30%);padding-left:.65rem;font-size:.84rem;position:absolute;bottom:0;right:0}.text-link{min-height:auto;color:var(--accent);background:0 0;border:none;border-radius:0;justify-self:end;margin-top:0;padding:0}.text-link:hover{color:var(--accent-strong)}.side-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.side-card{border-top:1px solid var(--border)}.side-card:before{display:none}.side-card__content{padding-top:18px}.contact-strip{grid-template-columns:minmax(0,.7fr) minmax(0,1.3fr);align-items:end}.contact-strip__links{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.contact-link{border:1px solid var(--border);background:#ffffff6b;border-radius:4px;gap:10px;padding:16px 18px;display:grid}.contact-link strong{color:var(--title);font-weight:600}.project-hero__image{border:1px solid var(--border);aspect-ratio:16/10;object-fit:cover;width:100%;max-width:780px}.tag-row{flex-wrap:wrap;gap:8px;margin-top:18px;display:flex}.tag,.status-pill{border:1px solid var(--border);background:#ffffff8f;border-radius:999px;padding:8px 12px}.project-hero .tag{color:var(--text-muted);background:#ffffffb8;border-color:#27364a14;padding:5px 9px;font-size:.78rem}.status-pill{min-height:36px;color:var(--title);letter-spacing:.08em;text-transform:uppercase;background:#ffffff8f;align-items:center;padding:0 12px;font-size:.76rem;display:inline-flex}.project-list{gap:10px;padding:0;display:grid}.project-list__item{border-top:1px solid #0000;border-bottom:1px solid var(--border);width:100%;color:inherit;text-align:left;cursor:pointer;background:0 0;border-left:none;border-right:none;border-radius:0;grid-template-columns:minmax(0,.8fr) minmax(0,1.2fr);align-items:center;gap:16px;padding:18px 0;display:grid}.project-list__item.is-active{border-top-color:var(--accent);background:0 0}.resume-hero{grid-template-columns:minmax(0,1fr);align-items:end}.resume-hero__body{gap:14px;display:grid}.resume-hero__contact,.resume-entry__org{color:var(--text-muted)}.resume-hero__contact{flex-wrap:wrap;align-items:center;gap:.4rem;display:inline-flex}.resume-hero__contact-icon{width:1.15rem;height:1.15rem;color:var(--accent);flex:none;justify-content:center;align-items:center;display:inline-flex}.resume-hero__contact-icon svg{width:100%;height:100%}.resume-hero__contact a{color:inherit;text-decoration:none}.resume-hero__contact a:hover{color:var(--title);text-decoration:underline}.resume-prose{gap:16px;max-width:54rem;display:grid}.resume-detail-list{gap:0;display:grid}.resume-detail-item{border-top:1px solid var(--border);grid-template-columns:180px minmax(0,1fr);gap:20px;padding:14px 0;display:grid}.resume-detail-item:first-child{border-top:none;padding-top:0}.resume-detail-item h3,.resume-detail-item p{margin:0}.resume-detail-item h3{color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;font-size:.82rem;font-weight:500}.resume-detail-item p{color:var(--title);font-size:1rem;line-height:1.7}.resume-detail-item__content{gap:4px;display:grid}.resume-detail-item__content p{margin:0}.resume-awards-list{gap:0;display:grid}.resume-award-item{border-top:1px solid var(--border);gap:6px;padding:14px 0;display:grid}.resume-award-item:first-child{border-top:none;padding-top:0}.resume-award-item h3,.resume-award-item p{margin:0}.resume-award-item h3{color:var(--title);font-size:.98rem;font-weight:600}.resume-award-item p{color:var(--text-muted)}.resume-hero__facts{gap:14px;display:grid}.resume-hero__facts div{border-bottom:1px solid var(--border);background:0 0;padding:14px 0}.resume-hero__facts strong{color:var(--title);margin-top:8px;font-size:1.02rem;display:block}.resume-note{font-size:1rem}.project-article{gap:24px;display:grid}.project-article strong{color:var(--title);font-weight:600}.project-article a[href]{color:var(--accent);text-underline-offset:.16em;-webkit-text-decoration:underline #1f4c8f47;text-decoration:underline #1f4c8f47;transition:color .18s,text-decoration-color .18s}.project-article a[href]:hover{color:var(--accent-strong);text-decoration-color:#16386a75}.project-article code{color:var(--accent-strong);font-family:"Courier New", var(--font-mono);vertical-align:baseline;background:#1f4c8f0f;border:1px solid #27364a1f;border-radius:6px;margin:0 .14em;padding:.1em .45em;font-size:.92em;line-height:1.2;display:inline-block}.project-article pre{background:linear-gradient(#f9fafcfa,#f2f5f9fa);border:1px solid #27364a1f;border-top:none;border-radius:0 0 10px 10px;margin:0;padding:18px 20px;overflow-x:auto;box-shadow:inset 0 1px #ffffff73}.project-article pre code{color:#24364d;font-family:"Courier New", var(--font-mono);white-space:normal;background:0 0;border:none;border-radius:0;margin:0;padding:0;font-size:.9rem;line-height:1.7;display:block}.project-code-block__line{grid-template-columns:38px minmax(0,1fr);align-items:baseline;gap:14px;display:grid}.project-code-block__line-number{color:#6e7c90b8;font-variant-numeric:tabular-nums;text-align:right;-webkit-user-select:none;user-select:none}.project-code-block__line-content{white-space:pre;display:block}.project-code-block{border-radius:10px;margin-top:16px;margin-bottom:16px;overflow:hidden;box-shadow:0 4px 12px #8591a00d}.project-code-block__toolbar{background:#ebf0f6f0;border:1px solid #27364a1f;border-bottom:none;border-radius:10px 10px 0 0;justify-content:space-between;align-items:center;gap:12px;min-height:42px;padding:0 14px 0 16px;display:flex}.project-code-block__label{color:var(--text-muted);font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;font-size:.78rem}.project-code-block__copy{min-height:30px;color:var(--title);font:inherit;cursor:pointer;background:#ffffffc7;border:1px solid #27364a1f;border-radius:999px;padding:0 10px;font-size:.82rem;transition:background-color .18s,border-color .18s,color .18s}.project-code-block__copy:hover{color:var(--accent-strong);background:#fffffff5;border-color:#1f4c8f2e}.project-article .token--comment{color:#728196}.project-article .token--string{color:#9b5d2a}.project-article .token--keyword{color:#1f4c8f;font-weight:600}.project-article .token--number{color:#6b3d94}.project-article img,.project-media img{cursor:zoom-in}.project-article__section{border-top:1px solid var(--border);padding-top:18px}.project-article__section h2{margin-bottom:12px;font-size:1.45rem}.project-article__section p+p{margin-top:.825em}.project-media{justify-self:center;gap:8px;width:100%;margin-top:16px;display:grid}.project-media--small{max-width:420px}.project-media--portrait{max-width:360px}.project-media--medium{max-width:640px}.project-media--large{max-width:880px}.project-media--full{max-width:none}.project-media-grid{--project-media-area-height:160px;align-items:start;gap:18px;margin-top:16px;display:grid}.project-media-grid--two{--project-media-area-height:180px;grid-template-columns:repeat(2,minmax(0,1fr));padding-inline:60px}.project-media-grid--three{--project-media-area-height:130px;grid-template-columns:repeat(3,minmax(0,1fr));padding-inline:20px}.project-media-grid>.project-media{grid-template-rows:var(--project-media-area-height) auto;align-content:start;margin-top:0}.project-media img{border:1px solid var(--border);background:#ffffff8f;border-radius:8px;width:100%}.project-media-grid>.project-media>img,.project-media-grid>.project-media>.project-media__frame{object-fit:contain;place-self:stretch stretch;width:100%;max-width:100%;height:100%;max-height:100%}.project-media-grid>.project-media>figcaption{align-self:start}.project-media figcaption{color:var(--text-muted);margin:0;font-size:.9rem}.project-equation{box-sizing:border-box;gap:8px;width:100%;margin:16px 0 22px;padding-inline:14px;display:grid}.project-equation__body{background:#fafbfdf2;border:1px solid #27364a1f;border-radius:10px;justify-content:center;align-items:center;padding:14px 18px;display:flex;overflow-x:auto}.project-equation__body--plain{background:0 0;border:0;border-radius:0;padding:2px 0}.project-equation__svg{width:100%;display:block}.project-equation__svg svg{max-width:100%;height:auto;color:var(--title);margin-inline:auto;display:block}.project-equation__error{color:#9b2c2c;white-space:pre-wrap;margin:0;font:.92rem/1.55 Courier New,SFMono-Regular,Consolas,monospace}.project-equation__caption{color:var(--text-muted);text-align:center;margin:0;font-size:.9rem}.project-equation-inline{vertical-align:-.18em;align-items:baseline;margin-inline:.12em;display:inline-flex}.project-equation-inline__svg{align-items:baseline;max-width:100%;display:inline-flex}.project-equation-inline__svg svg{width:auto;max-width:none;height:1.15em;color:var(--title);display:block}.project-equation-inline__error{color:#9b2c2c;font:.92em/1.2 Courier New,SFMono-Regular,Consolas,monospace}.project-equation__source{display:none}.project-article__section .bullet-list{margin-top:12px;margin-bottom:20px}.project-article__ending{color:#1f4c8f80;font-family:var(--font-serif);place-items:center;margin-top:34px;margin-bottom:20px;font-size:1.4rem;line-height:1;display:grid}.image-lightbox{--lightbox-control-bg:#ffffff14;--lightbox-control-border:#ffffff29;--lightbox-control-text:#ffffffeb;--lightbox-control-shadow:0 8px 24px #00000029;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#141c28d1;place-items:center;padding:0;display:grid;position:fixed;inset:0}.image-lightbox--light-image{--lightbox-control-bg:#121a248a;--lightbox-control-border:#ffffff42;--lightbox-control-text:#fffffffa;--lightbox-control-shadow:0 10px 30px #00000047}.image-lightbox__viewport{cursor:default;z-index:0;touch-action:none;place-items:center;width:100%;height:100%;display:grid;overflow:hidden}.image-lightbox__stage{width:100%;height:100%;position:relative;overflow:hidden}.image-lightbox__close{border:1px solid var(--lightbox-control-border);min-height:38px;color:var(--lightbox-control-text);background:var(--lightbox-control-bg);box-shadow:var(--lightbox-control-shadow);cursor:pointer;z-index:3;border-radius:999px;padding:0 14px;position:absolute;top:18px;right:18px}.image-lightbox__nav{border:1px solid var(--lightbox-control-border);width:48px;height:48px;color:var(--lightbox-control-text);background:var(--lightbox-control-bg);box-shadow:var(--lightbox-control-shadow);cursor:pointer;z-index:3;border-radius:999px;place-items:center;display:grid;position:absolute;top:50%;transform:translateY(-50%)}.image-lightbox__nav--prev{left:24px}.image-lightbox__nav--next{right:24px}.image-lightbox__nav svg{stroke:currentColor;stroke-width:2.1px;stroke-linecap:round;stroke-linejoin:round;fill:none;width:22px;height:22px}.image-lightbox__image{transform-origin:50%;will-change:transform;cursor:grab;-webkit-user-select:none;user-select:none;z-index:1;border-radius:0;max-width:100vw;max-height:100vh;transition:transform .22s cubic-bezier(.22,.61,.36,1);position:absolute;top:50%;left:50%;box-shadow:0 24px 60px #00000047}.image-lightbox__image:active{cursor:grabbing}.image-lightbox__image--adjacent{cursor:default;pointer-events:none;opacity:.94}.image-lightbox__image--no-transition{transition:none}.image-lightbox__meta{z-index:3;gap:10px;width:min(920px,100vw - 120px);display:grid;position:absolute;bottom:20px;left:50%;transform:translate(-50%)}.image-lightbox__info,.image-lightbox__gallery{border:1px solid var(--lightbox-control-border);color:var(--lightbox-control-text);background:var(--lightbox-control-bg);box-shadow:var(--lightbox-control-shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:14px;justify-items:center;padding:12px 18px;display:grid}.image-lightbox__counter,.image-lightbox__caption{margin:0}.image-lightbox__counter{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:#ffffffb8;font-size:.82rem}.image-lightbox__caption{text-align:center;max-width:min(880px,100vw - 96px);line-height:1.45}.image-lightbox__gallery{grid-template-columns:repeat(var(--gallery-columns,1), minmax(0, 1fr));align-items:center;gap:10px;padding:12px;position:relative;overflow:hidden}.image-lightbox__thumb{cursor:pointer;opacity:.48;background:#ffffff0d;border:1px solid #ffffff24;border-radius:10px;place-items:center;min-width:0;padding:0;transition:opacity .18s,transform .18s,border-color .18s,background-color .18s;display:grid;position:relative;overflow:hidden;transform:scale(.9)}.image-lightbox__thumb.is-placeholder{opacity:0;cursor:default;pointer-events:none}.image-lightbox__thumb:hover{opacity:.82;transform:scale(.95)}.image-lightbox__thumb.is-active{opacity:1;background:#ffffff1f;border-color:#fff6;transform:scale(1)}.image-lightbox__thumb img{aspect-ratio:16/9;object-fit:cover;cursor:pointer;width:100%}.image-lightbox__gallery.has-prev-hidden:before,.image-lightbox__gallery.has-next-hidden:after{content:"";pointer-events:none;width:28px;position:absolute;top:0;bottom:0}.image-lightbox__gallery.has-prev-hidden:before{background:linear-gradient(90deg,#080c1299,#080c1200);border-radius:14px 0 0 14px;left:0}.image-lightbox__gallery.has-next-hidden:after{background:linear-gradient(270deg,#080c1299,#080c1200);border-radius:0 14px 14px 0;right:0}@media (width<=760px){.image-lightbox{padding:0}.image-lightbox__nav{top:50%;bottom:auto;transform:translateY(-50%)}.image-lightbox__nav--prev{left:18px}.image-lightbox__nav--next{right:18px}.image-lightbox__image{max-width:100vw;max-height:100vh}.image-lightbox__meta{width:calc(100vw - 36px)}.project-media-grid--two,.project-media-grid--three{grid-template-columns:1fr}}@media (width<=900px){.hero-panel,.project-hero,.resume-hero,.contact-strip,.split-section,.editorial-section,.project-grid,.side-grid,.metrics-grid,.resume-grid{grid-template-columns:1fr}.section-label{position:static}.side-card,.project-list__item,.timeline__item,.resume-detail-item{grid-template-columns:1fr}.timeline__heading{grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:8px 20px;display:grid}.contact-strip__links{grid-template-columns:1fr}}@media (width<=1024px){.project-card__content{grid-template-columns:180px minmax(0,1fr)}.project-card__summary-wrap{display:none}}@media (width>=900px){.home-preview-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width>=560px) and (width<=899px){.home-preview-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=559px){.home-preview-grid{grid-template-columns:1fr}}@media (width<=760px){:root{--radius-lg:10px;--radius-md:8px}.site-header{border-radius:0;padding:16px 0 14px;position:sticky;top:0}.site-header__inner{width:min(calc(100% - 28px), var(--content-width));flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;display:flex}.site-header__main{display:contents}.site-header__brand{text-align:left;order:1;justify-content:flex-start;margin:0}.site-header__nav{flex-wrap:wrap;flex:0 0 100%;order:3;justify-content:flex-start;gap:12px 18px}.site-header__divider{display:none}.site-header__icons{order:2;justify-content:flex-end;align-items:center;gap:12px;min-width:0;margin-left:auto;display:flex}.site-header__link{flex:none}.site-header__lang-menu{left:auto;right:0}.site-header__icon{justify-self:auto}.content-shell{width:min(calc(100% - 28px), var(--content-width));padding-top:20px;padding-bottom:28px}.timeline__heading{grid-template-columns:1fr;gap:8px}.hero-panel,.project-hero,.resume-hero,.contact-strip,.section-card,.metric-card,.resume-card,.resume-note{padding:18px 0 0}.project-card__content,.side-card__content{padding:18px}.text-link{justify-self:start}.education-course-list__item{gap:8px 12px}.education-course-list__main{gap:8px}}@media (width<=560px){.project-card__content{grid-template-columns:1fr;gap:16px}.project-card__thumb,.project-card__thumb--placeholder{aspect-ratio:16/10}}
