:root{color-scheme:dark;--foreground:#fafafa;--foreground-muted:rgba(250, 250, 250, 0.6);--foreground-soft:rgba(250, 250, 250, 0.8);--background:#000000;--surface:rgba(255, 255, 255, 0.06);--border:rgba(255, 255, 255, 0.1);--accent:#f53003;--font-sans:"Inter", "PingFang SC", "Noto Sans SC", "Microsoft YaHei", sans-serif;--font-mono:"Geist Mono", ui-monospace, "SF Mono", Menlo, monospace;--content-width:42rem;--page-padding:1rem;--page-padding-top:3rem;--page-padding-left:1.5rem}@media(min-width:640px){:root{--page-padding:1.5rem;--page-padding-top:3rem;--page-padding-left:3rem}}@media(min-width:768px){:root{--page-padding-top:6rem;--page-padding-left:6rem}}*,*::before,*::after{box-sizing:border-box}html{font-family:var(--font-sans);font-size:16px;line-height:1.75;color:var(--foreground);background:var(--background);-webkit-font-smoothing:antialiased}body{margin:0;min-height:100vh}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}a{color:inherit;text-decoration:none;transition:color .1s ease-out}a:hover{color:var(--accent);text-decoration:underline}img,video{max-width:100%;height:auto;display:block}.site-main{padding:var(--page-padding-top)var(--page-padding)4rem var(--page-padding-left)}.page-shell{max-width:72rem}.home-hero__title{margin:0;font-family:var(--font-mono);font-size:1rem;font-weight:500}.home-hero__role{display:block;margin-top:.25rem;font-family:var(--font-mono);font-size:1rem;font-weight:500;color:var(--foreground-muted)}.home-hero__intro{margin-top:3rem;display:flex;flex-direction:column;gap:1rem;color:var(--foreground-soft);max-width:var(--content-width)}.home-hero__intro p{margin:0 0 1rem}.home-hero__intro p:last-child{margin-bottom:0}.tech-item{font-weight:700;white-space:nowrap}.tech-item__icon{display:inline-block;width:1rem;height:1rem;margin-right:.3rem;vertical-align:-.2em}.section-label{margin:0 0 1rem;font-family:var(--font-mono);font-size:.875rem;font-weight:500;color:var(--foreground-muted)}.home-links{margin-top:4rem}.home-links__list{margin:0;padding-left:1.25rem;list-style:disc;display:flex;flex-direction:column;gap:.75rem;color:var(--foreground-soft)}.home-links__list a:hover{color:var(--foreground)}.home-highlights{margin-top:5rem}.home-highlights .section-more{margin-top:2rem}.projects-page__grid{margin-top:0}.home-highlights__grid{display:flex;flex-direction:column;gap:3rem}@media(min-width:768px){.home-highlights__grid{gap:5rem}.highlight-card{display:grid;grid-template-columns:minmax(0,24rem)minmax(0,1fr);gap:1.5rem 2rem;align-items:start}}.highlight-card+.highlight-card{margin-top:0}.highlight-card__media{position:relative;aspect-ratio:16/9;width:100%;max-width:24rem;overflow:hidden;border-radius:.5rem;border:1px solid var(--border);background:var(--surface)}.highlight-card__media img,.highlight-card__media video{width:100%;height:100%;object-fit:cover}.highlight-card__poster{position:relative;z-index:1}.highlight-card__placeholder{width:100%;height:100%;background:linear-gradient(135deg,rgba(255,255,255,4%),rgba(245,48,3,.12))}.highlight-card__play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;border:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);cursor:pointer;padding:0}.highlight-card__play-icon{width:0;height:0;margin-left:.25rem;border-top:8px solid transparent;border-bottom:8px solid transparent;border-left:12px solid var(--foreground)}.highlight-card__body h3{margin:0 0 .75rem;font-size:1.125rem;font-weight:600}.highlight-card__body p{margin:0 0 .75rem;color:var(--foreground-soft)}.highlight-card__tag{display:inline-block;margin-bottom:.5rem;font-family:var(--font-mono);font-size:.75rem;color:var(--foreground-muted)}.highlight-card__link{font-size:.9375rem}.home-posts{margin-top:5rem}.post-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.5rem}.post-list__item{display:flex;flex-wrap:wrap;align-items:baseline;gap:.75rem 1rem;font-size:.9375rem}.post-list__date{flex-shrink:0;font-family:var(--font-mono);font-size:.8125rem;color:var(--foreground-muted)}.post-list__title{color:var(--foreground-soft)}.post-list__item a:hover .post-list__title{color:var(--foreground)}.section-more{margin-top:1rem;font-size:.875rem}.back-home{margin-bottom:2rem;font-family:var(--font-mono);font-size:.875rem;font-weight:500}.back-home a{color:var(--foreground-muted);text-decoration:none}.back-home a:hover{color:var(--accent);text-decoration:none}.page-header{margin-bottom:2rem}.page-header h1{margin:0 0 .5rem;font-size:1.5rem;font-weight:600}.page-header__subtitle{margin:0;color:var(--foreground-muted);font-family:var(--font-mono);font-size:.875rem}.archive-year{margin:2.5rem 0 1rem;font-family:var(--font-mono);font-size:.875rem;font-weight:500;color:var(--foreground-muted)}.archive-year:first-child{margin-top:0}.article-header{max-width:var(--content-width);margin-bottom:2rem}.article-header h1{margin:0 0 1rem;font-size:1.75rem;font-weight:600;line-height:1.3}.article-meta{display:flex;flex-wrap:wrap;gap:.5rem 1rem;font-family:var(--font-mono);font-size:.8125rem;color:var(--foreground-muted)}.article-tags{display:flex;flex-wrap:wrap;gap:.5rem}.article-tags a{color:var(--foreground-muted)}.article-tags a:hover{color:var(--accent)}.article-content{max-width:var(--content-width);color:var(--foreground-soft)}.article-content h2,.article-content h3,.article-content h4{color:var(--foreground);margin-top:2rem;margin-bottom:.75rem}.article-content p,.article-content ul,.article-content ol{margin:0 0 1rem}.article-content pre{overflow-x:auto;border-radius:.5rem;margin:0 0 1.5rem}.article-content :not(pre)>code{font-family:var(--font-mono);font-size:.875em;padding:.15em .35em;border-radius:.25rem;background:var(--surface);color:var(--foreground)}.article-content pre code{font-family:var(--font-mono);font-size:.875rem}.article-nav{display:grid;gap:1rem;margin-top:3rem;max-width:var(--content-width);font-size:.9375rem}@media(min-width:640px){.article-nav{grid-template-columns:1fr 1fr}}.article-nav a{display:block;padding:1rem;border:1px solid var(--border);border-radius:.5rem;color:var(--foreground-soft)}.article-nav a:hover{border-color:rgba(245,48,3,.3);color:var(--foreground);text-decoration:none}.article-nav__label{display:block;margin-bottom:.25rem;font-family:var(--font-mono);font-size:.75rem;color:var(--foreground-muted)}.terms-grid{display:flex;flex-wrap:wrap;gap:.75rem}.terms-grid a{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .65rem;border:1px solid var(--border);border-radius:999px;font-family:var(--font-mono);font-size:.8125rem;color:var(--foreground-soft)}.terms-grid a:hover{border-color:rgba(245,48,3,.3);color:var(--foreground);text-decoration:none}.terms-grid__count{color:var(--foreground-muted)}.pagination{display:flex;justify-content:space-between;gap:1rem;margin-top:2rem;font-family:var(--font-mono);font-size:.875rem}.site-footer{padding:2rem var(--page-padding)4rem var(--page-padding-left);font-family:var(--font-mono);font-size:.75rem;color:var(--foreground-muted)}.error-page h1{font-family:var(--font-mono);font-size:1rem;font-weight:500}#back-top{position:fixed;right:1.5rem;bottom:1.5rem;width:2.5rem;height:2.5rem;display:none;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:50%;background:var(--background);color:var(--foreground-muted);cursor:pointer;z-index:10}#back-top:hover{color:var(--accent);border-color:rgba(245,48,3,.3)}#back-top.is-visible{display:flex}@keyframes blur-in{from{opacity:0;filter:blur(8px);transform:translateY(4px)}to{opacity:1;filter:blur(0);transform:translateY(0)}}.animate-blur-in{animation:blur-in .6s ease-out both}.animate-blur-in-char{animation:blur-in .5s ease-out both}@media(prefers-reduced-motion:reduce){.animate-blur-in,.animate-blur-in-char{animation:none;opacity:1;filter:none;transform:none}}.highlight>.chroma{margin:0 0 1.5rem;border-radius:.5rem;overflow-x:auto;background:#282c34}.highlight .chroma code{color:#abb2bf}