@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;600&family=Inter:wght@300;400;500;600&display=swap";:root{--bg: #faf9f7;--text: #1a1a1a;--muted: #7a7a7a;--line: #e8e6e1;--surface: #f4f3f0;--accent: #3d3d3d;--photo-radius: 4px;--photo-shadow: 0 12px 32px rgba(0, 0, 0, .06);--section-gap: 1.5rem;--heading-font: "Playfair Display", "Georgia", "Times New Roman", serif;--body-font: "Inter", "SF Pro Text", "Helvetica Neue", Helvetica, Arial, system-ui, sans-serif;--title-weight: 500;--ease-out: cubic-bezier(.23, 1, .32, 1);--header-h: 76px}html[lang=zh]{--heading-font: "Noto Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif;--body-font: "Noto Sans SC", "PingFang SC", "Microsoft YaHei", system-ui, sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:var(--body-font);font-size:16px;line-height:1.6;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}a:hover{text-decoration:none}h1,h2,h3,p{margin:0}.container,.site-footer{width:min(1080px,calc(100% - 4rem));margin:0 auto}.site-header{position:fixed;top:0;left:0;right:0;z-index:50;height:var(--header-h);display:flex;align-items:center;background:color-mix(in srgb,var(--bg) 92%,white 8%);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--line);font-size:.88rem}.site-header-inner{width:min(1080px,calc(100% - 4rem));margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1rem}.site-nav{display:flex;gap:1.8rem;color:var(--muted);font-size:.78rem;font-weight:400;letter-spacing:.1em;text-transform:uppercase}.site-nav a{transition:color .3s var(--ease-out)}.site-nav a:hover{color:var(--text)}.brand{font-family:var(--heading-font);font-weight:500;font-size:1.05rem;letter-spacing:.01em}.nav-toggle{display:none;width:40px;height:36px;border:1px solid var(--line);background:var(--surface);padding:.55rem .6rem;cursor:pointer}.nav-toggle-icon{width:18px;height:18px;display:block;fill:currentColor}.nav-backdrop{display:none}.container{padding:calc(var(--header-h) + 2.2rem) 0 8rem}.site-footer{padding:2.5rem 0;border-top:1px solid var(--line);color:var(--muted);font-size:.82rem;letter-spacing:.02em}.section-hero{padding:5rem 0 4rem;border-bottom:1px solid var(--line)}.hero-name{font-family:var(--heading-font);font-size:clamp(2.8rem,7vw,5rem);font-weight:400;line-height:1.05;letter-spacing:-.02em}.hero-subtitle{margin-top:1rem;font-size:1rem;color:var(--muted);font-weight:400;letter-spacing:.06em;text-transform:uppercase}.hero-divider{width:40px;height:1px;background:var(--line);margin:2rem 0}.hero-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:2.5rem}.hero-btn{display:inline-block;padding:.6rem 1.2rem;font-size:.88rem;font-weight:500;letter-spacing:.04em;text-decoration:none;color:var(--text);background:var(--surface);border:1px solid var(--line);transition:border-color .25s var(--ease-out),color .25s var(--ease-out),box-shadow .25s var(--ease-out)}.hero-btn:hover{border-color:#c8c6c1;box-shadow:0 4px 12px #0000000f}.hero-btn-secondary{color:var(--muted)}.hero-btn-secondary:hover{color:var(--text)}.hero-bio{max-width:640px;color:#444;font-size:1.02rem;line-height:1.75}.hero-bio p+p{margin-top:1rem}.hero-photo-row{display:flex;align-items:flex-start;gap:3rem;margin-top:2.5rem}.hero-photo{width:220px;height:auto;border-radius:var(--photo-radius);object-fit:cover;box-shadow:var(--photo-shadow);flex-shrink:0}.hero-bio-block{flex:1;min-width:0}.section-block{padding:3.5rem 0 3.8rem;border-bottom:1px solid var(--line);scroll-margin-top:5rem}.section-kicker{display:block;margin-bottom:1.2rem;color:var(--muted);font-size:.7rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase}.section-block h1{font-family:var(--heading-font);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:400;line-height:1.2;letter-spacing:-.01em}.section-block h2{font-family:var(--heading-font);font-size:clamp(1.5rem,2.8vw,2rem);font-weight:400;line-height:1.2;letter-spacing:-.01em}.muted{margin-top:.8rem;max-width:60ch;color:var(--muted);font-size:.98rem;line-height:1.65}.section-copy{margin-top:.8rem;max-width:68ch;color:#333}.section-copy p{font-size:.96rem;line-height:1.7}.section-copy p+p{margin-top:.9rem}.section-connect{border-bottom:none}.section-connect .muted{max-width:none}.experience-grid{margin-top:1.5rem;display:grid;grid-template-columns:1fr;gap:1rem}.experience-card-link{display:block}.experience-card{display:flex;flex-wrap:wrap;align-items:center;gap:1.2rem;justify-content:space-between;border:1px solid var(--line);background:var(--surface);padding:1.4rem 1.2rem;transition:transform .35s var(--ease-out),border-color .35s var(--ease-out),box-shadow .35s var(--ease-out)}.experience-card-link:hover .experience-card{transform:translateY(-3px);border-color:#c8c6c1;box-shadow:0 8px 24px #0000000d}.company-logo-badge{width:100px;height:auto;margin-bottom:0;display:flex;align-items:center;flex-shrink:0}.experience-main{flex:1;min-width:0}.experience-meta{text-align:right;flex-shrink:0;margin-left:1rem}.company-logo-link{display:block;height:100%}.company-logo-image{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;display:block;opacity:.5;transition:filter .35s var(--ease-out)}.company-logo-link:hover .company-logo-image{opacity:1}.experience-card h3{font-family:var(--heading-font);font-size:1.08rem;line-height:1.35;font-weight:500}.experience-role{margin-top:.35rem;font-size:.88rem;color:#444}.experience-time{margin-top:.1rem;font-size:.78rem;color:var(--muted);letter-spacing:.02em}.experience-location{margin-top:.25rem;font-size:.78rem;color:var(--muted);letter-spacing:.02em}.experience-main-project{width:100%;margin:.6rem 0 0;padding-top:.5rem;border-top:1px solid var(--line);font-size:.85rem;color:var(--muted);letter-spacing:.02em}.experience-main-project:after{content:" ›";font-size:1.2em;vertical-align:-.05em}.timeline-project-card.is-collapsible.is-collapsed .project-card-block,.timeline-project-card.is-collapsible.is-collapsed .project-card-outcomes{display:none}.timeline-project-card .project-card-title{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.timeline-project-card .project-card-title-text{flex:1;min-width:0}.project-card-toggle{display:inline-flex;align-items:center;gap:.3rem;font-size:.8rem;color:var(--muted)}.project-card-toggle-icon{width:14px;height:14px;transition:transform .2s var(--ease-out)}.timeline-project-card.is-collapsible.is-collapsed .project-card-toggle-icon{transform:rotate(0)}.timeline-project-card.is-collapsible:not(.is-collapsed) .project-card-toggle-icon{transform:rotate(180deg)}.timeline-project-card.is-collapsible .project-card-title,.timeline-project-card.is-collapsible .project-card-title-text{cursor:pointer}.projects-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;margin-top:1.5rem}.project-card-link{display:block;text-decoration:none;height:100%}.project-card{border:1px solid var(--line);background:var(--surface);padding:1.4rem 1.2rem;height:100%;display:flex;flex-direction:column;transition:transform .35s var(--ease-out),border-color .35s var(--ease-out),box-shadow .35s var(--ease-out)}.section-skills{border-top:1px solid var(--line)}.skills-list{margin-top:1.2rem;display:flex;flex-direction:column;gap:.75rem}.skill-item{display:flex;flex-direction:column;align-items:flex-start;gap:.3rem}.skill-item h3{margin:0;font-size:.85rem;font-weight:500;color:#55504a}.skill-item p{margin:0;font-size:.86rem;line-height:1.6}.skill-pill{display:inline-flex;align-items:center;padding:.35rem .7rem;border-radius:999px;font-size:.8rem;color:#4f4a44;background:#f1ede7}.skill-pill--muted{background:#e8e5e0}.skill-pill--accent{background:#e4e6ef}.skill-pill--green{background:#e3efe6}.skill-pill--chip{background:#f2e8ec}@media(min-width:768px){.skills-list{flex-direction:row;flex-wrap:wrap;gap:.9rem}.skill-item{flex:1 1 calc(50% - .9rem);max-width:calc(50% - .9rem)}}.project-card-link:hover .project-card{transform:translateY(-3px);border-color:#c8c6c1;box-shadow:0 8px 24px #0000000d}.project-card h3{font-family:var(--heading-font);font-size:1.08rem;line-height:1.35;font-weight:500}.project-tech{margin-top:.5rem;font-size:.78rem;color:var(--muted);letter-spacing:.01em}.project-summary{margin-top:.8rem;color:#444;font-size:.9rem;line-height:1.55;flex:1}.project-subtitle{margin-top:.4rem;font-size:.86rem;color:var(--muted)}.section-link{display:inline-flex;align-items:center;gap:.45rem;margin-top:1.4rem;font-size:.82rem;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;transition:color .3s var(--ease-out)}.section-link:after{content:"→";transition:transform .3s var(--ease-out)}.section-link:hover{color:var(--text)}.section-link:hover:after{transform:translate(3px)}.connect-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;margin-top:1.5rem}.connect-item{display:flex;align-items:center;gap:.8rem;text-decoration:none;padding:1.2rem 1.1rem;border:1px solid var(--line);background:var(--surface);transition:transform .35s var(--ease-out),border-color .35s var(--ease-out),box-shadow .35s var(--ease-out)}.connect-item:hover{transform:translateY(-3px);border-color:#c8c6c1;box-shadow:0 8px 24px #0000000d}.connect-icon{width:22px;height:22px;flex-shrink:0;color:var(--muted);transition:color .3s var(--ease-out)}.connect-item:hover .connect-icon{color:var(--text)}.connect-icon-img{width:22px;height:22px;flex-shrink:0;object-fit:contain}.connect-text{display:flex;flex-direction:column;gap:.15rem;min-width:0}.connect-label{font-size:.68rem;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}.connect-value{font-size:.92rem;color:var(--text)}.connect-arrow{margin-left:auto;font-size:.85rem;color:var(--muted);opacity:0;transform:translate(-4px);transition:opacity .3s var(--ease-out),transform .3s var(--ease-out)}.connect-item:hover .connect-arrow{opacity:1;transform:translate(0)}.experience-detail{max-width:780px}.detail-head{display:flex;align-items:center;gap:1.2rem}.detail-head .company-logo-badge{width:60px;height:60px;flex-shrink:0}.detail-head .company-logo-image{width:100%;height:100%;object-fit:contain}.back-link{display:inline-block;font-size:.82rem;color:var(--muted);margin-bottom:.95rem;text-transform:uppercase;letter-spacing:.06em;transition:color .3s var(--ease-out)}.back-link:hover{color:var(--text)}.experience-detail-note{margin-top:.25rem;font-size:.82rem;color:var(--muted);font-style:italic}.experience-detail-meta{margin-top:.4rem;color:var(--muted);font-size:.9rem}.experience-detail-list{margin-top:1rem;padding-left:1rem}.experience-detail-list li{color:#333;font-size:.95rem;line-height:1.7}.experience-detail-list li>ul{margin:.5rem 0 .75rem;padding-left:1.15rem}.experience-detail-list li>ul>li{margin-top:.35rem}.experience-timeline{position:relative;padding-left:2rem}.experience-timeline:before{content:"";position:absolute;left:6px;top:.5rem;bottom:.5rem;width:2px;background:var(--line)}.timeline-item{position:relative;padding-bottom:2.5rem;scroll-margin-top:5rem}.timeline-item:last-child{padding-bottom:0}.timeline-marker{position:absolute;left:-2rem;top:.35rem;width:14px;height:14px;margin-left:0;border-radius:50%;background:#5a5a5a;border:2px solid var(--bg);box-sizing:border-box}.timeline-content{margin-left:0}.timeline-content .experience-header{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.timeline-content .experience-header .company-logo-badge{width:48px;height:48px;flex-shrink:0}.timeline-content .experience-header .company-logo-image{width:100%;height:100%;object-fit:contain}.timeline-content .experience-header h2{margin:0;font-size:clamp(1.2rem,2.2vw,1.5rem)}.timeline-content .experience-detail-note{width:100%;margin-top:.2rem;margin-left:0}.timeline-content .experience-detail-meta{width:100%;margin-top:.2rem}.experience-projects{margin-top:1.25rem;display:flex;flex-direction:column;gap:1rem}.timeline-project-card{padding:1.25rem 1.35rem;background:var(--surface);border:1px solid var(--line);border-radius:2px}.timeline-project-card .project-card-title{font-family:var(--heading-font);font-size:1.05rem;font-weight:500;margin:0}.timeline-project-card .project-card-meta{margin-top:.35rem;font-size:.85rem;color:var(--muted)}.timeline-project-card .project-card-block{margin-top:1rem;font-size:.92rem;line-height:1.65;color:#333}.timeline-project-card .project-card-block strong{display:block;font-size:.8rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.35rem}.timeline-project-card .project-card-outcomes{margin-top:.5rem;padding-left:1.1rem}.timeline-project-card .project-card-outcomes li{margin-top:.35rem;font-size:.92rem;line-height:1.6}.project-list{margin-top:.8rem;padding-left:1rem}.project-list li{color:#333;font-size:.89rem;line-height:1.6}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(245px,1fr));gap:1rem;margin-top:1.2rem}.card{padding:1.2rem;background:var(--surface);border:1px solid var(--line)}.card h2,.card h3{font-family:var(--heading-font);font-size:1.2rem;font-weight:500}.button{display:inline-block;margin-top:1.25rem;padding:.6rem 1rem;border:1px solid var(--accent);font-size:.84rem;letter-spacing:.04em;text-transform:uppercase;transition:background .3s var(--ease-out),color .3s var(--ease-out)}.button:hover{background:var(--text);color:var(--bg)}.lead{margin-top:1.4rem;max-width:62ch;color:var(--muted);font-size:clamp(1rem,1.8vw,1.18rem)}.arrow-link{display:inline-flex;align-items:center;gap:.4rem;margin-top:.95rem;font-weight:500}.arrow-link:after{content:"→";transition:transform .3s var(--ease-out)}.arrow-link:hover:after{transform:translate(3px)}.qr-modal{display:none;position:fixed;inset:0;z-index:100;align-items:center;justify-content:center}.qr-modal.is-open{display:flex}.qr-modal-backdrop{position:absolute;inset:0;background:#00000073;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.qr-modal-content{position:relative;background:#fff;padding:2rem;text-align:center;box-shadow:0 20px 60px #00000026}.qr-modal-img{width:220px;height:220px;object-fit:contain;display:block;margin:0 auto}.qr-modal-text{margin-top:1rem;font-size:.88rem;color:var(--muted)}.qr-modal-close{position:absolute;top:.5rem;right:.8rem;border:none;background:transparent;font-size:1.5rem;color:var(--muted);cursor:pointer;line-height:1;transition:color .2s}.qr-modal-close:hover{color:var(--text)}.lang-switcher{position:fixed;right:1.2rem;bottom:1.2rem;z-index:20;display:inline-flex;align-items:center;gap:.25rem;padding:.4rem .6rem;border:1px solid var(--line);background:color-mix(in srgb,var(--bg) 94%,white 6%);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);font-size:.78rem}.lang-btn{color:var(--muted);font-size:.78rem;padding:.15rem .3rem;text-decoration:none;transition:color .2s var(--ease-out)}.lang-btn.is-active{color:var(--text);font-weight:600}.lang-divider{color:var(--line);font-size:.78rem;user-select:none}ul{margin:1rem 0 0;padding-left:1rem}li+li{margin-top:.55rem}@media(max-width:720px){:root{--header-h: 66px}.container,.site-footer{width:min(1200px,calc(100% - 2rem))}.site-header{height:var(--header-h)}.site-header-inner{width:min(1200px,calc(100% - 2rem))}.nav-toggle{display:inline-flex;align-items:center;justify-content:center;gap:0}.nav-backdrop{display:block;position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000059;opacity:0;pointer-events:none;transition:opacity .25s var(--ease-out);z-index:55}.site-nav{position:fixed;top:0;right:0;height:100vh;width:min(320px,84vw);padding:calc(var(--header-h) + 1rem) 1.2rem 1.2rem;display:flex;flex-direction:column;gap:1rem;background:var(--bg);border-left:1px solid var(--line);transform:translate(100%);transition:transform .3s var(--ease-out);z-index:60}.site-nav a{font-size:.9rem;letter-spacing:.08em}html.nav-open .nav-backdrop{opacity:1;pointer-events:auto}html.nav-open .site-nav{transform:translate(0)}.section-hero{padding:3rem 0 2.5rem}.hero-name{font-size:clamp(2rem,9vw,3rem)}.hero-photo-row{flex-direction:column;align-items:center;gap:1.5rem}.hero-photo{width:200px}.section-block{padding:2.5rem 0}.projects-row,.experience-grid{grid-template-columns:1fr}.section-experience .experience-card{flex-direction:row;align-items:center;gap:1rem}.section-experience .company-logo-badge{width:60px;height:auto}.section-experience .experience-meta{text-align:right;margin-left:auto;display:block}.section-experience .experience-location:before{content:none}.section-education .experience-card{flex-direction:column;align-items:flex-start;gap:.9rem;justify-content:flex-start}.section-education .company-logo-badge{margin-bottom:.6rem}.section-education .experience-meta{text-align:left;margin-left:0;display:flex;align-items:center;gap:.4rem}.section-education .experience-time,.section-education .experience-location{margin-top:0}.section-education .experience-location:before{content:"|";margin:0 .25rem 0 0;color:var(--muted)}.connect-row{grid-template-columns:1fr}.detail-head{align-items:flex-start}.lang-switcher{right:.6rem;bottom:.6rem}}
