:root{color-scheme:light;font-family:Iowan Old Style,Georgia,Songti SC,"Noto Serif CJK SC","Noto Serif SC",serif;background:#fafaf8;color:#1a1a1a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:auto;--background: #fafaf8;--surface: #fffdf7;--surface-muted: rgba(184, 134, 11, .09);--surface-strong: rgba(184, 134, 11, .16);--text: #1a1a1a;--text-body: #403b34;--text-muted: #55504a;--border: rgba(26, 26, 26, .22);--border-strong: rgba(26, 26, 26, .42);--primary: #b8860b;--primary-dark: #8f6508;--accent: #b8860b;--max-width: 1380px}*{box-sizing:border-box}html{scroll-behavior:smooth}@keyframes projectDetailReveal{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes projectDetailRuleReveal{0%{transform:scaleX(0)}to{transform:scaleX(1)}}body{min-width:320px;margin:0;background:var(--background);color:var(--text);font-weight:400}a{color:inherit;text-decoration:none}button,a{-webkit-tap-highlight-color:transparent}button{font:inherit}a:focus-visible,button:focus-visible,[role=button]:focus-visible{outline:2px solid rgba(184,134,11,.45);outline-offset:3px}.site-shell{min-height:100vh}.skip-link{position:fixed;top:12px;left:12px;z-index:100;transform:translateY(-160%);border:1px solid var(--border-strong);border-radius:3px;background:var(--surface);color:var(--text);font-size:14px;font-weight:600;padding:10px 14px;transition:transform .16s ease}.skip-link:focus-visible{transform:translateY(0)}.side-nav{position:fixed;top:50%;left:36px;transform:translateY(-50%);z-index:20;width:226px;max-height:calc(100vh - 72px);overflow-y:auto;border-left:1px solid var(--border);background:var(--background);padding:4px 0 4px 22px}.brand{display:block;color:var(--text);font-size:21px;font-weight:600;letter-spacing:0;line-height:1.3;padding:0 0 22px}.nav-links{display:flex;flex-direction:column;gap:6px}.nav-group{display:grid;gap:4px}.nav-links a{color:var(--text-muted);font-size:15px;font-variant-caps:all-small-caps;font-weight:500;line-height:1.25;padding:8px 0;transition:background-color .16s ease,color .16s ease}.nav-links a:hover,.nav-links a:focus-visible,.nav-links a.active{background:transparent;color:var(--primary-dark);outline:none}.project-subnav{display:grid;gap:2px;margin:1px 0 6px 12px;padding-left:12px;border-left:1px solid var(--border)}.project-subnav a{color:var(--text-muted);font-size:12.5px;font-variant-caps:normal;font-weight:500;line-height:1.35;padding:5px 0}.project-subnav a:hover,.project-subnav a:focus-visible,.project-subnav a.active{color:var(--primary-dark)}.page-content{width:min(var(--max-width),calc(100% - 64px));margin:0 auto;padding-left:220px}.hero-section{display:grid;grid-template-columns:minmax(0,1fr) 320px;column-gap:72px;row-gap:18px;align-items:stretch;padding:88px 0 18px;border-bottom:1px solid var(--border)}.hero-copy{grid-column:1;grid-row:1;min-width:0}.hero-copy h1{max-width:900px;margin:0;color:var(--text);font-size:clamp(44px,6.4vw,72px);font-weight:500;line-height:1.04;letter-spacing:0}.hero-intro{max-width:700px;margin:28px 0 0;color:var(--text-body);font-size:18px;font-weight:450;line-height:1.85}.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:32px}.hero-tags{grid-column:1;grid-row:2;padding-top:4px}.tag-row{display:grid;grid-template-columns:repeat(2,minmax(220px,1fr));gap:12px 16px;max-width:720px}.tag{display:inline-flex;align-items:center;justify-content:flex-start;min-height:46px;border:1px solid rgba(26,26,26,.22);border-radius:3px;background:transparent;color:var(--text-body);font-family:Iowan Old Style,Georgia,Songti SC,"Noto Serif CJK SC",serif;font-size:15px;font-variant-caps:normal;font-weight:500;line-height:1.3;padding:10px 18px}.hero-aside{grid-column:2;grid-row:1 / span 2;display:grid;grid-template-rows:auto 1fr;align-self:stretch;width:100%;max-width:320px;height:100%;gap:14px;margin-top:0}.hero-copy h1{max-width:780px;margin:0;color:var(--text);font-size:clamp(44px,6.4vw,72px);font-weight:500;line-height:1.04;letter-spacing:0}.hero-title{margin:22px 0 0;color:var(--primary-dark);font-size:clamp(19px,3vw,28px);font-weight:500;line-height:1.32}.hero-intro{max-width:650px;margin:28px 0 0;color:var(--text-body);font-size:19px;font-weight:450;line-height:1.86}.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:36px}.button{display:inline-flex;min-height:44px;align-items:center;justify-content:center;border-radius:3px;border:1px solid transparent;font-size:14px;font-variant-caps:all-small-caps;font-weight:600;line-height:1;padding:12px 20px;transition:background-color .16s ease,border-color .16s ease,color .16s ease}.button-primary{background:var(--text);color:var(--background)}.button-primary:hover,.button-primary:focus-visible{background:var(--primary-dark);outline:none}.button-secondary{background:transparent;border-color:var(--primary);color:var(--text)}.button-secondary:hover,.button-secondary:focus-visible{background:var(--surface-muted);color:var(--primary-dark);outline:none}.profile-panel,.profile-photo-frame,.text-panel,.skill-card,.project-card,.project-detail,.contact-section{background:var(--surface);border:1px solid var(--border);border-radius:3px}.profile-photo-frame{aspect-ratio:4 / 4;margin:0;overflow:hidden;background:var(--surface-muted)}.profile-photo-frame img{display:block;width:100%;height:100%;object-fit:cover;object-position:center 42%}.profile-panel{height:100%;padding:22px 22px 24px}.profile-panel dl{display:grid;gap:16px;margin:0}.profile-panel div{border-bottom:1px solid var(--border);padding-bottom:14px}.profile-panel div:last-child{border-bottom:0;padding-bottom:0}.profile-panel dt{margin-bottom:7px;color:var(--text-muted);font-size:12px;font-variant-caps:all-small-caps;font-weight:600}.profile-panel dd{margin:0;color:var(--text);font-weight:500;line-height:1.45;overflow-wrap:anywhere}.profile-panel a{color:var(--primary-dark)}.hero-tags{grid-column:1 / -1;padding-top:48px}.tag-row{display:grid;grid-template-columns:repeat(2,260px);gap:10px 14px;justify-content:start}.tag{display:inline-flex;align-items:center;justify-content:flex-start;min-height:42px;width:260px;border:1px solid rgba(26,26,26,.22);border-radius:3px;background:transparent;color:var(--text-body);font-family:Iowan Old Style,Georgia,Songti SC,"Noto Serif CJK SC",serif;font-size:15px;font-variant-caps:normal;font-weight:500;letter-spacing:.01em;line-height:1.3;padding:10px 16px}.tag-count{color:var(--primary-dark)}.content-section{scroll-margin-top:86px;padding:48px 0;border-bottom:1px solid var(--border)}.section-heading{display:flex;align-items:end;justify-content:space-between;gap:24px;margin-bottom:22px}.section-heading h2{margin:0;color:var(--text);font-size:clamp(30px,4vw,44px);font-weight:500;letter-spacing:0;line-height:1.15}.section-heading p{max-width:660px;margin:0;color:var(--text-body);font-size:16px;font-weight:450;line-height:1.75}.section-heading-wide{align-items:start;flex-direction:column;gap:10px}.text-panel{width:100%;max-width:none;padding:30px 34px}.text-panel p,.detail-section p,.contact-section p,.project-card p{color:var(--text-body);font-size:16px;font-weight:450;line-height:1.86}.text-panel p{max-width:960px;margin:0}.text-panel p+p{margin-top:14px}.skill-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px;border-top:1px solid var(--border);padding-top:28px}.skill-card{min-height:0;border:0;border-left:1px solid var(--border);background:transparent;padding:0 0 0 18px}.skill-card h3{margin:0 0 18px;color:var(--text);font-size:22px;font-weight:500;line-height:1.25}.skill-list{display:grid;gap:9px;margin:0;padding:0;list-style:none}.skill-list li{color:var(--text-body);font-size:15px;font-variant-caps:all-small-caps;font-weight:500;line-height:1.35}.project-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.project-card{display:flex;min-height:100%;flex-direction:column;justify-content:space-between;overflow:hidden;position:relative;isolation:isolate;transition:background-color .18s ease,border-color .18s ease,box-shadow .18s ease,transform .18s ease}.project-card:before{content:"";position:absolute;top:0;right:0;left:0;z-index:-1;height:5px;background:var(--primary);opacity:.18;transform:scaleX(.18);transform-origin:left;transition:opacity .18s ease,transform .22s ease}.project-card-interactive{cursor:pointer}.project-card-interactive:hover{border-color:var(--border-strong);background:var(--surface-muted);box-shadow:0 16px 36px #1a1a1a17;transform:translateY(-3px)}.project-card-interactive:hover:before,.project-card-open:before{opacity:1;transform:scaleX(1)}.project-card-interactive:focus-visible{border-color:var(--primary);outline:2px solid rgba(184,134,11,.22);outline-offset:3px}.project-card-open{border-color:var(--primary);background:var(--surface-strong);box-shadow:0 14px 34px #b8860b1f}.project-card-body{display:grid;gap:16px;padding:26px 24px 24px}.project-card-topline{display:flex;align-items:center;justify-content:space-between;gap:14px;color:var(--text-muted);font-size:12.5px;font-variant-caps:all-small-caps;font-weight:700;line-height:1.2}.project-card-topline span:first-child{color:var(--primary-dark);font-size:20px;font-weight:500}.project-card h3{margin:0;color:var(--text);font-size:23px;font-weight:500;line-height:1.3}.project-subtitle{margin:5px 0 0;color:var(--primary-dark);font-size:16px;font-weight:500}.project-timeline{margin:10px 0 0;color:var(--text-muted);font-size:13px;font-variant-caps:all-small-caps;font-weight:600;line-height:1.3}.project-card p{margin:0}.project-kicker{color:var(--primary-dark);font-size:12px;font-variant-caps:all-small-caps;font-weight:600;letter-spacing:0;line-height:1.2}.project-role{color:var(--text);font-weight:500}.project-card-footer{border-top:1px solid var(--border);color:var(--text-muted);font-size:13px;font-variant-caps:all-small-caps;font-weight:600;line-height:1.2;margin:auto 24px 0;padding:14px 0 18px}.project-card-open .project-card-footer{color:var(--primary-dark)}.project-detail{scroll-margin-top:36px;position:relative;overflow:hidden;margin-top:24px;border-color:#b8860b6b;background:#fffbf0;padding:30px;box-shadow:0 18px 48px #1a1a1a14;animation:projectDetailReveal .36s ease both}.project-detail:before{content:"";position:absolute;top:0;right:0;left:0;height:4px;background:var(--primary);transform-origin:left;animation:projectDetailRuleReveal .48s ease both}.project-detail>*{position:relative}.project-detail-header{display:grid;grid-template-columns:minmax(0,.9fr) minmax(280px,1.1fr);gap:30px;align-items:start;border-bottom:1px solid var(--border);padding-bottom:24px}.project-detail-header h3{margin:0;color:var(--text);font-size:clamp(24px,4vw,34px);font-weight:500;line-height:1.2}.project-detail-header p{margin:8px 0 0;color:var(--primary-dark);font-size:17px;font-weight:500}.project-detail-timeline{display:inline-block;margin-top:12px;color:var(--text-muted);font-size:13px;font-variant-caps:all-small-caps;font-weight:600;line-height:1.3}.detail-tags{justify-content:flex-end}.detail-copy{display:grid;gap:28px;padding-top:30px}.detail-section h4,.media-panel h4{margin:0 0 10px;color:var(--text);font-size:17px;font-variant-caps:all-small-caps;font-weight:600;line-height:1.35}.detail-section p{margin:0;max-width:760px}.detail-section p+p{margin-top:10px}.media-panel{border-top:1px solid var(--border);margin-top:34px;padding-top:28px}.media-panel-header{display:flex;align-items:baseline;justify-content:space-between;gap:24px;margin-bottom:16px}.media-panel-header h4{margin:0}.media-panel-header span{color:var(--text-body);font-size:14px;font-weight:500;line-height:1.4;text-align:right}.media-stage{width:100%;border:1px solid var(--border);background:#1a1a1a}.media-placeholder{display:flex;min-height:min(58vh,620px);align-items:center;justify-content:center;background:var(--background);color:var(--text-muted);font-size:16px;line-height:1.45;padding:30px;text-align:center}.media-placeholder span{display:grid;gap:4px}.media-placeholder b{color:var(--primary-dark);font-size:12px;font-weight:500}.media-asset{display:block;width:100%;max-height:min(68vh,760px);object-fit:contain}.media-switcher{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:0;border:1px solid var(--border);border-top:0}.media-switcher button{display:flex;min-height:56px;align-items:center;gap:10px;border:0;border-right:1px solid var(--border);border-bottom:1px solid var(--border);background:transparent;color:var(--text-body);cursor:pointer;font-size:14px;font-weight:500;line-height:1.35;padding:12px 14px;text-align:left;transition:background-color .16s ease,color .16s ease}.media-switcher button:nth-child(4n),.media-switcher button:last-child{border-right:0}.media-switcher button span{color:var(--primary);font-size:12px;font-variant-caps:all-small-caps}.media-switcher button:hover,.media-switcher button:focus-visible,.media-switcher button.active{background:var(--surface-muted);color:var(--text);outline:none}.project-detail-actions{display:flex;justify-content:flex-end;border-top:1px solid var(--border);margin-top:28px;padding-top:22px}.project-collapse{min-height:42px;border:1px solid var(--border-strong);border-radius:3px;background:var(--surface);color:var(--text);cursor:pointer;font-size:14px;font-variant-caps:all-small-caps;font-weight:600;line-height:1;padding:11px 18px;transition:background-color .16s ease,border-color .16s ease,color .16s ease}.project-collapse:hover,.project-collapse:focus-visible{border-color:var(--primary);background:var(--surface-muted);color:var(--primary-dark);outline:none}.contact-section{display:flex;scroll-margin-top:86px;align-items:center;justify-content:space-between;gap:24px;margin:66px 0 96px;padding:30px}.contact-section h2{margin:0 0 8px;font-weight:500;font-size:clamp(26px,4vw,36px)}.contact-section p{max-width:690px;margin:0}.contact-actions{display:flex;flex:0 0 auto;flex-wrap:wrap;justify-content:flex-end;gap:10px}.contact-wechat{display:inline-flex;min-height:44px;align-items:center;justify-content:center;gap:8px;border:1px solid var(--border);border-radius:3px;color:var(--text);font-size:14px;font-weight:600;line-height:1;padding:12px 16px;white-space:nowrap}.contact-wechat span{color:var(--text-body);font-weight:600}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}.project-detail,.project-detail:before{animation:none}.project-card,.project-card:before,.button,.project-collapse,.media-switcher button{transition:none}}@media(max-width:980px){.hero-section,.project-detail-header{grid-template-columns:1fr}.hero-section{row-gap:24px;align-items:start}.hero-copy,.hero-aside,.hero-tags{grid-column:1;grid-row:auto}.hero-aside{justify-self:start;align-self:start;width:min(100%,520px);max-width:520px;height:auto}.detail-tags{justify-content:flex-start}.media-panel{border-top:1px solid var(--border);margin-top:28px;padding-top:22px}}@media(max-width:760px){.side-nav{position:fixed;top:0;left:0;transform:none;width:100%;max-height:118px;overflow-x:auto;overflow-y:hidden;border-bottom:1px solid var(--border);border-left:0;background:#fafaf8f5;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:10px 14px 9px}.brand{font-size:17px;line-height:1.2;padding:0 4px 7px}.nav-links{flex-direction:row;gap:12px;overflow-x:auto;padding-bottom:1px}.nav-group{flex:0 0 auto}.nav-links a{flex:0 0 auto;min-height:44px;display:inline-flex;align-items:center;font-size:14px;padding:7px 0;white-space:nowrap}.project-subnav{display:none}.page-content{width:min(100% - 28px,var(--max-width));padding-left:0;padding-top:118px}.hero-section{display:grid;grid-template-columns:1fr;gap:22px;padding:34px 0 38px}.hero-copy h1{max-width:100%;font-size:clamp(40px,14vw,56px);line-height:1.04}.hero-title{font-size:19px;line-height:1.35}.hero-intro{font-size:16px;line-height:1.75}.hero-actions{margin-top:26px}.hero-aside{width:100%;max-width:none;grid-template-columns:104px minmax(0,1fr);grid-template-rows:auto;align-items:stretch;gap:12px}.profile-photo-frame{width:104px;aspect-ratio:1}.profile-panel{min-width:0;padding:14px}.profile-panel dl{gap:10px}.profile-panel div{padding-bottom:9px}.profile-panel dt{margin-bottom:4px;font-size:10px}.profile-panel dd{font-size:13px;line-height:1.32}.hero-tags{padding-top:8px}.tag-row{display:flex;flex-wrap:wrap;gap:8px;max-width:100%}.tag{width:auto;min-width:0;min-height:34px;font-size:13px;padding:7px 10px}.button{width:100%}.section-heading{align-items:flex-start;flex-direction:column;gap:10px}.project-grid,.skill-grid{grid-template-columns:1fr}.project-card-interactive:hover{box-shadow:none;transform:none}.project-card-body{padding:22px 18px 20px}.project-card-footer{margin:auto 18px 0}.project-card-topline{align-items:flex-start;flex-direction:column;gap:6px}.skill-card{padding:0 0 0 16px}.project-detail,.text-panel{padding:18px}.project-detail{scroll-margin-top:116px}.media-panel-header{align-items:flex-start;flex-direction:column;gap:6px}.media-panel-header span{text-align:left}.media-switcher{grid-template-columns:1fr}.media-switcher button{border-right:0}.project-detail-actions{justify-content:stretch}.project-collapse{width:100%}.contact-section{align-items:stretch;flex-direction:column;margin-bottom:48px;padding:20px}.contact-actions{justify-content:stretch}.contact-wechat{width:100%}}@media(max-width:420px){.hero-aside{grid-template-columns:86px minmax(0,1fr)}.profile-photo-frame{width:86px}.profile-panel{padding:12px}.profile-panel dd{font-size:12.5px}}.pdf-shell{background:#fafaf8}.pdf-shell .page-content{width:min(980px,calc(100% - 48px));padding-left:0}.pdf-shell .hero-section{grid-template-columns:minmax(0,1fr) 170px;column-gap:28px;row-gap:18px;align-items:start;padding:40px 0 28px}.pdf-shell .hero-copy{align-self:start}.pdf-shell .hero-copy h1{max-width:680px;font-size:46px;line-height:1.04}.pdf-shell .hero-title{margin-top:14px;font-size:20px}.pdf-shell .hero-intro{max-width:650px;margin-top:18px;font-size:15px;line-height:1.7}.pdf-shell .hero-actions,.pdf-shell .project-card-footer,.pdf-shell .project-detail-actions,.pdf-shell .media-switcher{display:none}.pdf-shell .hero-aside{grid-column:2;grid-row:1;width:170px;max-width:170px;gap:10px}.pdf-shell .profile-photo-frame{width:170px;aspect-ratio:1}.pdf-shell .profile-panel{padding:14px}.pdf-shell .profile-panel dl{gap:10px}.pdf-shell .profile-panel div{padding-bottom:9px}.pdf-shell .profile-panel dt{margin-bottom:4px;font-size:9px}.pdf-shell .profile-panel dd{font-size:11px;line-height:1.35}.pdf-shell .hero-tags{grid-column:1;grid-row:auto;padding-top:0}.pdf-shell .tag-row{display:flex;flex-wrap:wrap;grid-template-columns:none;gap:6px;max-width:none}.pdf-shell .tag{width:auto;min-height:0;font-size:10px;line-height:1.2;padding:4px 7px}.pdf-shell .content-section{padding:30px 0}.pdf-shell .section-heading{margin-bottom:16px}.pdf-shell .section-heading h2{font-size:30px}.pdf-shell .text-panel,.pdf-shell .contact-section{padding:20px}.pdf-shell .text-panel p,.pdf-shell .detail-section p,.pdf-shell .contact-section p{font-size:12.5px;line-height:1.65}.pdf-shell .skill-grid{gap:16px}.pdf-project-list{display:grid;gap:22px}.pdf-project{border:1px solid var(--border);border-radius:3px;background:var(--surface);padding:22px}.pdf-project-heading{display:grid;grid-template-columns:minmax(0,1fr);gap:12px;border-bottom:1px solid var(--border);padding-bottom:14px}.pdf-project-number{margin:0 0 8px;color:var(--primary-dark);font-size:11px;font-variant-caps:all-small-caps;font-weight:700}.pdf-project-heading h3{margin:0;color:var(--text);font-size:24px;font-weight:500;line-height:1.18}.pdf-project-heading p{margin:6px 0 0;color:var(--primary-dark);font-size:13px;font-weight:500}.pdf-shell .detail-copy{gap:16px;padding-top:18px}.pdf-shell .detail-section h4,.pdf-media-panel h4{margin-bottom:6px;font-size:13px}.pdf-media-panel{border-top:1px solid var(--border);margin-top:18px;padding-top:14px}.pdf-media-panel figure{margin:0}.pdf-media-panel img{display:block;width:100%;max-height:360px;object-fit:contain;border:1px solid var(--border);background:#1a1a1a}.pdf-media-panel figcaption,.pdf-media-note{color:var(--text-muted);font-size:11px;line-height:1.45;margin-top:8px}@page{size:A4;margin:13mm}@media print{html,body{background:#fff}body{-webkit-print-color-adjust:exact;print-color-adjust:exact}.pdf-shell .page-content{width:100%;margin:0;padding:0}.pdf-shell .hero-section{break-after:page;padding-top:0}.pdf-shell .content-section{border-bottom:0;padding:0}.pdf-shell .text-panel,.pdf-shell .skill-grid,.pdf-shell .contact-section{break-inside:avoid}.pdf-project{break-before:page;break-inside:auto;box-shadow:none}.pdf-project:first-child{break-before:auto}.pdf-project-heading,.detail-section,.pdf-media-panel{break-inside:avoid}.pdf-shell .project-card,.pdf-shell .project-grid{display:none}}
