: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}.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:34px 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:stretch;overflow:hidden;border:1px solid var(--line);border-radius:6px}.card-thumb img{display:block;width:200px;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;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-bubble>*+*{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)}.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)}.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}
