: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:48rem;--page-padding-x:1.5rem;--page-padding-top:3rem}@media(min-width:640px){:root{--page-padding-x:3rem;--page-padding-top:3rem}}@media(min-width:768px){:root{--page-padding-top:6rem;--page-padding-x: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-x)4rem}.page-shell{width:100%;max-width:56rem;margin-inline:auto}.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--clickable{cursor:pointer}.highlight-card--clickable:focus-visible{outline:2px solid rgba(245,48,3,.7);outline-offset:.35rem;border-radius:.5rem}.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}.highlight-card__body{display:flex;flex-direction:column;gap:.6rem;min-width:0;padding-top:.1rem}.highlight-card__body h3{margin:0;line-height:1.4}.highlight-card__body p{margin:0;max-width:60ch;line-height:1.75}.highlight-card__tag{margin-bottom:0}.highlight-card__link{display:inline-flex;align-items:center;align-self:flex-start;margin-top:.1rem}@media(min-width:768px){.highlight-card__body{min-height:100%}.highlight-card__link{margin-top:auto}}.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 table{display:block;width:100%;max-width:100%;margin:0 0 1.5rem;overflow-x:auto;border-collapse:collapse;border:1px solid var(--border);border-radius:.5rem;background:rgba(255,255,255,2%)}.article-content table thead,.article-content table tbody,.article-content table tr{width:max-content;min-width:100%}.article-content table th,.article-content table td{padding:.6rem .75rem;border-bottom:1px solid var(--border);text-align:left;vertical-align:top;white-space:nowrap}.article-content table th{font-family:var(--font-mono);font-size:.8125rem;font-weight:500;color:var(--foreground);background:rgba(255,255,255,4%)}.article-content table td{color:var(--foreground-soft)}.article-content table tr:last-child td{border-bottom:0}.article-content table::-webkit-scrollbar{height:10px}.article-content table::-webkit-scrollbar-track{background:0 0;border-radius:999px}.article-content table::-webkit-scrollbar-thumb{background:rgba(255,255,255,.22);border-radius:999px;border:2px solid transparent;background-clip:padding-box}.article-content table::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.32)}.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{width:100%;max-width:72rem;margin-inline:auto;padding:2rem var(--page-padding-x)4rem;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;padding:.9rem 1rem;border:1px solid var(--border);background:rgba(255,255,255,3%)}.highlight .chroma code{color:var(--foreground-soft)}.highlight .chroma .k,.highlight .chroma .kd,.highlight .chroma .kn,.highlight .chroma .kr,.highlight .chroma .kt{color:#ff8f73}.highlight .chroma .nf,.highlight .chroma .fm,.highlight .chroma .nc{color:#ffb097}.highlight .chroma .nb,.highlight .chroma .bp{color:#f9d27d}.highlight .chroma .s,.highlight .chroma .sa,.highlight .chroma .sb,.highlight .chroma .sc,.highlight .chroma .s1,.highlight .chroma .s2,.highlight .chroma .sd,.highlight .chroma .se,.highlight .chroma .sh,.highlight .chroma .si,.highlight .chroma .sr,.highlight .chroma .ss,.highlight .chroma .sx,.highlight .chroma .dl{color:#9fd3b0}.highlight .chroma .mi,.highlight .chroma .mf,.highlight .chroma .mh,.highlight .chroma .il,.highlight .chroma .mo{color:#79c7ff}.highlight .chroma .c,.highlight .chroma .ch,.highlight .chroma .cm,.highlight .chroma .c1,.highlight .chroma .cs,.highlight .chroma .cp,.highlight .chroma .cpf{color:var(--foreground-muted);font-style:italic}.highlight .chroma .o,.highlight .chroma .ow{color:#ffcf8f}.highlight .chroma .p{color:rgba(250,250,250,.72)}.highlight .chroma .lnt,.highlight .chroma .ln{color:rgba(250,250,250,.35)}.highlight .chroma .hl{background:rgba(245,48,3,.14)}html{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.35)transparent}html::-webkit-scrollbar{width:10px;height:10px}html::-webkit-scrollbar-track{background:0 0}html::-webkit-scrollbar-thumb{background:rgba(255,255,255,.22);border-radius:999px;border:2px solid transparent;background-clip:padding-box}html::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.32)}