@font-face{font-family:Bricolage Grotesque Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(/_astro/bricolage-grotesque-vietnamese-wght-normal.BUzh504Q.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:Bricolage Grotesque Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(/_astro/bricolage-grotesque-latin-ext-wght-normal.CcLUaPy7.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:Bricolage Grotesque Variable;font-style:normal;font-display:swap;font-weight:200 800;src:url(/_astro/bricolage-grotesque-latin-wght-normal.DLoelf7F.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}:root{color-scheme:light;--bg: #f9fafb;--text: #111827;--muted: #4b5563;--subtle: #6b7280;--border: #e5e7eb;--panel: #ffffff;--input: #ffffff;--accent: #60a5fa;--button: #374151;--button-hover: #111827}:root.dark{color-scheme:dark;--bg: #27272a;--text: #fafafa;--muted: #d4d4d8;--subtle: #a1a1aa;--border: #3f3f46;--panel: #3f3f46;--input: #3f3f46;--button: #52525b;--button-hover: #71717a}*{box-sizing:border-box}html{min-height:100%;scroll-behavior:smooth}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}body{min-height:100vh;margin:0;background:var(--bg);color:var(--text);font-family:Bricolage Grotesque Variable,sans-serif}button,input{font:inherit}.site-shell{display:flex;flex-direction:column;width:100%;max-width:42rem;min-height:100vh;margin:0 auto;padding:2rem 1.5rem 4rem}.main{flex:1}.skip-link,.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}.skip-link:focus{top:1rem;left:1rem;z-index:100;width:auto;height:auto;margin:0;padding:.5rem 1rem;overflow:visible;clip:auto;color:var(--accent);background:var(--panel);border-radius:.375rem;outline:2px solid var(--accent);outline-offset:2px}.site-header nav{display:flex;align-items:center;justify-content:space-between;padding-bottom:3rem}.brand{display:inline-flex;align-items:center;gap:.75rem;font-size:1.25rem}.brand-logo{width:2rem;height:2rem;color:var(--muted)}.nav-links{display:flex;align-items:center;gap:.75rem;margin:0;padding:0;list-style:none}.link{position:relative;color:inherit;text-decoration:none}.link:after{position:absolute;left:0;bottom:-.125rem;width:0;height:1px;content:"";background:var(--accent);transition:width .18s ease}.link:hover:after,.link:focus-visible:after{width:100%}.icon-link,.theme-toggle,.back-to-top{display:inline-flex;align-items:center;justify-content:center;color:var(--muted);background:transparent;border:0;border-radius:.375rem;cursor:pointer;transition:color .18s ease,background-color .18s ease,opacity .18s ease}.icon-link,.theme-toggle{width:2.25rem;height:2.25rem;margin:-.5rem}.icon-link:hover,.icon-link:focus-visible,.theme-toggle:hover,.theme-toggle:focus-visible{color:var(--accent)}.icon{width:1.25rem;height:1.25rem}.is-hidden{display:none!important}.intro{margin-bottom:4rem;color:var(--muted);font-size:1.125rem;line-height:1.65}.avatar{float:left;width:5rem;height:5rem;margin:0 1rem .5rem 0;border-radius:999px}.post-list{display:flex;flex-direction:column;gap:2rem}.post-card{display:flex;flex-direction:column;gap:.5rem}.post-card h2{margin:0;font-size:1.25rem;font-weight:400}.post-card time,.post-meta{color:var(--subtle);font-size:.875rem}.post-card p{margin:0;color:var(--muted);line-height:1.65}.post-header{margin-bottom:2rem}.post-header h1{margin:0;font-size:clamp(2.5rem,9vw,3rem);font-weight:400;line-height:1.05}.post-meta{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-top:1rem}.prose{color:var(--text);font-size:1.125rem;font-weight:300;line-height:1.75}.prose p{margin:0 0 1.75em}.prose p:last-child{margin-bottom:0}.prose a{color:inherit;text-decoration:none;background-image:linear-gradient(#9ca3af,#9ca3af);background-position:0 100%;background-repeat:no-repeat;background-size:100% 1px;transition:background-image .18s ease}:root.dark .prose a{background-image:linear-gradient(#71717a,#71717a)}.prose a:hover,.prose a:focus-visible{background-image:linear-gradient(var(--accent),var(--accent))}.prose a:focus-visible,.link:focus-visible,.icon-link:focus-visible,.theme-toggle:focus-visible,.back-to-top:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.newsletter{margin:2rem 0 4rem;padding-top:2rem;border-top:1px solid var(--border)}.newsletter-inner{max-width:28rem}.newsletter h2{margin:0;font-size:1.125rem;font-weight:500}.newsletter p{margin:.25rem 0 0;color:var(--subtle);font-size:.875rem}.newsletter form{display:flex;flex-direction:column;gap:.75rem;margin-top:1.5rem}.newsletter input[type=email]{width:100%;padding:.5rem .75rem;color:var(--text);background:var(--input);border:1px solid var(--border);border-radius:.375rem;outline:none}.newsletter input[type=email]:focus{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.newsletter button{align-self:stretch;padding:.625rem 1.5rem;color:#fff;background:var(--button);border:1px solid var(--button);border-radius:.375rem;cursor:pointer;transition:background-color .18s ease,border-color .18s ease,opacity .18s ease}.newsletter button:not(:disabled):hover,.newsletter button:not(:disabled):focus-visible{background:var(--button-hover);border-color:var(--button-hover)}.newsletter button:disabled{cursor:not-allowed;opacity:.55}@media(min-width:640px){.newsletter form{flex-direction:row;align-items:center}.newsletter button{align-self:auto}}.post-nav{display:flex;justify-content:space-between;gap:1.5rem;padding:2rem 0;border-top:1px solid var(--border)}.post-nav>div{flex:1}.post-nav-next{text-align:right}.post-nav-label{display:block;margin-bottom:.25rem;color:var(--subtle);font-size:.875rem}.not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center}.not-found h1{margin:0;font-size:4rem}.not-found p{color:var(--subtle);font-size:1.25rem}.back-to-top{position:fixed;right:1.5rem;bottom:1.5rem;width:3rem;height:3rem;color:var(--muted);background:var(--border);box-shadow:0 10px 25px #00000026;opacity:0;pointer-events:none}.back-to-top.is-visible{opacity:1;pointer-events:auto}
