:root{--bg:#0a0a0a;--surface:#141414;--surface-hover:#1a1a1a;--border:#232323;--border-hover:#2a2a2a;--badge:#1a1a1a;--text-primary:#ffffff;--text-secondary:#a3a3a3;--text-muted:#737373;--text-faint:#525252;--scrollbar:#333333;--btn-bg:rgba(255, 255, 255, 0.1);--btn-bg-hover:rgba(255, 255, 255, 0.2)}html[data-theme=light]{--bg:#ffffff;--surface:#f5f5f5;--surface-hover:#ebebeb;--border:#e5e5e5;--border-hover:#d4d4d4;--badge:#e5e5e5;--text-primary:#0a0a0a;--text-secondary:#525252;--text-muted:#737373;--text-faint:#a3a3a3;--scrollbar:#cccccc;--btn-bg:rgba(0, 0, 0, 0.08);--btn-bg-hover:rgba(0, 0, 0, 0.15)}*,*::before,*::after{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;background:var(--bg);color:var(--text-primary);font-family:outfit,system-ui,sans-serif;font-weight:400;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;transition:background-color .2s ease,color .2s ease}a{color:inherit}::selection{background:var(--btn-bg-hover);color:var(--text-primary)}.container{width:100%;max-width:720px;margin:0 auto;padding:0 1rem}.site-main{padding:2rem 0 4rem}.site-header{position:sticky;top:0;z-index:10;background:color-mix(in srgb,var(--bg) 85%,transparent);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}.site-header .container{display:flex;align-items:center;justify-content:space-between;height:56px}.back-link{display:inline-flex;align-items:center;gap:.4rem;font-size:.875rem;color:var(--text-secondary);text-decoration:none;transition:color .2s ease}.back-link:hover{color:var(--text-primary)}.header-actions{display:flex;align-items:center;gap:.5rem}.icon-btn{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:34px;padding:0 .5rem;border:1px solid var(--border);border-radius:.625rem;background:var(--btn-bg);color:var(--text-secondary);font-size:.75rem;font-weight:600;cursor:pointer;text-decoration:none;transition:background-color .2s ease,color .2s ease,border-color .2s ease}.icon-btn:hover{background:var(--btn-bg-hover);color:var(--text-primary);border-color:var(--border-hover)}.icon-btn svg{width:16px;height:16px}.card{display:block;background:var(--surface);border:1px solid var(--border);border-radius:1rem;padding:1rem;text-decoration:none;color:inherit;transition:background-color .2s ease,border-color .2s ease}.card:hover{background:var(--surface-hover);border-color:var(--border-hover)}@media(min-width:640px){.card{padding:1.5rem}}.post-list{display:grid;gap:1rem;list-style:none;padding:0;margin:0}.tag-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.tag{border:1px solid var(--border-hover);border-radius:9999px;padding:.1rem .55rem;font-size:.72rem;color:var(--text-muted)}.post-card-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0 0 .25rem}.post-card-date{font-size:.75rem;color:var(--text-faint);margin:0 0 .5rem}.post-card-desc{font-size:.9rem;color:var(--text-muted);margin:0}.page-intro{margin-bottom:2rem}.page-intro h1{font-size:1.875rem;font-weight:700;margin:0 0 .5rem}.page-intro p{color:var(--text-muted);margin:0}.post-header{margin-bottom:1.5rem}.post-title{font-size:2rem;font-weight:700;line-height:1.2;margin:.5rem 0 .4rem}.post-meta{font-size:.8rem;color:var(--text-faint)}.prose{color:var(--text-secondary);font-size:1rem;line-height:1.75}.prose>*+*{margin-top:1.15em}.prose h2,.prose h3,.prose h4{color:var(--text-primary);font-weight:600;line-height:1.3;margin-top:2em;margin-bottom:.6em}.prose h2{font-size:1.5rem}.prose h3{font-size:1.2rem}.prose h4{font-size:1.05rem}.prose strong{color:var(--text-primary);font-weight:600}.prose em{font-style:italic}.prose a{color:var(--text-primary);text-decoration:underline;text-decoration-color:var(--border-hover);text-underline-offset:2px;transition:text-decoration-color .2s ease}.prose a:hover{text-decoration-color:var(--text-secondary)}.prose ul,.prose ol{padding-left:1.4em}.prose li{margin-top:.4em}.prose li::marker{color:var(--text-faint)}.prose blockquote{border-left:3px solid var(--border-hover);padding-left:1em;color:var(--text-muted);font-style:italic}.prose hr{border:0;border-top:1px solid var(--border);margin:2.5em 0}.prose code{background:var(--surface);border:1px solid var(--border);border-radius:.375rem;padding:.1em .35em;font-size:.875em;font-family:ui-monospace,sf mono,Menlo,Consolas,monospace;color:var(--text-primary)}.prose pre{background:var(--surface);border:1px solid var(--border);border-radius:.75rem;padding:1rem 1.1rem;overflow-x:auto;font-size:.85rem;line-height:1.6}.prose pre code{background:0 0;border:0;padding:0;font-size:inherit;color:var(--text-secondary)}.highlight{margin:1.15em 0}.prose table{width:100%;border-collapse:collapse;font-size:.9rem}.prose th,.prose td{border:1px solid var(--border);padding:.5rem .75rem;text-align:left}.prose th{color:var(--text-primary);font-weight:600;background:var(--surface)}.prose img{max-width:100%;height:auto;border-radius:.75rem}.site-footer{border-top:1px solid var(--border);padding:2rem 0;font-size:.8rem;color:var(--text-faint)}.site-footer .container{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:space-between;align-items:center}.site-footer a{color:var(--text-muted);text-decoration:none}.site-footer a:hover{color:var(--text-primary)}*{scrollbar-width:thin;scrollbar-color:var(--scrollbar)transparent}*::-webkit-scrollbar{height:8px;width:8px}*::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:9999px}.bg{background-color:initial}.chroma{background-color:initial;-webkit-text-size-adjust:none}.chroma .lnlinks{outline:none;text-decoration:none;color:inherit}.chroma .lntd{vertical-align:top;padding:0;margin:0;border:0}.chroma .lntable{border-spacing:0;padding:0;margin:0;border:0}.chroma .hl{background-color:#e5e5e5}.chroma .lnt{white-space:pre;-webkit-user-select:none;user-select:none;margin-right:.4em;padding:0 .4em;color:#7f7f7f}.chroma .ln{white-space:pre;-webkit-user-select:none;user-select:none;margin-right:.4em;padding:0 .4em;color:#7f7f7f}.chroma .line{display:flex}.chroma .k{font-weight:700}.chroma .kc{font-weight:700}.chroma .kd{font-weight:700}.chroma .kn{font-weight:700}.chroma .kr{font-weight:700}.chroma .nc{font-weight:700}.chroma .ni{font-weight:700}.chroma .ne{font-weight:700}.chroma .nn{font-weight:700}.chroma .nt{font-weight:700}.chroma .s{font-style:italic}.chroma .sa{font-style:italic}.chroma .sb{font-style:italic}.chroma .sc{font-style:italic}.chroma .dl{font-style:italic}.chroma .sd{font-style:italic}.chroma .s2{font-style:italic}.chroma .se{font-weight:700;font-style:italic}.chroma .sh{font-style:italic}.chroma .si{font-weight:700;font-style:italic}.chroma .sx{font-style:italic}.chroma .sr{font-style:italic}.chroma .s1{font-style:italic}.chroma .ss{font-style:italic}.chroma .ow{font-weight:700}.chroma .c{font-style:italic}.chroma .ch{font-style:italic}.chroma .cm{font-style:italic}.chroma .c1{font-style:italic}.chroma .cs{font-style:italic}.chroma .ge{font-style:italic}.chroma .gh{font-weight:700}.chroma .gp{font-weight:700}.chroma .gs{font-weight:700}.chroma .gu{font-weight:700}