body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--bg-0: #e9eff8;--bg-1: #dfe8f2;--surface: rgba(251, 253, 255, .92);--surface-strong: #f8fbff;--text-strong: #1f2f44;--text-muted: #4c6078;--accent: #3f658f;--accent-soft: #dce8f7;--border: rgba(90, 112, 137, .28);--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.5rem;--space-6: 2rem;--space-7: 2.5rem;--space-8: 3rem;--radius-sm: 10px;--radius-md: 16px;--radius-lg: 24px;--shadow-sm: 0 8px 20px rgba(29, 47, 70, .08);--shadow-md: 0 20px 45px rgba(26, 45, 69, .12);--shadow-lg: 0 30px 70px rgba(18, 33, 53, .15);--font-sans-en: "Manrope", "Inter", "Segoe UI", sans-serif;--font-sans-zh: "Noto Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif;--font-mono: "JetBrains Mono", "SFMono-Regular", Menlo, monospace}*,*:before,*:after{box-sizing:border-box}html,body,#root{min-height:100%}html[lang^=en] body{font-family:var(--font-sans-en)}html[lang^=zh] body{font-family:var(--font-sans-zh)}body{margin:0;color:var(--text-strong);background:linear-gradient(155deg,var(--bg-0) 0%,var(--bg-1) 100%);line-height:1.6}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:radial-gradient(circle at 10% 15%,rgba(255,255,255,.65),transparent 38%),radial-gradient(circle at 90% 85%,rgba(90,118,150,.1),transparent 42%)}.page-shell{min-height:100vh;display:grid;place-items:center;padding:clamp(var(--space-4),4vw,var(--space-7))}.container{position:relative;width:min(840px,100%);display:grid;grid-template-columns:1.35fr .85fr;grid-template-areas:"hero profile" "about profile" "links links" "projects projects";gap:var(--space-6);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:clamp(var(--space-5),3vw,var(--space-8));animation:card-in .26s ease-out both}.hero{grid-area:hero;display:grid;gap:var(--space-3);align-content:start;padding-right:7.5rem}.about{grid-area:about}.profile{grid-area:profile;align-self:center;justify-self:center}.links-section{grid-area:links;border-top:1px solid rgba(84,110,141,.2);padding-top:var(--space-5)}.projects-section{grid-area:projects;border-top:1px solid rgba(84,110,141,.2);padding-top:var(--space-5)}.projects-header{margin-bottom:var(--space-4)}.projects-subtitle{margin-top:var(--space-2)}.language-selector{position:absolute;top:clamp(var(--space-4),2.4vw,var(--space-6));right:clamp(var(--space-4),2.4vw,var(--space-6));z-index:2}.language-button{display:inline-flex;align-items:center;gap:var(--space-2);cursor:pointer;border:1px solid var(--border);border-radius:999px;background:linear-gradient(180deg,#fff,#f2f6fb);color:var(--text-strong);font-weight:600;font-size:.88rem;padding:.42rem .9rem}.dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);padding:.3rem;display:grid;gap:.2rem;opacity:0;transform:translateY(-6px);pointer-events:none;transition:opacity .18s ease,transform .18s ease;min-width:120px}.dropdown.visible{opacity:1;transform:translateY(0);pointer-events:auto}.dropdown button{border:none;border-radius:8px;background:transparent;color:var(--text-strong);font-size:.9rem;display:flex;align-items:center;gap:var(--space-2);width:100%;text-align:left;padding:.45rem .6rem;cursor:pointer}.dropdown button[aria-checked=true]{background:var(--accent-soft);font-weight:700}.language-check{width:1rem;display:inline-block;color:var(--accent)}.eyebrow{margin:0;color:var(--accent);font-size:.76rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase}h1{margin:0;color:var(--text-strong);font-size:clamp(2rem,3.6vw,2.8rem);line-height:1.15;letter-spacing:-.03em}.subtitle{margin:0;color:var(--text-muted);font-size:clamp(1rem,2.1vw,1.12rem);line-height:1.65}h2{margin:0 0 var(--space-3);font-size:clamp(1.15rem,2vw,1.45rem);color:var(--text-strong);font-weight:600;letter-spacing:-.01em}p{margin:0;color:var(--text-muted);font-size:clamp(1rem,1.7vw,1.08rem);line-height:1.65}.headshot{display:block;width:clamp(170px,23vw,240px);height:clamp(170px,23vw,240px);object-fit:cover;border-radius:50%;border:1px solid rgba(80,105,134,.35);box-shadow:var(--shadow-sm),inset 0 1px 6px #ffffffb3;transition:transform .22s ease,box-shadow .22s ease}.headshot:hover{transform:translateY(-2px) rotate(-1deg);box-shadow:var(--shadow-md),inset 0 1px 6px #ffffffb3}.links{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-3)}.projects-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-3)}.project-card{display:flex;flex-direction:column;gap:var(--space-3);min-height:100%;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-strong);box-shadow:var(--shadow-sm);padding:var(--space-4)}.project-card h3{margin:0;font-size:1.08rem;line-height:1.3;color:var(--text-strong)}.project-card p{margin:0;font-size:.96rem;line-height:1.6}.project-tech-list{list-style:none;display:flex;flex-wrap:wrap;gap:var(--space-2);margin:0;padding:0}.project-tech-list li{font-size:.76rem;font-weight:700;letter-spacing:.02em;color:var(--accent);background:var(--accent-soft);border-radius:999px;padding:.2rem .55rem}.project-actions{margin-top:auto;display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.project-actions a,.project-soon{display:inline-flex;align-items:center;justify-content:center;min-height:2rem;border-radius:999px;padding:.22rem .72rem;font-size:.8rem;font-weight:700;text-decoration:none}.project-actions a{color:var(--text-strong);border:1px solid var(--border);background:#fff}.project-actions a:hover{background:var(--accent-soft)}.project-soon{color:var(--text-muted);border:1px dashed var(--border);background:#f5f8fc}.link-pill{display:inline-flex;align-items:center;justify-content:flex-start;gap:.68rem;padding:.58rem .75rem;border-radius:999px;border:1px solid var(--border);background:var(--surface-strong);box-shadow:var(--shadow-sm);text-decoration:none;color:var(--text-strong);font-weight:600;transform:translateY(4px);opacity:0;animation:link-in .28s ease forwards}.link-pill:nth-child(1){animation-delay:40ms}.link-pill:nth-child(2){animation-delay:90ms}.link-pill:nth-child(3){animation-delay:.14s}.link-pill:nth-child(4){animation-delay:.19s}.link-pill:nth-child(5){animation-delay:.24s}.link-pill:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.linkImage{width:34px;height:34px;flex-shrink:0}.linkText{font-size:.96rem}.links a:focus-visible,.project-actions a:focus-visible,.language-button:focus-visible,.dropdown button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@keyframes card-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes link-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@media(max-width:920px){.container{width:min(760px,100%);grid-template-columns:1fr;grid-template-areas:"hero" "profile" "about" "links" "projects";gap:var(--space-5)}.profile{justify-self:start}}@media(max-width:1023px){.projects-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:640px){.page-shell{padding:var(--space-4)}.container{padding:var(--space-5);border-radius:var(--radius-md)}.hero{padding-right:0}.language-selector{position:relative;top:auto;right:auto;margin-bottom:var(--space-2)}.links,.projects-grid{grid-template-columns:1fr}.link-pill{width:100%}}@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.headshot:hover,.link-pill:hover{transform:none}}
