:root{color:#291334;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f8f4ef;font-family:Avenir Next,Inter,PingFang SC,Microsoft YaHei,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:#efe6db;min-width:320px;margin:0}button,a{font:inherit}a{color:inherit}#root{min-height:100vh}.site-shell{color:#291334;background:#f8f4ef;min-height:100vh;padding:12px 22px 32px}.site-toolbar{z-index:50;justify-content:flex-end;display:flex;position:fixed;top:12px;right:22px}.language-switch{background:#fffdfb;border:1px solid #29133414;border-radius:999px;align-items:center;gap:2px;padding:5px;display:inline-flex}.language-button{color:#29133499;cursor:pointer;background:0 0;border:0;border-radius:999px;padding:7px 12px;font-size:.88rem}.language-button.active{color:#291334;background:#f6ece3}.site-layout{grid-template-columns:300px minmax(0,1fr);align-items:start;gap:28px;max-width:1400px;margin:0 auto;display:grid}.sidebar{background:#f0e9e2;border-radius:0;align-self:start;min-height:calc(100vh - 24px);padding:18px 22px 20px;position:sticky;top:12px}.avatar-shell{justify-content:center;margin-bottom:26px;display:flex}.avatar-photo{object-fit:cover;object-position:center;border:6px solid #fffaf6e0;border-radius:999px;width:200px;height:200px;box-shadow:0 10px 24px #29133414}.sidebar-intro{text-align:center;justify-items:center;gap:6px;margin-bottom:22px;display:grid}.sidebar-intro h1,.hero-block h1,.hero-block h2,.page-intro h1,.content-section h2,.project-body h3,.experience-body h3{color:#291334;margin:0;font-family:Segoe UI,PingFang SC,sans-serif}.sidebar-intro h1{font-size:1.45rem;font-weight:700;line-height:1.15}.sidebar-intro p,.hero-block p,.page-intro p,.paragraph-stack p,.project-summary,.experience-role,.contact-card,.sidebar-contact{color:#291334db;margin:0;font-size:.99rem;line-height:1.72}.sidebar-nav{gap:8px;margin-top:4px;display:grid}.sidebar-link{color:#291334;text-align:left;cursor:pointer;background:0 0;border:0;border-radius:999px;width:100%;padding:12px 18px;font-size:.92rem}.sidebar-link.active{background:#ffffff57}.sidebar-contacts{gap:10px;margin-top:24px;padding-left:14px;padding-right:14px;display:grid}.sidebar-contact{gap:2px;display:grid}.sidebar-contact span,.contact-label,.project-tag,.experience-period{color:#29133494;letter-spacing:.06em;text-transform:uppercase;font-size:.75rem}.sidebar-contact strong,.contact-card strong{color:#291334;font-weight:600}.linkable{text-decoration:none}.content-area{padding:34px 10px 28px 6px}.content-stack{gap:44px;max-width:980px;display:grid}.compact-stack{max-width:760px}.hero-block{gap:14px;display:grid}.hero-eyebrow{color:#291334b8;font-size:1rem;font-weight:600}.hero-block h1{font-size:clamp(2.15rem,4.4vw,3.1rem);font-weight:800;line-height:1.02}.hero-block h2{font-size:clamp(1.45rem,3vw,2rem);font-weight:750;line-height:1.08}.lang-zh .sidebar-intro h1,.lang-zh .hero-block h1,.lang-zh .hero-block h2,.lang-zh .page-intro h1,.lang-zh .content-section h2,.lang-zh .project-body h3,.lang-zh .experience-body h3{font-family:PingFang SC,Noto Sans SC,Microsoft YaHei,sans-serif}.lang-zh .hero-eyebrow{font-size:.92rem}.lang-zh .hero-block h1{letter-spacing:-.02em;font-size:clamp(1.9rem,3.8vw,2.65rem);font-weight:700;line-height:1.08}.lang-zh .hero-block h2{font-size:clamp(1.25rem,2.5vw,1.72rem);font-weight:650;line-height:1.16}.lang-zh .content-section h2,.lang-zh .page-intro h1{font-size:clamp(1.36rem,2.5vw,1.82rem);font-weight:700}.lang-zh .sidebar-intro p,.lang-zh .hero-block p,.lang-zh .page-header p,.lang-zh .paragraph-stack p,.lang-zh .project-summary,.lang-zh .experience-role,.lang-zh .contact-card,.lang-zh .sidebar-contact{font-size:.94rem;line-height:1.82}.lang-zh .project-body h3,.lang-zh .experience-body h3{font-size:1rem;font-weight:700}.hero-actions{flex-wrap:wrap;gap:16px;padding-top:10px;display:flex}.filled-button,.outlined-button,.project-link{border-radius:999px;justify-content:center;align-items:center;font-size:.94rem;text-decoration:none;display:inline-flex}.filled-button,.outlined-button{cursor:pointer;border:0;padding:16px 22px}.filled-button{color:#291334;background:#f2ebe4}.outlined-button{color:#291334;background:0 0;border:1px solid #2913344d}.content-section,.page-intro{gap:14px;display:grid}.works-intro{gap:18px;margin-bottom:20px}.page-intro h1{margin-bottom:0}.content-section h2,.page-intro h1{font-size:clamp(1.55rem,3vw,2.1rem);font-weight:800;line-height:1.08}.paragraph-stack{gap:14px;display:grid}.paragraph-stack.compact{gap:10px}.section-heading-row{justify-content:space-between;align-items:baseline;gap:14px;display:flex}.subtle-link{color:#291334ad;cursor:pointer;background:0 0;border:0;padding:0;font-size:.92rem}.soft-section{background:#fffdfbbd;border:1px solid #2913340f;border-radius:18px;padding:18px 20px}.extras-list{gap:12px;display:grid}.extra-item{gap:4px;display:grid}.extra-item strong{color:#291334;font-size:.9rem}.extra-item span{color:#291334cc;font-size:.9rem;line-height:1.7}.project-list,.experience-list,.contact-list{gap:0;display:grid}.project-row,.experience-row{grid-template-columns:280px minmax(0,1fr);gap:24px;padding:22px 0;display:grid}.project-row+.project-row,.experience-row+.experience-row{border-top:1px solid #2913341a}.project-thumb{background:#f3f1ef;border-radius:22px;place-items:center;min-height:170px;display:grid;overflow:hidden}.project-thumb.has-video{background:#120d17;padding:0}.project-thumb span{color:#291334b8;letter-spacing:0;font-size:2rem;font-weight:500}.project-video-trigger{aspect-ratio:16/10;cursor:pointer;background:linear-gradient(135deg,#efe4da 0%,#f7f1eb 100%);border:0;width:100%;min-height:170px;padding:0;position:relative;overflow:hidden}.project-video-preview{object-fit:contain;background:#120d17;width:100%;height:100%;display:block}.project-video-overlay{color:#fffdfb;background:linear-gradient(#120d1714 0%,#120d176b 100%);flex-direction:column;justify-content:center;align-items:center;gap:10px;transition:background .2s;display:flex;position:absolute;inset:0}.project-video-trigger:hover .project-video-overlay{background:linear-gradient(#120d1724 0%,#120d1785 100%)}.project-play-icon{color:#291334;background:#fffdfbeb;border-radius:999px;justify-content:center;align-items:center;width:54px;height:54px;padding-left:3px;font-size:1.2rem;display:inline-flex}.project-play-text{letter-spacing:.04em;font-size:.88rem;font-weight:600}.project-body,.experience-body{gap:10px;display:grid}.project-body h3,.experience-body h3{font-size:1.08rem;font-weight:800;line-height:1.24}.project-summary{font-size:1rem}.contact-list{gap:14px}.video-modal-backdrop{z-index:80;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#120d17b8;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.video-modal{background:#fffaf6;border-radius:28px;gap:16px;width:min(1080px,100%);padding:18px;display:grid;box-shadow:0 24px 80px #120d173d}.video-modal-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.video-modal-header h3{color:#291334;margin:6px 0 0;font-size:1.15rem;font-weight:800}.video-modal-close{color:#291334b3;cursor:pointer;background:0 0;border:0;font-size:2rem;line-height:1}.video-modal-player{background:#120d17;border-radius:20px;width:100%;max-height:76vh}.contact-card{background:#fffdfb;border:1px solid #29133414;border-radius:20px;gap:4px;padding:18px 20px;display:grid}@media (width<=1080px){.site-layout{grid-template-columns:1fr}.sidebar{border-radius:26px;min-height:auto;position:static}.project-row,.experience-row{grid-template-columns:1fr}}@media (width<=720px){.site-shell{padding:14px 14px 28px}.content-area{padding:6px 0 22px}.hero-block h1{font-size:2.55rem}.hero-block h2,.content-section h2,.page-intro h1{font-size:1.8rem}.section-heading-row{flex-direction:column;align-items:flex-start}.project-video-trigger{aspect-ratio:9/16;justify-self:start;max-width:240px}.video-modal-backdrop{padding:12px}.video-modal{border-radius:22px;padding:14px}.video-modal-player{max-height:68vh}}
