:root{--bg: #0d0f12;--bg-soft: #14171c;--line: #20242b;--fg: #d7dce3;--muted: #7d8794;--accent: #4ade80;--accent-dim: #2a6f44;--link: #d7dce3;--serif: "Source Serif 4", Charter, "Bitstream Charter", Georgia, Cambria, "Times New Roman", serif;--sans: "Source Sans 3", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--mono: "JetBrains Mono", "SF Mono", "Fira Code", ui-monospace, "Cascadia Code", Menlo, Consolas, monospace}[data-theme=light]{--bg: #f4f4f3;--bg-soft: #ffffff;--line: #e0e0dd;--fg: #111316;--muted: #6a7078;--accent: #15803d;--accent-dim: #86c7a0;--link: #111316}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--fg);font-family:var(--sans);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;transition:background .25s ease,color .25s ease}.wrap{max-width:760px;margin:0 auto;padding:0 24px}header{position:sticky;top:0;z-index:10;background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}nav{display:flex;align-items:center;justify-content:space-between;height:87px}.brand{font-family:var(--mono);font-weight:600;font-size:19px;letter-spacing:-.3px;color:var(--fg);text-decoration:none;display:inline-flex;align-items:center;gap:9px}.brand-icon{width:1.9em;height:1.9em;color:var(--fg);transform-origin:50% 85%}.brand-icon.play{animation:pinch .85s ease}.brand:hover .brand-icon{animation:pinch .85s ease infinite}@keyframes pinch{0%{transform:rotate(0)}18%{transform:rotate(-12deg)}40%{transform:rotate(9deg)}62%{transform:rotate(-6deg)}82%{transform:rotate(3deg)}to{transform:rotate(0)}}@media(prefers-reduced-motion:reduce){.brand-icon.play,.brand:hover .brand-icon{animation:none}}.nav-right{display:flex;align-items:center;gap:20px}.nav-right a{color:var(--muted);text-decoration:none;font-size:14px}.nav-right a:hover,.nav-right a.active{color:var(--fg)}.toggle{background:none;border:1px solid var(--line);color:var(--muted);font-family:var(--mono);font-size:12px;cursor:pointer;padding:4px 10px;border-radius:6px;transition:.2s}.toggle:hover{color:var(--fg);border-color:var(--muted)}.hero{padding:90px 0 70px}.hero--blog{padding:90px 0 50px}.hero .line{font-family:var(--mono);color:var(--muted);font-size:13px;margin-bottom:18px}.hero .line .accent{color:var(--accent)}h1{font-family:var(--serif);font-size:clamp(40px,9vw,72px);font-weight:700;letter-spacing:-1px;line-height:1.02;margin-bottom:22px}.cursor{display:inline-block;width:.5ch;height:.92em;background:var(--accent);margin-left:5px;transform:translateY(.12em);animation:blink 1.1s steps(1) infinite}@keyframes blink{50%{opacity:0}}.hero p.tagline{font-family:var(--serif);color:var(--muted);max-width:56ch;font-size:18px;line-height:1.6}.hero p.tagline a{color:var(--fg);text-decoration:none;border-bottom:1px solid var(--accent-dim)}.section{padding:28px 0 60px}.section--blog{padding:8px 0 60px}.section-head{display:flex;align-items:baseline;gap:12px;color:var(--muted);font-size:13px;margin-bottom:8px}.section-head .hash{color:var(--accent)}.section-sub{color:var(--muted);font-size:13px;margin-bottom:32px}.project{display:block;text-decoration:none;color:inherit;border-top:1px solid var(--line);padding:26px 0;position:relative;transition:padding-left .2s ease}.project:last-child{border-bottom:1px solid var(--line)}.project:hover{padding-left:14px}.project:before{content:"›";position:absolute;left:-2px;top:26px;color:var(--accent);opacity:0;transition:opacity .2s ease,left .2s ease}.project:hover:before{opacity:1;left:2px}.project-top{display:flex;align-items:baseline;justify-content:space-between;gap:16px}.project h3{font-family:var(--serif);font-size:23px;font-weight:700;letter-spacing:-.4px}.project .open{color:var(--muted);font-size:12px;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}.project:hover .open{color:var(--accent)}.project .open .arrow{transition:transform .2s ease}.project:hover .open .arrow{transform:translate(2px,-2px)}.project p{font-family:var(--serif);color:var(--muted);font-size:16px;margin-top:8px;max-width:62ch}.project .host{color:var(--accent-dim);font-size:12px;margin-top:10px}.project-row{position:relative}.project-row:last-child .project{border-bottom:1px solid var(--line)}.project-info{position:absolute;right:0;bottom:24px;z-index:2;display:inline-flex;align-items:center;gap:5px;font-family:var(--mono);font-size:12px;color:var(--muted);text-decoration:none;padding:5px 12px;border:1px solid var(--line);border-radius:999px;background:var(--bg);transition:color .2s ease,border-color .2s ease}.project-info:hover{color:var(--accent);border-color:var(--accent)}.project-info span{transition:transform .2s ease}.project-info:hover span{transform:translate(2px)}.project-row .project{transition:padding-left .45s cubic-bezier(.16,1,.3,1)}.project-row .project:before{content:none}.project-row:hover .project{padding-left:210px}.project-preview{position:absolute;left:12px;top:50%;width:180px;height:auto;border-radius:8px;border:1px solid var(--line);box-shadow:0 14px 34px #00000038;opacity:0;transform:translateY(-50%) rotate(0) scale(.9);transform-origin:50% 50%;transition:opacity .35s ease,transform .45s cubic-bezier(.16,1,.3,1);pointer-events:none;z-index:3}.project-row:hover .project-preview{opacity:1;transform:translateY(-50%) rotate(-6deg) scale(1)}@media(prefers-reduced-motion:reduce){.project-preview{transition:opacity .2s ease}.project-row:hover .project-preview{transform:translateY(-50%) rotate(-6deg)}}.project-head{display:flex;align-items:center;gap:16px}.project-icon{width:60px;height:60px;flex:0 0 auto;border-radius:14px;border:1px solid var(--line);object-fit:cover;background:var(--bg-soft)}.project-links{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.project-links a{color:var(--muted);text-decoration:none;display:inline-flex;align-items:center;gap:5px}.project-links a:hover{color:var(--accent)}.project-links a .arrow{transition:transform .2s ease}.project-links a:hover .arrow{transform:translate(2px,-2px)}.project-links .host-inline{color:var(--accent-dim);font-size:12px;margin-left:auto;font-family:var(--mono)}.tech-list{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin:16px 0 0;padding:0}.tech-chip{font-family:var(--mono);font-size:12px;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:4px 11px}.filters{display:flex;gap:8px;margin:14px 0 8px}.fbtn{background:none;border:1px solid var(--line);color:var(--muted);font-family:var(--mono);font-size:12px;cursor:pointer;padding:4px 12px;border-radius:6px;transition:.2s}.fbtn:hover{color:var(--fg);border-color:var(--muted)}.fbtn.active{color:var(--bg);background:var(--accent);border-color:var(--accent)}.entry{display:block;text-decoration:none;color:inherit;border-top:1px solid var(--line);padding:22px 0;position:relative}.entry:last-child{border-bottom:1px solid var(--line)}.entry.hidden{display:none!important}.entry .kicker{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:9px}.entry .kleft{display:flex;align-items:baseline;gap:9px}.entry .kind{font-size:11px;letter-spacing:.5px;text-transform:uppercase}.entry .kp{color:var(--accent)}.entry .kn{color:var(--accent-dim)}.entry .date{color:var(--muted);font-size:12px;white-space:nowrap}.entry .lang{font-size:12px;color:var(--muted);white-space:nowrap}.entry .lang .lc{color:var(--muted)}.entry .lang .lc.on{color:var(--accent)}.entry .lang .lsep{color:var(--muted)}.entry.post{transition:padding-left .2s ease}.entry.post:before{content:"›";position:absolute;left:-2px;top:22px;color:var(--accent);opacity:0;transition:opacity .2s ease,left .2s ease}.entry.post:hover{padding-left:13px}.entry.post:hover:before{opacity:1;left:2px}.entry.post h3{font-family:var(--serif);font-size:23px;font-weight:700;letter-spacing:-.4px}.entry.post .summary{font-family:var(--serif);color:var(--muted);font-size:16px;margin-top:8px;max-width:62ch}.entry.post .meta{display:flex;flex-wrap:wrap;align-items:center;gap:0 8px;margin-top:14px;font-size:12px;color:var(--muted)}.entry.post .meta .dot{opacity:.45}.entry.post .xp{display:inline-flex;align-items:center;gap:9px}.entry.post .xp-icon{width:15px;height:15px;color:var(--muted);transition:color .2s ease}.entry.post:hover .xp-icon{color:var(--fg)}.entry.post .xp-text{color:var(--accent-dim)}.entry.post.has-thumb{display:grid;grid-template-columns:54px minmax(0,1fr);grid-template-areas:"thumb title" "thumb summary" "thumb meta";column-gap:16px;align-items:start;transition:grid-template-columns .55s cubic-bezier(.16,1,.3,1)}.entry.post.has-thumb:before{content:none}.entry.post.has-thumb:hover{padding-left:0;grid-template-columns:200px minmax(0,1fr)}.entry.post.has-thumb>h3{grid-area:title}.entry.post.has-thumb>.summary{grid-area:summary}.entry.post.has-thumb>.meta{grid-area:meta}.card-thumb{grid-area:thumb;align-self:start;position:relative;height:120px;overflow:hidden;border:1px solid var(--line);border-radius:6px}.card-thumb img{display:block;position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:left center;filter:grayscale(1) contrast(.95);transition:filter .55s ease}.entry.post.has-thumb:hover .card-thumb img{filter:grayscale(0) contrast(1)}@media(hover:none),(max-width:640px){.entry.post.has-thumb{display:flow-root}.card-thumb{float:left;width:30%;max-width:240px;height:auto;max-height:none;aspect-ratio:16 / 9;margin:2px 18px 12px 0;shape-outside:margin-box}.card-thumb img{width:100%;height:100%;object-fit:cover;filter:none}}.entry.note{display:flex;gap:12px;align-items:flex-start}.note-avatar{width:42px;height:42px;flex:0 0 auto;border-radius:50%;object-fit:cover;border:1px solid var(--line);margin-top:2px}.note-main{flex:1 1 auto;min-width:0}.note-bubble{position:relative;background:var(--bg-soft);border:1px solid var(--line);border-radius:4px 14px 14px;padding:12px 16px}.note-bubble:before{content:"";position:absolute;left:-8px;top:12px;width:0;height:0;border-top:8px solid transparent;border-bottom:8px solid transparent;border-right:8px solid var(--line)}.note-bubble:after{content:"";position:absolute;left:-7px;top:13px;width:0;height:0;border-top:7px solid transparent;border-bottom:7px solid transparent;border-right:7px solid var(--bg-soft)}.note-body>*+*{margin-top:8px}.note-bubble p{font-family:var(--serif);font-size:16px;color:var(--fg);max-width:60ch}.note-bubble a{color:var(--fg);border-bottom:1px solid var(--accent-dim);text-decoration:none}.note-bubble a:hover{border-bottom-color:var(--accent)}.note-bubble code{font-family:var(--mono);font-size:13px;background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent);padding:1px 5px;border-radius:4px}.note-bubble ul,.note-bubble ol{padding-left:20px}.note-meta{margin-top:7px;font-size:12px;color:var(--muted)}.note-meta .lc{color:var(--muted)}.note-meta .lc.on{color:var(--accent)}.note-meta .lsep{color:var(--muted)}.note-bubble.has-images{display:flex;flex-wrap:wrap;gap:14px;align-items:flex-start}.note-body{flex:1 1 58%;min-width:0}.note-gallery{flex:0 0 auto;position:relative;width:160px}.gallery-preview{display:block;width:100%;aspect-ratio:4 / 3;padding:0;background:none;border:1px solid var(--line);border-radius:10px;overflow:hidden;cursor:pointer;transition:border-color .2s ease}.gallery-preview img{display:block;width:100%;height:100%;object-fit:cover;filter:grayscale(1);transition:filter .3s ease}.gallery-preview:hover{border-color:var(--muted)}.entry.note:hover .gallery-preview img,.entry.note:hover .chip img{filter:grayscale(0)}.gallery-chips{position:absolute;left:8px;bottom:8px;display:flex;gap:5px}.chip{width:34px;height:34px;padding:0;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.65);border-radius:6px;overflow:hidden;background:#0006;cursor:pointer}.chip img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(1);transition:filter .3s ease}.chip:hover{border-color:#fff}.chip-more{background:#000000b8;color:#fff;font-family:var(--mono);font-size:12px;font-weight:700}.empty{font-family:var(--mono);border:1px dashed var(--line);border-radius:8px;padding:40px 28px;text-align:left;color:var(--muted)}.empty .prompt{color:var(--accent)}.empty .blink{display:inline-block;width:.55ch;height:1em;background:var(--muted);margin-left:2px;transform:translateY(.12em);animation:blink 1.1s steps(1) infinite}.empty p{font-size:14px;margin-top:10px;max-width:56ch}footer{border-top:1px solid var(--line);padding:34px 0 60px;color:var(--muted);font-size:13px;display:flex;flex-wrap:wrap;gap:8px 20px;justify-content:space-between}footer a{color:var(--muted);text-decoration:none}footer a:hover{color:var(--fg)}::selection{background:var(--accent);color:var(--bg)}.entry-page{padding-top:40px}.entry-back{display:inline-block;color:var(--muted);text-decoration:none;font-size:13px;margin-bottom:22px}.entry-back:hover{color:var(--fg)}.byline{color:var(--muted);font-size:13px;margin-bottom:26px}.entry-lang{font-size:13px}.entry-lang .lc{color:var(--muted);text-decoration:none}.entry-lang .lc:hover{color:var(--fg)}.entry-lang .lc.on{color:var(--accent)}.entry-lang .lsep{color:var(--muted);margin:0 2px}.cover-wrap{container-type:inline-size;margin:6px 0 28px}.cover{position:relative;display:block;overflow:hidden;border:1px solid var(--line);border-radius:8px;height:calc(100cqw * var(--cover-ratio, .5625) * .2);transition:height .55s cubic-bezier(.16,1,.3,1)}.cover:hover{height:calc(100cqw * var(--cover-ratio, .5625))}.cover-img{display:block;width:100%;height:auto}.cover-hint{position:absolute;right:10px;bottom:9px;font-family:var(--mono);font-size:11px;color:var(--muted);background:color-mix(in srgb,var(--bg) 72%,transparent);border:1px solid var(--line);border-radius:5px;padding:2px 8px;pointer-events:none;transition:opacity .3s ease}.cover:hover .cover-hint{opacity:0}@media(hover:none){.cover{height:calc(100cqw * var(--cover-ratio, .5625))}.cover-hint{display:none}}.entry-title{font-family:var(--serif);font-size:clamp(30px,6vw,44px);font-weight:700;letter-spacing:-.5px;line-height:1.1;margin-bottom:14px}.entry-summary{font-family:var(--serif);color:var(--muted);font-size:19px;line-height:1.5;max-width:62ch;margin-bottom:16px}.entry-tags{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:30px}.entry-tags .tag{color:var(--muted);font-size:12px}.entry-tags .tag .hash{color:var(--accent)}.prose{font-family:var(--serif);color:var(--fg);font-size:19px;line-height:1.6;border-top:1px solid var(--line);padding-top:30px}.prose>*+*{margin-top:22px}.prose h2{font-family:var(--sans);font-size:27px;font-weight:700;letter-spacing:-.3px;margin-top:44px}.prose h3{font-family:var(--sans);font-size:21px;font-weight:700;margin-top:32px}.prose p{color:var(--fg);max-width:68ch}.prose a{color:var(--fg);border-bottom:1px solid var(--accent-dim);text-decoration:none}.prose a:hover{border-bottom-color:var(--accent)}.prose ul,.prose ol{padding-left:24px;max-width:68ch}.prose li{margin-top:6px}.prose li::marker{color:var(--accent-dim)}.prose strong{font-weight:700}.prose em{font-style:italic}.prose code{font-family:var(--mono);font-size:15px;background:var(--bg-soft);border:1px solid var(--line);border-radius:4px;padding:1px 5px;color:var(--accent)}.prose pre{font-family:var(--mono);background:var(--bg-soft);border:1px solid var(--line);border-radius:8px;padding:16px 18px;overflow-x:auto;font-size:14px}.prose pre code{background:none;border:none;padding:0;font-size:inherit;color:var(--fg)}.astro-code,.astro-code span{font-family:var(--mono);color:var(--shiki-dark)}[data-theme=light] .astro-code,[data-theme=light] .astro-code span{color:var(--shiki-light)}.prose blockquote{font-style:italic;border-left:2px solid var(--accent-dim);padding-left:18px;color:var(--muted);max-width:68ch}.prose p:has(>img){max-width:none;text-align:center}.prose img{display:block;margin:12px auto;max-width:100%;height:auto;border-radius:8px;border:1px solid var(--line)}.zoomable{cursor:zoom-in}.prose hr{border:none;border-top:1px solid var(--line)}.refs-block{margin-top:44px;border-top:1px solid var(--line);padding-top:24px}.refs-head{color:var(--muted);font-size:13px;margin-bottom:6px}.refs-head .hash{color:var(--accent)}.refs-note{color:var(--muted);font-size:14px;margin-bottom:14px;max-width:60ch}.refs-list{list-style:none;display:flex;flex-direction:column}.refs-list a{display:flex;align-items:baseline;gap:12px;text-decoration:none;color:var(--muted);padding:10px 0;border-bottom:1px solid var(--line);transition:padding-left .2s ease,color .2s ease}.refs-list li:last-child a{border-bottom:none}.refs-list a:hover{color:var(--fg);padding-left:6px}.refs-platform{color:var(--accent-dim);font-size:12px;text-transform:uppercase;letter-spacing:.5px;min-width:64px}.refs-list a:hover .refs-platform{color:var(--accent)}.refs-icon{width:18px;height:18px;flex:0 0 auto;align-self:center;color:var(--muted);transition:color .2s ease}.refs-list a:hover .refs-icon{color:var(--accent)}.refs-label{font-size:15px;flex:1}.refs-host{color:var(--accent-dim);font-size:12px;white-space:nowrap}.refs-list a:hover .refs-host{color:var(--accent)}.refs-arrow{color:var(--muted);font-size:12px}.lightbox{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;background:#000000e6}.lightbox[hidden]{display:none}.lb-img{max-width:92vw;max-height:88vh;border-radius:8px;object-fit:contain}.lb-btn{position:absolute;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#ffffff1f;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:8px;font-size:22px;line-height:1;cursor:pointer}.lb-btn:hover{background:#ffffff38}.lb-close{top:18px;right:18px}.lb-prev{left:18px;top:50%;transform:translateY(-50%)}.lb-next{right:18px;top:50%;transform:translateY(-50%)}.lb-count{position:absolute;bottom:20px;left:0;right:0;text-align:center;color:#fffc;font-family:var(--mono);font-size:13px}
