.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}:root{color-scheme:light;--bg: #FAFAFA;--bg-subtle: #F0F0F0;--text: #111111;--text-muted: #777777;--rule: #E0E0E0;--accent: #000000;--accent-hover: #555555;--shiki-color-text: var(--text);--shiki-color-background: transparent;--shiki-token-constant: var(--text-muted);--shiki-token-string: #666666;--shiki-token-comment: #999999;--shiki-token-keyword: #111111;--shiki-token-parameter: var(--text-muted);--shiki-token-function: #333333;--shiki-token-string-expression: #666666;--shiki-token-punctuation: #888888;--shiki-token-link: var(--text);--font-body: "Inter Variable", ui-sans-serif, system-ui, -apple-system, sans-serif;--font-ui: "Inter Variable", ui-sans-serif, system-ui, -apple-system, sans-serif;--font-mono: ui-monospace, SFMono-Regular, "SF Mono", Consolas, Menlo, monospace;--measure: 42rem}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}html,body{margin:0;padding:0;background-color:var(--bg);color:var(--text);font-family:var(--font-body);font-size:18px;line-height:1.65;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"kern" 1,"liga" 1;text-rendering:optimizeLegibility}h1,h2,h3,h4,h5,h6,p,figure,pre,ul,ol{margin:0;padding:0}img{max-width:100%;height:auto;display:block}a{color:var(--text);text-decoration:none;background-image:linear-gradient(var(--rule),var(--rule));background-size:100% 1px;background-repeat:no-repeat;background-position:left 92%;transition:none}a:hover{background-size:100% 2px;background-image:linear-gradient(var(--text),var(--text));color:var(--accent)}a:active{transform:translateY(1px)}::selection{background:color-mix(in srgb,var(--accent) 30%,transparent);color:var(--text)}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}.skip-link{position:absolute;top:.5rem;left:.5rem;padding:.5rem .85rem;background:var(--text);color:var(--bg);font-family:var(--font-mono);font-size:.85rem;text-decoration:none;border-radius:3px;transform:translateY(-200%);transition:transform .16s ease;z-index:100}.skip-link:focus-visible{transform:translateY(0);outline-offset:2px}.page{display:flex;flex-direction:column;min-height:100dvh;max-width:var(--measure);margin:0 auto;padding:2.75rem 1.5rem 3rem}main{flex:1}.site-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1.25rem;border-bottom:1px solid var(--rule);margin-bottom:3.5rem;font-family:var(--font-mono);font-size:.82rem}.site-name{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--font-mono);font-size:.88rem;font-weight:500;color:var(--text);text-decoration:none;letter-spacing:-.01em}.site-name:hover{color:var(--accent)}.site-footer{margin-top:5rem;padding-top:1.25rem;border-top:1px solid var(--rule);font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted);display:flex;justify-content:space-between;gap:1.5rem;align-items:center;text-transform:lowercase;letter-spacing:.01em;font-variant-numeric:tabular-nums}.social-links{display:flex;gap:1.1rem}.social-links a{color:var(--text-muted);text-decoration:none;transition:color .18s ease}.social-links a:hover{color:var(--accent)}.sep{opacity:.5}.hero{margin-bottom:4.5rem}.hero-identity{font-family:var(--font-mono);font-size:clamp(2rem,4.5vw,2.75rem);font-weight:500;letter-spacing:-.04em;color:var(--text);margin-bottom:1.5rem;display:flex;align-items:center;gap:1rem}.hero-role{font-family:var(--font-body);font-size:1.1rem;line-height:1.55;color:var(--text);max-width:32rem;text-wrap:pretty;margin-bottom:1.5rem}.hero-role em{font-style:normal;font-family:var(--font-mono);font-size:.92em;color:var(--text);padding:.05em .25em;background:var(--bg-subtle);border-radius:2px}.writing{margin-top:2rem}.section-label{font-family:var(--font-mono);font-size:.72rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.14em;margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem}.section-label:after{content:"";flex:1;height:1px;background:var(--rule)}.year-group+.year-group{margin-top:2.5rem}.year-header{font-family:var(--font-body);font-size:1.75rem;font-weight:300;color:var(--text-muted);letter-spacing:-.02em;margin-bottom:1.25rem;font-variant-numeric:tabular-nums lining-nums;opacity:1}.post-list{list-style:none;display:flex;flex-direction:column;gap:1.5rem}.post-list-item{display:grid;grid-template-columns:4.5rem 1fr;gap:1.5rem;align-items:start}.post-list-item .post-date{padding-top:.35rem}.post-date{font-family:var(--font-mono);font-size:.78rem;color:var(--text-muted);font-variant-numeric:tabular-nums;text-transform:lowercase;letter-spacing:.01em}.post-title{font-size:1.05rem;font-weight:500;letter-spacing:-.02em;line-height:1.4;font-family:var(--font-mono)}.post-title a{color:var(--text);text-decoration:none;background-image:linear-gradient(var(--rule),var(--rule));background-size:100% 1px;background-repeat:no-repeat;background-position:left 92%;transition:none}.post-title a:hover{color:var(--text);background-image:linear-gradient(var(--text),var(--text));background-size:100% 2px}.post-description{display:block;font-size:.95rem;color:var(--text-muted);margin-top:.3rem;text-wrap:pretty;line-height:1.5}.featured{margin-bottom:4rem;padding-bottom:2rem;border-bottom:1px solid var(--rule)}.kicker{display:block;font-family:var(--font-mono);font-size:.72rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.14em;margin-bottom:.9rem}.featured-title{font-family:var(--font-mono);font-size:1.5rem;font-weight:500;line-height:1.3;letter-spacing:-.04em;text-wrap:balance;margin-bottom:.75rem}.featured-title a{color:var(--text);text-decoration:none}.featured-title a:hover{color:var(--accent)}.featured-description{font-size:1.02rem;color:var(--text-muted);text-wrap:pretty;margin-bottom:.75rem}.featured-meta{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted);font-variant-numeric:tabular-nums;text-transform:lowercase}.featured-meta .sep{margin:0 .4em;opacity:.5}.post-meta{margin-top:.4rem;font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted);letter-spacing:.01em;display:flex;align-items:center;gap:.25rem;flex-wrap:wrap}.post-meta .sep{opacity:.5}.article-header{margin-bottom:2.5rem}.article-title{font-family:var(--font-mono);font-size:clamp(1.75rem,4vw,2.5rem);font-weight:500;line-height:1.2;letter-spacing:-.05em;text-wrap:balance;margin-bottom:1rem}.article-meta{font-family:var(--font-ui);font-size:.82rem;color:var(--text-muted);font-variant-numeric:oldstyle-nums}.article-meta .sep{margin:0 .4em;opacity:.5}.prose{font-family:var(--font-body)}.prose a{background-image:linear-gradient(var(--text-muted),var(--text-muted))}.prose a:hover{color:var(--accent);background-image:linear-gradient(var(--text),var(--text))}.prose>*+*{margin-top:1.25rem}.prose h2{margin-top:2.75rem;font-size:1.35rem;font-weight:600;font-family:var(--font-mono);letter-spacing:-.03em;text-wrap:balance}.prose h3{margin-top:2rem;font-size:1.1rem;font-weight:600;font-family:var(--font-mono);letter-spacing:-.02em;text-wrap:balance}.prose p{text-wrap:pretty}.prose ul,.prose ol{padding-left:1.25rem}.prose li+li{margin-top:.35rem}.prose blockquote{margin:1.75rem 0;padding:.25rem 0 .25rem 1.25rem;border-left:2px solid var(--accent);color:var(--text-muted);font-style:italic}.prose blockquote>*+*{margin-top:.75rem}.prose hr{border:none;border-top:1px solid var(--rule);margin:2.5rem 0}.prose :not(pre)>code{font-family:var(--font-mono);font-size:.88em;background:var(--bg-subtle);padding:.1em .35em;border-radius:3px}.prose pre{position:relative;font-family:var(--font-mono);font-size:.85rem;line-height:1.6;background:var(--bg-subtle);padding:1rem 1.25rem;border:1px dashed var(--rule);border-radius:2px;overflow-x:auto;margin:1.5rem 0}.prose pre code{font-family:inherit;background:transparent;padding:0;font-size:inherit}.article-nav{margin-top:4.5rem;padding-top:1.5rem;border-top:1px solid var(--rule);display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;font-family:var(--font-ui);font-size:.9rem}.article-nav-link{color:var(--text-muted);text-decoration:none;display:flex;flex-direction:column;gap:.3rem;min-width:0;transition:color .18s ease}.article-nav-link:hover{color:var(--accent)}.article-nav-link.next{text-align:right;align-items:flex-end}.article-nav-label{font-family:var(--font-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.14em;opacity:.7;display:inline-flex;align-items:center;gap:.5ch}.article-nav-link.prev .article-nav-label:before{content:"←";display:inline-block;transition:transform .22s cubic-bezier(.16,1,.3,1)}.article-nav-link.next .article-nav-label:after{content:"→";display:inline-block;transition:transform .22s cubic-bezier(.16,1,.3,1)}.article-nav-link.prev:hover .article-nav-label:before{transform:translate(-3px)}.article-nav-link.next:hover .article-nav-label:after{transform:translate(3px)}.article-nav-title{font-family:var(--font-body);color:var(--text);font-size:1rem;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.article-nav-placeholder{display:block}.not-found-title{font-family:var(--font-body);font-size:clamp(3.5rem,9vw,5.5rem);font-weight:500;letter-spacing:-.06em;color:var(--text-muted);margin-bottom:.75rem;font-variant-numeric:lining-nums}.not-found-body{font-size:1.1rem;color:var(--text-muted);max-width:32rem;text-wrap:pretty}@media(max-width:560px){html,body{font-size:17px}.page{padding:1.75rem 1.25rem 2rem}.hero-identity{font-size:1.75rem;gap:.7rem}.hero-role{font-size:1rem}.post-list-item{grid-template-columns:1fr;gap:.25rem}.article-title{font-size:1.85rem}.year-header{font-size:1.35rem}.not-found-title{font-size:2.75rem}.not-found-body{font-size:1rem}}.code-chrome{position:absolute;top:.5rem;right:.5rem;display:flex;align-items:center;gap:.6rem;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.02em;color:var(--text-muted);pointer-events:none}.code-lang{text-transform:lowercase;opacity:.75}.code-copy{pointer-events:auto;font:inherit;color:var(--text-muted);background:var(--bg);border:1px solid var(--rule);border-radius:3px;padding:.15rem .5rem;cursor:pointer;transition:color .16s ease,border-color .16s ease,transform .12s ease}.code-copy:hover{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 40%,var(--rule))}.code-copy:active{transform:translateY(1px)}.code-copy[data-copied]{color:var(--accent);border-color:var(--accent)}.prose :where(h2,h3,h4){scroll-margin-top:2rem}.prose .heading-anchor{display:inline-block;margin-left:.4em;color:var(--text-muted);text-decoration:none;font-weight:400;opacity:0;transition:opacity .16s ease,color .16s ease,transform .16s ease;transform:translate(-2px)}.prose :where(h2,h3,h4):hover .heading-anchor,.prose .heading-anchor:focus-visible{opacity:1;transform:translate(0)}.prose .heading-anchor:hover{color:var(--accent)}.site-name,.site-name:hover,.social-links a,.social-links a:hover,.article-nav-link,.article-nav-link:hover,.featured-title a,.featured-title a:hover,.skip-link,.skip-link:hover{background-image:none}.site-name,.social-links a,.article-nav-link{transition:color .18s ease,transform .12s ease}.site-name:active,.social-links a:active,.article-nav-link:active{transform:translateY(1px)}.mark{display:inline-flex;color:var(--accent);flex-shrink:0;line-height:1}.site-name .mark{width:1rem;height:1rem;transform:translateY(-1px)}.hero-identity .mark{width:1.75rem;height:1.75rem}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/_astro/inter-cyrillic-ext-wght-normal.BOeWTOD4.woff2) format("woff2-variations");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/_astro/inter-cyrillic-wght-normal.DqGufNeO.woff2) format("woff2-variations");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/_astro/inter-greek-ext-wght-normal.DlzME5K_.woff2) format("woff2-variations");unicode-range:U+1F00-1FFF}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/_astro/inter-greek-wght-normal.CkhJZR-_.woff2) format("woff2-variations");unicode-range:U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/_astro/inter-vietnamese-wght-normal.CBcvBZtf.woff2) format("woff2-variations");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/_astro/inter-latin-ext-wght-normal.DO1Apj_S.woff2) format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/_astro/inter-latin-wght-normal.Dx4kXJAl.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}.magical-pixel-logo[data-astro-cid-hbrxync6]{display:inline-flex;align-items:center;height:1.2em}.site-name .magical-pixel-logo[data-astro-cid-hbrxync6]{height:14px;margin-top:-2px}.hero-identity .magical-pixel-logo[data-astro-cid-hbrxync6]{height:48px;margin-top:-4px}.px-svg[data-astro-cid-hbrxync6]{height:100%;width:auto;overflow:visible}.px[data-astro-cid-hbrxync6]{fill:#1a1a1a;opacity:1;transform-origin:center;transform-box:fill-box;will-change:transform,opacity,fill;transition:fill .2s ease,opacity .2s ease}.site-name:hover .px[data-astro-cid-hbrxync6],.hero-identity:hover .px[data-astro-cid-hbrxync6]{fill:var(--color);animation:glitch-anim .35s infinite alternate steps(2,jump-none);animation-delay:var(--delay)}@keyframes glitch-anim{0%{transform:translate(0);opacity:1}30%{transform:translate(calc(var(--rx) * .3px));opacity:.85}60%{transform:translate(calc(var(--rx) * -.15px));opacity:1}90%{transform:translate(calc(var(--rx) * .5px));opacity:.75}to{transform:translate(0);opacity:1}}
