:root{--buncss-light:initial;--buncss-dark: ;color-scheme:light dark;--fg:var(--buncss-light,#0a0a0a)var(--buncss-dark,#f5f5f5);--fg-dim:var(--buncss-light,#6b7280)var(--buncss-dark,#9ca3af);--bg:var(--buncss-light,#fafaf7)var(--buncss-dark,#111113);--bg-soft:var(--buncss-light,#f2f1ee)var(--buncss-dark,#1a1a1c);--border:var(--buncss-light,#e8e8e8)var(--buncss-dark,#232327);--radius:14px;--max:1800px;--space-4:4px;--space-8:8px;--space-12:12px;--space-16:16px;--space-20:20px;--space-24:24px;--space-32:32px;--space-40:40px;--space-48:48px;--space-64:64px;--space-section:clamp(32px,5vw,64px);--space-gutter:clamp(20px,3vw,32px)}@media (prefers-color-scheme:dark){:root{--buncss-light: ;--buncss-dark:initial}}html[data-theme=light]{--buncss-light:initial;--buncss-dark: ;color-scheme:light}html[data-theme=dark]{--buncss-light: ;--buncss-dark:initial;color-scheme:dark}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font:17px/1.55 -apple-system,BlinkMacSystemFont,Inter,Segoe UI,system-ui,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif}a{color:inherit}img{display:block;max-width:100%}:focus-visible{outline:2px solid var(--fg);outline-offset:2px;border-radius:2px}.visually-hidden{position:absolute;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0}.skip-link{position:absolute;top:var(--space-8);left:var(--space-8);background:var(--fg);color:var(--bg);padding:var(--space-8)var(--space-16);border-radius:var(--space-4);text-decoration:none;z-index:100;transition:transform .15s;transform:translateY(-200%)}.skip-link:focus{transform:translateY(0)}h1,h2{margin:var(--space-section)0 var(--space-16);letter-spacing:-.01em;font-size:1rem;font-weight:600}:is(h1,h2):first-child{margin-top:0}.card{border:1px solid var(--border);padding:var(--space-24);background:var(--bg);border-radius:16px;box-shadow:0 2px 4px #0000000a}.card--outline{background:0 0}.intro p{margin:0 0 var(--space-16)}.intro p:last-child{margin-bottom:0}.intro ul{margin:var(--space-16)0;padding-left:var(--space-20);list-style:circle}.intro li{margin-bottom:var(--space-4)}.prose{max-width:720px}.prose h1{margin:0 0 var(--space-8);letter-spacing:-.025em;font-size:clamp(1.6rem,1.2rem + 1.5vw,2.4rem);line-height:1.1}.prose .meta{color:var(--fg-dim);margin:0 0 var(--space-32);font-size:.9rem}.prose h2{margin:var(--space-32)0 var(--space-12);font-size:1.3rem}.prose h3{margin:var(--space-24)0 var(--space-8);font-size:1.1rem}.prose p{margin:0 0 var(--space-16)}.prose ul{padding-left:var(--space-24);margin:0 0 var(--space-16)}.prose ol{padding-left:var(--space-24);margin:0 0 var(--space-16)}.prose li{margin-bottom:var(--space-4)}.prose a{text-underline-offset:3px}.prose blockquote{border-left:3px solid var(--border);margin:0 0 var(--space-16);padding:var(--space-4)var(--space-16);color:var(--fg-dim)}.prose :not(pre)>code{background:var(--bg-soft);border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-size:.9em}.prose img{margin:var(--space-16)0;border-radius:8px}.prose video{margin:var(--space-16)0;border-radius:8px}.prose pre.shiki{padding:var(--space-16)var(--space-20);overflow-x:auto;margin:0 0 var(--space-16);border:1px solid var(--border);border-radius:8px;font-size:.88rem;line-height:1.55}.prose pre.shiki code{font-size:inherit;background:0 0;border:none;padding:0}.prose>.btn{margin-top:var(--space-section)}.wrap{max-width:var(--max);padding:var(--space-gutter);display:grid;grid-template-columns:1fr 4fr;gap:var(--space-16);margin-inline-start:auto;margin-inline-end:auto}@media (max-width:880px){.wrap{grid-template-columns:auto 1fr auto;grid-template-areas:"avatar nav  toggle" "page   page page";align-items: center;column-gap:var(--space-16);row-gap:var(--space-section);padding-bottom:var(--space-64)}}.content{width:100%;min-width:0;max-width:820px;margin-left:auto}@media (max-width:880px){.wrap .identity,.wrap .content,.wrap .topbar{display:contents}#page{grid-area:page}}.identity{position:sticky;top:var(--space-48);align-self: start}.identity .avatar{object-fit:cover;background:#eee;border-radius:50%;width:184px;height:184px}.identity .name{margin:var(--space-32)0 var(--space-4);letter-spacing:-.025em;font-size:clamp(1.7rem,1.4rem + 1.4vw,2.9rem);font-weight:700;line-height:1.04}.identity .title{color:var(--fg-dim);margin:0 0 var(--space-24);font-size:1rem}.identity .socials{display:flex;gap:var(--space-16)}.identity .socials a{color:var(--fg);opacity:.85;display:inline-flex}.identity .socials a:hover{opacity:1}.identity .socials svg{width:20px;height:20px}@media (max-width:880px){.identity .avatar{grid-area:avatar;width:40px;height:40px}.identity .name{display:none}.identity .title{display:none}.identity .socials{display:none}}.topbar{display:flex;justify-content:flex-end;gap:var(--space-32);margin-bottom:var(--space-section);align-items: center}.topbar nav{display:flex;gap:var(--space-32)}.topbar nav a{text-decoration:none;padding:var(--space-4)0;border-bottom:2px solid #0000;font-size:.95rem}.topbar nav a[aria-current=page]{border-bottom-color:var(--fg)}.theme-toggle{appearance:none;cursor:pointer;color:var(--fg-dim);display:inline-flex;background:0 0;border:none;border-radius:8px;justify-content:center;align-items: center;width:32px;height:32px;padding:0;transition:color .15s,background .15s}.theme-toggle:hover{color:var(--fg);background:var(--bg-soft)}.theme-toggle__icon{display:none;line-height:0}.theme-toggle__icon svg{width:18px;height:18px}.theme-toggle[data-state=light] .theme-toggle__icon--light,.theme-toggle[data-state=dark] .theme-toggle__icon--dark,.theme-toggle[data-state=system] .theme-toggle__icon--system{display:inline-flex}@media (max-width:880px){.topbar nav{grid-area:nav;gap:var(--space-16)}.theme-toggle{grid-area:toggle}}.btn{display:inline-block;background:var(--fg);color:var(--bg);padding:var(--space-12)var(--space-24);border:1px solid var(--fg);border-radius:var(--space-8);font:inherit;text-decoration:none;cursor:pointer;transition:background .15s,color .15s,opacity .15s;font-weight:500}.btn:hover{opacity:.85}.btn--outline{color:var(--fg);background:0 0}.btn--outline:hover{background:var(--fg);color:var(--bg);opacity:1}.btn--block{display:block;text-align:center;width:100%}.lazy-media{opacity:0;transition:opacity .4s}.lazy-media.loaded{opacity:1}.link-cards{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-16);margin:var(--space-24)0}@media (max-width:600px){.link-cards{grid-template-columns:1fr}}.link-card{display:block;text-decoration:none;color:inherit;transition:transform .15s,box-shadow .25s}.link-card h3{margin:0 0 var(--space-8);letter-spacing:-.01em;font-size:1rem;font-weight:600}.link-card p{color:var(--fg-dim);margin:0;font-size:.95rem;line-height:1.5}.link-card:hover{transform:translateY(-1px);box-shadow:0 6px 16px #00000014}.posts{list-style:none;margin:0;padding:0}.posts li{position:relative;display:flex;justify-content:space-between;align-items: center;gap:var(--space-16);padding:var(--space-20)0;border-bottom:1px solid var(--border)}.posts li a:after{content:"";position:absolute;inset:0}.posts a{color:var(--fg);text-decoration:none;letter-spacing:-.01em;background-image:linear-gradient(currentColor,currentColor);background-position:0 calc(100% - 2px);background-repeat:no-repeat;background-size:0% 1px;transition:background-size .2s linear;font-weight:600}.posts a:hover{background-size:100% 1px}.posts time{color:var(--fg-dim);white-space:nowrap;font-size:.88rem}.card>.posts li:first-child{padding-top:0}.card>.posts li:last-child{border-bottom:0;padding-bottom:0}.home-extra{margin:var(--space-section)0 0;max-width:none}.home-extra:empty{display:none}.home-extra img{border-radius:6px;max-width:100%}.home-extra h2{margin-top:var(--space-section)}.project-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-24);content-visibility:auto;contain-intrinsic-size:auto 600px}@media (max-width:600px){.project-grid{grid-template-columns:1fr}}.project-card{position:relative;display:block;aspect-ratio:2;overflow:hidden;border:1px solid var(--border);background:var(--bg-soft);text-decoration:none;border-radius:11px;transition:box-shadow .25s;box-shadow:0 2px 4px #0000000a}.project-card:hover{box-shadow:0 6px 16px #00000014}.project-card:hover img{transform:scale(1.04)}.project-card:hover video{transform:scale(1.04)}.project-card img{object-fit:cover;object-position:top left;display:block;width:100%;height:100%;transition:transform .35s}.project-card video{object-fit:cover;object-position:top left;display:block;width:100%;height:100%;transition:transform .35s}.project-card h3{position:absolute;bottom:var(--space-8);left:var(--space-8);max-width:calc(100% - var(--space-16));background:var(--bg);color:var(--fg);letter-spacing:-.005em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:inline-flex;border-radius:6px;align-items: center;gap:6px;margin:0;padding:5px 10px;font-size:.72rem;font-weight:500}.project-card h3 svg{color:var(--fg-dim);flex-shrink:0;width:.85em;height:.85em}.heat-graph{--hg-l0:var(--buncss-light,#ebedf0)var(--buncss-dark,#161b22);--hg-l1:var(--buncss-light,#9be9a8)var(--buncss-dark,#0e4429);--hg-l2:var(--buncss-light,#40c463)var(--buncss-dark,#006d32);--hg-l3:var(--buncss-light,#30a14e)var(--buncss-dark,#26a641);--hg-l4:var(--buncss-light,#216e39)var(--buncss-dark,#39d353);position:relative;margin:var(--space-section)0 0;padding:var(--space-16);border:1px solid var(--border);color:var(--fg-dim);background:0 0;border-radius:11px;font-size:12px;box-shadow:0 2px 4px #0000000a}h2+.heat-graph{margin-top:0}.heat-graph__caption{margin-bottom:var(--space-12);color:var(--fg-dim)}.heat-graph__caption a{color:var(--fg-dim);text-decoration:none;border-bottom:1px dotted var(--fg-dim)}.heat-graph__caption a:hover{color:var(--fg);border-bottom-color:var(--fg)}.heat-graph__total{color:var(--fg);font-weight:600}.heat-graph__scroll{overflow-x:auto;overflow-y:visible;scrollbar-width:thin;margin:0 calc(-1*var(--space-4));padding:0 var(--space-4)}.heat-graph__inner{display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto 1fr;gap:6px;min-width:660px}.heat-graph__months{grid-column:2;grid-row:1;display:grid;grid-template-columns:repeat(var(--weeks),1fr);gap:3px;font-size:11px;line-height:1}.heat-graph__month{grid-row:1;white-space:nowrap}.heat-graph__days{grid-column:1;grid-row:2;display:grid;grid-template-rows:repeat(7,1fr);padding-right:var(--space-4);gap:3px;font-size:11px}.heat-graph__days span{align-self: center;line-height:1}.heat-graph__grid{grid-column:2;grid-row:2;display:grid;grid-template-columns:repeat(var(--weeks),1fr);grid-template-rows:repeat(7,1fr);gap:3px}.heat-graph__cell{aspect-ratio:1;background:var(--hg-l0);outline:1px solid #0000;border-radius:2px;transition:outline-color .1s}.heat-graph__cell[data-level="1"]{background:var(--hg-l1)}.heat-graph__cell[data-level="2"]{background:var(--hg-l2)}.heat-graph__cell[data-level="3"]{background:var(--hg-l3)}.heat-graph__cell[data-level="4"]{background:var(--hg-l4)}.heat-graph__cell:hover{outline-color:var(--fg);outline-offset:1px}.heat-graph__cell:focus-visible{outline-color:var(--fg);outline-offset:1px}.heat-graph__legend{display:flex;align-items: center;gap:var(--space-4);margin-top:var(--space-12);justify-content:flex-end;font-size:11px}.heat-graph__legend .heat-graph__cell{aspect-ratio:auto;width:10px;height:10px}.heat-graph__legend span:first-child{margin-right:2px}.heat-graph__legend span:last-child{margin-left:2px}.heat-graph__tooltip{position:absolute;background:var(--fg);color:var(--bg);padding:var(--space-4)var(--space-8);white-space:nowrap;pointer-events:none;z-index:1;border-radius:6px;font-size:11px;line-height:1.4;box-shadow:0 2px 8px #00000026}.heat-graph__tooltip[hidden]{display:none}.cal-widget{margin-top:var(--space-section)}body.resume-page{background:var(--bg)}body.resume-page .resume-doc{padding:var(--space-64)var(--space-40)96px;max-width:880px;margin:0 auto}@media (max-width:720px){body.resume-page .resume-doc{padding:var(--space-40)var(--space-20)var(--space-64)}}body.resume-page .resume-head{display:flex;align-items: center;gap:var(--space-24);margin-bottom:var(--space-48);padding-bottom:var(--space-32);border-bottom:1px solid var(--border)}body.resume-page .resume-avatar{object-fit:cover;border-radius:50%;width:112px;height:112px}body.resume-page .resume-id h1{margin:0 0 var(--space-4);letter-spacing:-.02em;font-size:1.7rem;font-weight:700}body.resume-page .resume-id .resume-role{margin:0 0 var(--space-4);color:var(--fg)}body.resume-page .resume-id .resume-email{color:var(--fg-dim);margin:0;font-size:.95rem}body.resume-page .resume-id .resume-email a{color:inherit;text-decoration:none}body.resume-page .resume-id .resume-email a:hover{text-decoration:underline}body.resume-page .resume-section{margin-bottom:var(--space-section)}body.resume-page .resume-section h2{margin:0 0 var(--space-24);letter-spacing:-.01em;font-size:1rem;font-weight:600}body.resume-page .resume-about{max-width:680px}body.resume-page .resume-about p{margin:0 0 var(--space-16);line-height:1.6}body.resume-page .resume-about p:last-child{margin-bottom:0}body.resume-page .resume-row{display:grid;grid-template-columns:140px 1fr;gap:var(--space-32);margin-bottom:var(--space-40)}@media (max-width:720px){body.resume-page .resume-row{grid-template-columns:1fr;gap:var(--space-8)}}body.resume-page .resume-period{color:var(--fg-dim);padding-top:3px;font-size:.9rem}body.resume-page .resume-body h3{margin:0 0 2px;font-size:1rem;font-weight:600}body.resume-page .resume-body .resume-meta{margin:0 0 var(--space-12);color:var(--fg-dim);font-size:.9rem}body.resume-page .resume-body p{margin:0 0 var(--space-12);line-height:1.55}body.resume-page .resume-body ul{margin:0 0 var(--space-12);padding-left:var(--space-20)}body.resume-page .resume-body li{margin-bottom:var(--space-4)}body.resume-page .resume-body a{color:inherit;text-underline-offset:2px}.not-found{display:flex;align-items: center;gap:var(--space-32);padding-block:var(--space-section);text-align:center;flex-direction:column}.not-found__headline{margin:0;font-size:1.125rem;font-weight:700;line-height:1.4}.not-found__help{margin:0;line-height:1.6}
