@view-transition{navigation: auto;
}::view-transition{background-color:#111827}:root{color-scheme:dark;--color-text:#f3f4f6;--color-text-secondary:#9ca3af;--color-bg:#111827;--color-bg-secondary:#1f2937;--color-border:#374151;--color-accent:#22d3ee;--color-link-visited:#a78bfa;--color-code-bg:#1e293b;--color-bg-sidebar:#1e293b;--color-card-bg:#1e293b;--color-card-border:#374151;--color-icon-projects:#f59e0b;--color-icon-support:#fb7185;--color-icon-feeds:#a78bfa}*,*::before,*::after{box-sizing:border-box}html{font-family:-apple-system,BlinkMacSystemFont,segoe ui,Roboto,Oxygen,Ubuntu,Cantarell,fira sans,droid sans,helvetica neue,sans-serif;font-size:18px;line-height:1.6;color:var(--color-text);background-color:var(--color-bg)}body{margin:0;padding:0}a{color:var(--color-accent);text-decoration-thickness:1px;text-underline-offset:2px;text-decoration-skip-ink:none}a:visited{color:var(--color-link-visited)}a:hover{text-decoration-thickness:2px}a:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:2px}a.icon-link{text-decoration:none;white-space:nowrap}a.icon-link span{text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px;text-decoration-skip-ink:none}a.icon-link:hover span{text-decoration-thickness:2px}.skip-link{position:absolute;top:-100%;left:1rem;padding:.5rem 1rem;background:var(--color-accent);color:#fff;text-decoration:none;border-radius:0 0 4px 4px;z-index:1000;font-weight:600}.skip-link:visited{color:#fff}.skip-link:focus{top:0;outline:2px solid var(--color-accent);outline-offset:2px}.like-honeypot{position:absolute;left:-9999px;opacity:0;height:0;width:0;overflow:hidden}.like-form--nav{display:contents}button.sidebar__link{background:0 0;border:none;cursor:pointer;font-family:inherit}label.sidebar__link{cursor:pointer}.modal-toggle{position:fixed;opacity:0;pointer-events:none;width:1px;height:1px}.modal-backdrop{position:fixed;inset:0;z-index:1001;display:none;background-color:rgba(0,0,0,.5)}.modal-toggle:checked~.modal-backdrop{display:block}.modal-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1002;display:none;background:var(--color-card-bg);border:1px solid var(--color-card-border);border-radius:6px;box-shadow:0 4px 12px rgba(0,0,0,.3)}.modal-toggle:checked~.modal-popup,.modal-toggle:checked~form .modal-popup{display:block}.modal-close-x{position:absolute;top:.75rem;right:.75rem;cursor:pointer;color:var(--color-text-secondary);font-size:1.25rem;line-height:1;padding:.25rem;border-radius:50%;background-color:inherit}.modal-close-x:hover{color:var(--color-text)}.modal-close{display:block;text-align:center;margin-top:1rem;color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:4px;padding:.5rem 1rem;cursor:pointer}.modal-close:hover{background:var(--color-bg-secondary);color:var(--color-text)}.modal-popup h2{font-size:1.1rem}.modal-popup h2:first-of-type{margin-top:0}.like-popup{padding:1rem;min-width:min(24rem,calc(100vw - 2rem));font-size:1rem}.like-popup textarea{width:100%;background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border);border-radius:4px;padding:.5rem;font-family:inherit;font-size:.95rem;min-height:5rem;resize:vertical}.like-popup textarea:focus{outline:2px solid var(--color-accent);outline-offset:-1px}.like-popup .like-popup__note{margin:0 0 .5rem;font-size:.8rem;color:var(--color-text-secondary);display:flex;align-items:start;gap:.35rem}.like-popup.like-popup .like-popup__note svg{color:var(--color-text-secondary);margin-top:.15rem;flex-shrink:0}.like-popup__actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:.75rem}.like-popup__send{background:var(--color-accent);color:var(--color-bg);border:none;border-radius:4px;padding:.5rem 1rem;font-family:inherit;font-size:.9rem;font-weight:600;cursor:pointer;transition:filter .15s}.like-popup__send:hover{filter:brightness(1.15)}.like-popup__cancel{background:0 0;color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:4px;padding:.5rem 1rem;font-size:.9rem;cursor:pointer;transition:background-color .15s,color .15s}.like-popup__cancel:hover{background:var(--color-bg-secondary);color:var(--color-text)}.like-trigger{flex:1}.like-form{display:inline-block}.like-trigger-label{cursor:pointer;font-size:inherit;color:var(--color-accent)}.like-trigger-label span{text-decoration-line:underline;text-decoration-thickness:1px;text-underline-offset:2px;text-decoration-skip-ink:none}.like-trigger-label:hover span{text-decoration-thickness:2px}.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}.site-layout{display:grid;grid-template-columns:15.625rem 1fr;min-height:100vh}.content-area{display:flex;flex-direction:column;min-height:100vh;min-width:0}.content-area>main{flex:1;padding:2rem}.sidebar{position:sticky;top:0;z-index:1001;height:100vh;overflow-y:auto;background:var(--color-bg-sidebar);border-right:1px solid var(--color-border);padding:1.5rem 0;display:flex;flex-direction:column}.sidebar__brand{display:flex;align-items:center;gap:.15em;padding:0 1.25rem 1.25rem;font-size:1.25rem;font-weight:700;color:var(--color-text);text-decoration:none;border-bottom:1px solid var(--color-border);margin-bottom:1rem}.sidebar__brand svg{color:var(--color-accent);flex-shrink:0;width:1.2em;height:1.2em}.sidebar__brand:visited{color:var(--color-text)}.sidebar__nav{padding:0 .75rem;margin-bottom:1.25rem}.sidebar__nav+.sidebar__nav{padding-top:.75rem;border-top:1px solid var(--color-border)}.sidebar__nav-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);padding:.25rem .5rem;margin-bottom:.25rem}.sidebar__link{display:flex;align-items:center;gap:.75rem;flex:1;white-space:nowrap;padding:.5rem;color:var(--color-text);text-decoration:none;border-radius:6px;font-size:.9rem;transition:background-color .15s}.sidebar__link:visited{color:var(--color-text)}.sidebar__link:hover{background:#2d3a50;text-decoration:none}.sidebar__link:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.sidebar__link svg{width:20px;height:20px;flex-shrink:0}.sidebar__nav--writing .sidebar__link svg{color:var(--color-accent)}.sidebar__nav--projects .sidebar__link svg{color:var(--color-icon-projects)}.sidebar__nav--support .sidebar__link svg{color:var(--color-icon-support)}.sidebar__nav--feeds .sidebar__link svg{color:var(--color-icon-feeds)}.sidebar__link-pair{display:flex}@media(min-width:769px){.sidebar__link-pair>*{max-width:50%;min-width:50%}}.sidebar__spacer{flex:1}.sidebar__toggle-input{position:fixed;opacity:0;pointer-events:none;width:1px;height:1px}.sidebar__toggle-label{display:none}.sidebar__nav-container{display:flex;flex-direction:column;flex:1}.content--article{max-width:70ch;margin:0 auto;width:100%}.content--wide{max-width:56.25rem;margin:0 auto;width:100%}.date-detail{white-space:nowrap;color:var(--color-text-secondary)}.date-detail::before{content:"·";margin:0 .4em}h1,h2,h3,h4,h5,h6{line-height:1.3;margin-top:1.5em;margin-bottom:.5em;text-wrap:balance}h1{font-size:1.75rem}h2{font-size:1.5rem}h3{font-size:1.25rem}code{font-family:sf mono,fira code,fira mono,roboto mono,Menlo,Monaco,Consolas,liberation mono,courier new,monospace;font-size:.875em;background:var(--color-code-bg);padding:.15em .3em;border-radius:3px}code.inline{padding:0}pre{background:var(--color-code-bg);padding:1rem;border-radius:4px;overflow-x:auto;-webkit-text-size-adjust:100%;text-size-adjust:100%}pre code{background:0 0;padding:0}img,video{max-width:100%;height:auto}blockquote{border-left:3px solid var(--color-accent);margin-left:0;padding-left:1rem;color:var(--color-text-secondary)}table{border-collapse:collapse;width:100%;margin:1rem 0}th,td{padding:.5rem .75rem;border:1px solid var(--color-border);text-align:left}th{background:var(--color-bg-secondary);font-weight:600}.human-notice{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--color-text-secondary);margin:.75rem 0 1.25rem;border-left:2px solid var(--color-border);padding:.5rem .75rem}.human-notice svg{color:var(--color-text-secondary);flex-shrink:0}@media(max-width:1024px){.site-layout{grid-template-columns:11.25rem 1fr}.sidebar{padding:1rem 0}.sidebar__brand{padding:0 .75rem 1rem;font-size:1.1rem}.sidebar__nav{padding:0 .5rem}.sidebar__nav-label{display:none}.sidebar__link{font-size:.8rem;padding:.4rem .5rem;gap:.5rem}.sidebar__link svg{width:16px;height:16px}.content-area>main{padding:1.5rem}}@media(max-width:768px){.site-layout{grid-template-columns:1fr;grid-template-rows:auto 1fr}.sidebar{position:sticky;top:calc(-1 * (1rem + 1.2rem + 1px) - 3px);z-index:1000;height:auto;flex-direction:column;border-right:none;border-bottom:1px solid var(--color-border);padding:0;background:var(--color-bg);overflow:visible}.sidebar__brand{padding:.6rem .75rem;font-size:1rem;border-bottom:1px solid var(--color-border);margin-bottom:0;line-height:1}.sidebar__toggle-label{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;cursor:pointer;color:var(--color-text);font-size:.9rem;user-select:none;line-height:1}.sidebar__toggle-label svg{width:1em;height:1em}.sidebar__toggle-label:hover{background:var(--color-bg-secondary)}.sidebar__toggle-label::after{content:'▶';margin-left:auto;font-size:.75rem;opacity:.6}.sidebar__toggle-input:checked~.sidebar__toggle-label::after{content:'▼'}.sidebar__nav-container{display:none;flex:unset}.sidebar__toggle-input:checked~.sidebar__nav-container{display:block;position:absolute;top:100%;left:0;right:0;background:var(--color-bg);border-bottom:1px solid var(--color-border);z-index:999}.sidebar__nav-container .sidebar__nav{display:flex;flex-wrap:wrap;padding:.25rem .5rem;margin-bottom:0;gap:.125rem;border-top:1px solid var(--color-border)}.sidebar__nav-container .sidebar__nav-label{display:none}.sidebar__nav-container .sidebar__link{font-size:.8rem;padding:.3rem .4rem;gap:.3rem;flex:0}.sidebar__nav-container .sidebar__link svg{width:16px;height:16px}.sidebar__spacer{display:none}.content-area{min-height:auto}.content-area>main{padding:1.5rem 1rem}.content--article>h1:first-child,.content--article>:first-child>h1:first-child,.content--article>:first-child>:first-child>h1:first-child,.content--wide>:first-child>h1:first-child,.content--wide>:first-child>:first-child>h1:first-child{margin-top:0}html{scroll-padding-top:3rem}}.post-title{display:flex;align-items:baseline;gap:.5em}.post-title a{flex:auto;min-width:0}.post-categories{flex:none;display:inline-flex;gap:.25em;white-space:nowrap}.cat-icon{color:inherit;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;padding:4px;border-radius:50%}.cat-icon:visited{color:inherit}.cat-icon:hover{box-shadow:0 0 0 2px #f59e0b}.cat-icon--match{box-shadow:0 0 0 2px #f59e0b}.cat-icon--match:hover{background-color:rgba(245,158,11,.2)}.latest-post__title{display:inline-flex;align-items:baseline;gap:.5em;min-width:0}mark{background-color:rgba(253,224,71,.3);color:inherit;border-radius:2px;padding:.05em 0}.chroma{color:#f8f8f2;background-color:var(--color-code-bg)}.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:#3c3d38}.chroma .lnt,.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,.chroma .kc,.chroma .kd,.chroma .kp,.chroma .kr,.chroma .kt,.chroma .no{color:#66d9ef}.chroma .err,.chroma .kn,.chroma .nt,.chroma .o,.chroma .ow,.chroma .gd{color:#f59}.chroma .na,.chroma .nc,.chroma .nd,.chroma .ne,.chroma .nx,.chroma .nf,.chroma .fm,.chroma .gi{color:#a6e22e}.chroma .ld,.chroma .s,.chroma .sa,.chroma .sb,.chroma .sc,.chroma .dl,.chroma .sd,.chroma .s2,.chroma .sh,.chroma .si,.chroma .sx,.chroma .sr,.chroma .s1,.chroma .ss{color:#e6db74}.chroma .l,.chroma .se,.chroma .m,.chroma .mb,.chroma .mf,.chroma .mh,.chroma .mi,.chroma .il,.chroma .mo{color:#ae81ff}.chroma .c,.chroma .ch,.chroma .cm,.chroma .c1,.chroma .cs,.chroma .cp,.chroma .cpf,.chroma .gu{color:#9e9a8b}.chroma .ge{font-style:italic}.chroma .gs{font-weight:700}.blog-search{display:flex;gap:.5rem;margin-bottom:1.5rem}.blog-search__input-wrap{position:relative;flex:1}.blog-search__input-wrap>svg{position:absolute;left:.6rem;top:50%;transform:translateY(-50%);color:var(--color-text-secondary);pointer-events:none}.blog-search__icon-submit{position:absolute;left:0;top:0;bottom:0;width:2.2rem;background:0 0;border:none;padding:0;margin:0;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);z-index:1}.blog-search__icon-submit svg{width:18px;height:18px}.blog-search__icon-submit:hover{color:var(--color-accent)}.blog-search input[type=search]{width:100%;padding:.5rem 2.2rem;border:1px solid var(--color-border);border-radius:4px;background:var(--color-bg);color:var(--color-text);font-size:.9rem;font-family:inherit}.blog-search input[type=search]::placeholder{color:var(--color-text-secondary)}.blog-search>button{padding:.5rem 1rem;border:1px solid var(--color-border);border-radius:4px;background:var(--color-bg);color:var(--color-text);cursor:pointer;font-size:.9rem;font-family:inherit}.blog-search>button:hover{border-color:var(--color-accent)}.search-privacy-note{font-size:.8rem;color:var(--color-text-secondary);margin-top:-1rem;margin-bottom:1.5rem}.search-privacy-note svg{vertical-align:-.15em}.search-privacy-more{color:var(--color-accent);cursor:pointer;text-decoration:underline}.search-privacy-more:hover{filter:brightness(1.15)}.blog-search__clear{position:absolute;right:.6rem;top:50%;transform:translateY(-50%);color:var(--color-text-secondary);text-decoration:none;font-size:1rem;line-height:1;display:flex;align-items:center}.blog-search__clear:hover{color:var(--color-accent)}.search-help-popup,.kbd-shortcuts-popup{padding:1.5rem;width:calc(100vw - 2rem)}.search-help-popup{max-width:45rem;max-height:calc(100vh - 4rem);overflow-y:auto}.search-help-popup h2{margin-top:1rem;margin-bottom:.25rem}.search-help-popup ul,.search-help-inline ul{margin-top:.25rem;padding-left:1.5rem}.search-help-popup li,.search-help-inline li{margin-bottom:.25rem}.search-help-popup code,.search-help-inline code{padding-right:0}.kbd-hint{display:flex;align-items:center;align-self:flex-start;gap:.3rem;cursor:pointer;font-size:.75rem;color:var(--color-text-secondary);white-space:nowrap;padding:.2rem .55rem .2rem .3rem;border:1px solid var(--color-border);border-radius:4px;background:var(--color-bg-secondary);transition:color .15s,border-color .15s}.kbd-hint:hover{color:var(--color-text);border-color:var(--color-text-secondary)}.kbd-hint kbd{display:inline-block;background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:3px;padding:.05rem .35rem;font-family:inherit;font-size:.8rem;line-height:1.3;min-width:1.3rem;text-align:center;box-shadow:0 1px 0 var(--color-border)}.page-header{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:.5rem}.page-header+h2{margin-top:.5em}.page-header .kbd-hint{margin-top:calc(1.75rem * 1.5)}@media(max-width:768px){.page-header .kbd-hint{display:none}}.kbd-shortcuts-nojs{display:none}html.no-js .kbd-shortcuts-nojs{display:block;margin:0 0 1rem;padding:.6rem .75rem;background:color-mix(in srgb,#ef4444 15%,var(--color-card-bg));border-radius:4px;color:#fca5a5;font-size:.85rem}.kbd-shortcuts-popup{max-width:30rem}.kbd-shortcuts-popup h2{margin:1rem 0 .5rem}.kbd-shortcuts-list{margin:0}.kbd-shortcuts-item{display:flex;align-items:center;gap:1rem;padding:.4rem 0}.kbd-shortcuts-item dt{min-width:6rem;text-align:right;white-space:nowrap}.kbd-shortcuts-item dd{margin:0;color:var(--color-text-secondary)}.kbd-shortcuts-popup kbd{display:inline-block;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:3px;padding:.1rem .45rem;font-family:inherit;font-size:.85rem;line-height:1.4;min-width:1.5rem;text-align:center}@media(max-width:768px){.search-help-popup,.kbd-shortcuts-popup{padding:1rem}}.search-help-inline{margin-top:1.5rem;color:var(--color-text-secondary);font-size:.9rem}.search-help-inline h2{color:var(--color-text);margin-top:1rem;margin-bottom:.25rem;font-size:1.1rem}.search-help-inline h2:first-child{margin-top:0}.search-results-info{font-size:.9rem;color:var(--color-text-secondary);margin-bottom:1rem}.search-error{font-size:.9rem;color:#fca5a5;margin-bottom:1rem}@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}