:root{--bg:#F0EEE9;--ink:#1A1A1A;--mut:#6B6863;--soft:#E7E3DB;--line:#DFDAD0;--card:#FFFFFF;--reading:#26241F;--acc:#005240;--acc-soft:#DCE8E3;--read-font:"Lora", Georgia, serif;--c-violet:#5F4B8B;--c-teal:#005240;--c-aqua:#307BA6;--c-wine:#A10015;--c-coral:#CF5C78;--c-indigo:#37515F;--sans:"Manrope", system-ui, -apple-system, sans-serif;--mono:"JetBrains Mono", ui-monospace, SFMono-Regular, monospace;--read:var(--read-font);--code-bg:#15181C;--code-kw:#C792EA;--code-txt:#C9CDD6;--code-cmt:#6E7681;--code-str:#7EE0A6}*{box-sizing:border-box}html,body{margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;min-height:100vh;display:flex;flex-direction:column}::selection{background:var(--acc-soft)}a{color:inherit;text-decoration:none}button{font-family:inherit}img{max-width:100%}.site-main{flex:1}.fade-region{opacity:1;transition:opacity .22s ease}.wrap{max-width:1180px;margin:0 auto;padding:0 40px}.two-col{display:grid;grid-template-columns:1fr 320px;gap:56px}.nav{position:sticky;top:0;z-index:40;background:rgba(240,238,233,.85);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}.nav__inner{max-width:1180px;margin:0 auto;padding:0 24px;height:64px;display:flex;align-items:center;justify-content:space-between;gap:16px}.nav__brand{display:flex;align-items:baseline;gap:12px;cursor:pointer;flex-shrink:0}.nav__wordmark{font:800 19px/1 var(--sans);letter-spacing:-.5px}.nav__tagline{font:500 12px/1.2 var(--mono);color:var(--mut)}.nav__links{display:flex;gap:26px;font:700 14px var(--sans)}.nav__link{cursor:pointer;color:var(--ink);padding-bottom:2px;border-bottom:2px solid transparent;transition:color .15s}.nav__link.is-active{color:var(--acc);border-bottom-color:var(--acc)}.nav__link:hover{color:var(--acc)}.nav__right{display:flex;align-items:center;gap:10px}.nav__search{display:flex;align-items:center;gap:7px;font:500 12px var(--mono);color:var(--mut);background:var(--card);border:1px solid var(--line);border-radius:8px;padding:7px 11px;cursor:pointer;transition:border-color .15s}.nav__search:hover{border-color:var(--acc);color:var(--acc)}.nav__menu-btn{display:none;flex-direction:column;gap:4px;background:0 0;border:none;cursor:pointer;padding:6px}.nav__menu-btn span{width:20px;height:2px;background:var(--ink);border-radius:2px}.nav__mobile{display:none;border-top:1px solid var(--line);padding:8px 24px 14px;flex-direction:column;gap:2px}.nav__mobile.is-open{display:flex}.nav__mobile a{font:700 15px var(--sans);padding:10px 0;color:var(--ink)}.nav__mobile a.is-active{color:var(--acc)}.hero{padding:56px 40px 40px;border-bottom:1px solid var(--line)}.hero__inner{max-width:1180px;margin:0 auto}.hero__title{font:800 44px/1.12 var(--sans);letter-spacing:-1.4px;max-width:780px;margin:0 0 16px}.hero__sub{font:18px/1.55 var(--sans);color:var(--mut);max-width:560px;margin:0}.tabs{display:flex;gap:24px;border-bottom:2px solid var(--ink);margin-bottom:4px}.tabs__tab{font:700 14px var(--sans);color:var(--mut);background:0 0;border:none;cursor:pointer;padding:0 0 14px;border-bottom:2px solid transparent;margin-bottom:-2px}.tabs__tab.is-active{font-weight:800;color:var(--ink);border-bottom-color:var(--acc)}.row{display:flex;gap:22px;padding:26px 0;border-bottom:1px solid var(--line);cursor:pointer}.row__body{flex:1;min-width:0}.row__meta-top{display:flex;align-items:center;gap:10px;margin-bottom:8px;flex-wrap:wrap}.row__title{font:800 22px/1.26 var(--sans);letter-spacing:-.4px;color:var(--ink);margin:0 0 8px;text-decoration:none;text-underline-offset:4px;text-decoration-color:var(--acc);text-decoration-thickness:2px}.row:hover .row__title{text-decoration:underline}.row__deck{font:14.5px/1.55 var(--sans);color:var(--mut);margin:0 0 12px;max-width:620px}.row__meta{display:flex;align-items:center;gap:11px;flex-wrap:wrap}.row__date{font:500 12px var(--mono);color:var(--mut);white-space:nowrap}.row__dot{width:3px;height:3px;border-radius:50%;background:var(--line)}.row__tags{display:flex;gap:6px;flex-wrap:wrap}.thumb{position:relative;overflow:hidden;flex-shrink:0;border:1px solid rgba(26,26,26,6%);background:var(--thumb-img,none),linear-gradient(135deg,var(--thumb-a,#CDE3D6),var(--thumb-b,#E7F1EB));background-size:cover;background-position:50%}.thumb__sheen{position:absolute;inset:0;background:linear-gradient(160deg,rgba(255,255,255,.35),transparent 55%)}.thumb--cover .thumb__sheen{display:none}.thumb__ring{position:absolute;right:-16%;bottom:-28%;width:80%;aspect-ratio:1;border-radius:50%;border:2px solid rgba(255,255,255,.4)}.thumb--cover .thumb__ring{display:none}.thumb__label{position:absolute;left:9px;bottom:7px;font:700 9px var(--mono);letter-spacing:.4px;text-transform:uppercase;color:rgba(26,26,26,.42)}.thumb--cover .thumb__label{color:#fff;left:0;right:0;bottom:0;padding:14px 9px 6px;background:linear-gradient(transparent,rgba(0,0,0,.45))}.row__thumb{width:132px;height:95px;border-radius:10px;margin-top:3px}.cat{font:700 11px var(--sans);color:var(--acc);background:var(--acc-soft);padding:3px 9px;border-radius:5px;letter-spacing:.2px}.series-link{font:600 11px var(--sans);white-space:nowrap}.tag{font:600 12px var(--mono);color:var(--ink);background:var(--card);border:1px solid var(--line);padding:4px 10px;border-radius:100px;cursor:pointer;transition:all .14s;display:inline-block}.tag:hover{border-color:var(--tag-c,var(--acc));color:var(--tag-c,var(--acc))}.tag.is-active{color:#fff;background:var(--acc);border-color:transparent}.card{display:block;background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;cursor:pointer;transition:border-color .15s,transform .15s}.card:hover{border-color:var(--acc);transform:translateY(-2px)}.card__thumb{width:100%;height:132px}.card__body{padding:16px 20px 20px}.card__meta{display:flex;align-items:center;gap:8px;margin-bottom:11px}.card__min{font:500 11px var(--mono);color:var(--mut)}.card__title{font:800 17px/1.28 var(--sans);letter-spacing:-.3px;margin:0 0 10px}.card__deck{font:13.5px/1.55 var(--sans);color:var(--mut);margin:0}.sidebar{display:flex;flex-direction:column;gap:30px}.about-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:24px 22px}.about-card__name{font:800 17px var(--sans);margin:14px 0 6px}.about-card__bio{font:14px/1.55 var(--sans);color:var(--mut);margin:0 0 16px}.about-card__links{display:flex;gap:8px;flex-wrap:wrap}.btn-acc{font:700 12px var(--sans);color:#fff;background:var(--acc);border:none;padding:7px 13px;border-radius:7px;cursor:pointer;display:inline-block}.chip-acc{font:700 12px var(--sans);color:var(--acc);background:var(--acc-soft);padding:7px 11px;border-radius:7px;display:inline-block}.side-block__title{font:800 14px var(--sans);margin:0 0 14px}.tag-cloud{display:flex;flex-wrap:wrap;gap:8px}.series-list{display:flex;flex-direction:column;gap:12px}.series-item{display:flex;gap:12px;align-items:center;cursor:pointer;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:12px 14px}.series-item__badge{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;font:800 13px var(--mono);flex-shrink:0}.series-item__text{display:flex;flex-direction:column;gap:3px;min-width:0}.series-item__title{font:700 13px/1.3 var(--sans)}.series-item__count{font:500 11px var(--mono);color:var(--mut)}.avatar{border-radius:50%;background:#dce7f0;color:var(--c-aqua);border:2px solid #fff;display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-weight:700;flex-shrink:0}.footer{background:var(--ink);color:#fff;margin-top:20px}.footer__inner{max-width:1180px;margin:0 auto;padding:40px}.footer__top{padding-bottom:26px;border-bottom:1px solid rgba(255,255,255,.14)}.footer__wordmark{font:800 22px var(--sans);letter-spacing:-.5px;margin-bottom:8px}.footer__blurb{font:13px var(--sans);opacity:.6;max-width:260px}.footer__copy{font:500 12px var(--mono);opacity:.5;margin-top:18px}.list-head{padding-top:44px}.list-head__title{font:800 38px var(--sans);letter-spacing:-1.2px;margin:0 0 10px}.list-head__sub{font:17px var(--sans);color:var(--mut);margin:0 0 26px}.filter-bar{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--line);padding-bottom:16px;flex-wrap:wrap;gap:12px}.filter-bar__chips{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.filter-chip{font:600 13px var(--mono);color:var(--ink);background:var(--card);border:1px solid var(--line);padding:7px 13px;border-radius:100px;cursor:pointer;transition:all .14s}.filter-chip[data-tag=__all]{font-family:var(--sans);font-weight:700;padding:7px 14px}.filter-chip:hover{border-color:var(--acc);color:var(--acc)}.filter-chip.is-active{color:#fff;background:var(--acc);border-color:transparent}.filter-bar__sort{font:600 13px var(--mono);color:var(--mut);background:0 0;border:none;cursor:pointer}.list-empty{padding:50px 0;font:500 15px var(--sans);color:var(--mut)}.progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:60;background:0 0}.progress__bar{height:100%;width:0;background:var(--acc);transition:width .08s linear}.article__grid{max-width:1e3px;margin:0 auto;padding:0 40px;display:grid;grid-template-columns:190px 1fr;gap:44px}.toc__sticky{position:sticky;top:96px;padding-top:48px}.toc__back{font:600 12.5px var(--sans);color:var(--mut);background:0 0;border:none;cursor:pointer;padding:0;margin-bottom:24px;display:inline-flex;align-items:center;gap:6px}.toc__back:hover{color:var(--acc)}.toc__label{font:700 11px var(--mono);color:var(--mut);margin-bottom:12px;letter-spacing:.5px}.toc__item{font:500 13px/1.4 var(--sans);color:var(--mut);padding:7px 0 7px 14px;border-left:2px solid var(--line);cursor:pointer;transition:color .15s;display:block}.toc__item.is-active{font-weight:700;color:var(--acc);border-left-color:var(--acc)}.toc__item--l3{padding-left:26px;font-size:12.5px}.article__main{max-width:680px;padding-top:48px;min-width:0}.article__cat-row{display:flex;align-items:center;gap:8px;margin-bottom:18px}.article__title{font:800 40px/1.16 var(--sans);letter-spacing:-1.2px;margin:0 0 18px}.article__deck{font:20px/1.5 var(--read);color:var(--mut);margin:0 0 28px;font-style:italic}.article__byline{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:26px;margin-bottom:34px;border-bottom:1px solid var(--line)}.article__meta{font:500 13px var(--mono);color:var(--mut);display:flex;align-items:center;gap:10px}.article__meta span.dot{width:3px;height:3px;border-radius:50%;background:var(--line)}.article__actions{display:flex;gap:8px}.article__actions button{border:1px solid var(--line);border-radius:8px;padding:8px 14px;font:600 12px var(--sans);color:var(--mut);background:var(--card);cursor:pointer}.article__actions button:hover{border-color:var(--acc);color:var(--acc)}.series-widget{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px 18px;display:flex;align-items:center;gap:14px;margin-bottom:30px}.series-widget__badge{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font:800 12px var(--mono);flex-shrink:0}.series-widget__body{flex:1;min-width:0}.series-widget__label{font:700 13px var(--sans);margin-bottom:7px}.series-widget__track{height:5px;border-radius:3px;background:var(--line);overflow:hidden}.series-widget__fill{height:100%}.post-body{font:18px/1.78 var(--read);color:var(--reading)}.post-body>*{margin:0 0 22px}.post-body>*:last-child{margin-bottom:0}.post-body h2{font:800 26px var(--sans);letter-spacing:-.5px;color:var(--ink);margin:38px 0 14px;scroll-margin-top:90px}.post-body h3{font:800 19px var(--sans);letter-spacing:-.3px;color:var(--ink);margin:30px 0 10px;scroll-margin-top:90px}.post-body h4{font:800 16px var(--sans);color:var(--ink);margin:24px 0 8px}.post-body p{margin:0 0 22px}.post-body a{color:var(--acc);text-decoration:underline;text-underline-offset:2px}.post-body strong{font-weight:700;color:var(--ink)}.post-body em{font-style:italic}.post-body ul,.post-body ol{padding-left:24px}.post-body li{margin-bottom:10px}.post-body li::marker{color:var(--acc)}.post-body blockquote{border-left:3px solid var(--acc);padding:4px 0 4px 22px;font:500 23px/1.45 var(--read);font-style:italic;color:var(--ink);margin:8px 0 22px}.post-body blockquote p{margin:0}.post-body :not(pre)>code{font:500 .85em var(--mono);background:var(--soft);color:var(--ink);padding:2px 6px;border-radius:5px}.post-body img{border-radius:12px;border:1px solid var(--line);display:block}.post-body figure{margin:0 0 22px}.post-body figure img{margin:0 auto}.post-body figure figcaption{font:500 12px var(--mono);color:var(--mut);text-align:center;margin-top:10px}.post-body hr{border:none;border-top:1px solid var(--line);margin:32px 0}.post-body table{border-collapse:collapse;font:14px var(--sans);width:100%}.post-body th,.post-body td{border:1px solid var(--line);padding:8px 12px;text-align:left}.post-body th{background:var(--soft)}.code-block{background:var(--code-bg);border-radius:12px;overflow:hidden;margin:6px 0 22px}.code-head{display:flex;align-items:center;gap:7px;padding:11px 16px;border-bottom:1px solid rgba(255,255,255,7%)}.code-head .dot{width:10px;height:10px;border-radius:50%}.code-head .dot-r{background:#ff5f57}.code-head .dot-y{background:#febc2e}.code-head .dot-g{background:#28c840}.code-lang{font:500 11px var(--mono);color:rgba(255,255,255,.4);margin-left:8px}.code-block .highlight{margin:0}.code-block pre{margin:0;padding:16px 18px;overflow-x:auto;background:0 0!important}.code-block pre code{font:13px/1.7 var(--mono);color:var(--code-txt)}.code-block .chroma{background:0 0;color:var(--code-txt);font:13px/1.7 var(--mono)}.code-block .chroma .lntable{border-spacing:0;width:100%}.code-block .chroma .lntable td{padding:0;vertical-align:top}.code-block .chroma .lntd:first-child{width:1%;white-space:nowrap}.code-block .chroma .lnt,.code-block .chroma .ln{color:rgba(255,255,255,.22);user-select:none;padding-right:14px}.code-block .chroma .k,.code-block .chroma .kc,.code-block .chroma .kd,.code-block .chroma .kn,.code-block .chroma .kp,.code-block .chroma .kr,.code-block .chroma .kt{color:var(--code-kw)}.code-block .chroma .c,.code-block .chroma .ch,.code-block .chroma .cm,.code-block .chroma .c1,.code-block .chroma .cs,.code-block .chroma .cp,.code-block .chroma .cpf{color:var(--code-cmt);font-style:italic}.code-block .chroma .s,.code-block .chroma .sa,.code-block .chroma .sb,.code-block .chroma .sc,.code-block .chroma .dl,.code-block .chroma .sd,.code-block .chroma .s2,.code-block .chroma .se,.code-block .chroma .sh,.code-block .chroma .si,.code-block .chroma .sx,.code-block .chroma .sr,.code-block .chroma .s1,.code-block .chroma .ss{color:var(--code-str)}.code-block .chroma .m,.code-block .chroma .mb,.code-block .chroma .mf,.code-block .chroma .mh,.code-block .chroma .mi,.code-block .chroma .il,.code-block .chroma .mo{color:var(--code-str)}.code-block .chroma .nb,.code-block .chroma .bp{color:var(--code-kw)}.code-block .chroma .nf,.code-block .chroma .fm{color:var(--code-txt)}.code-block .chroma .o,.code-block .chroma .ow,.code-block .chroma .p{color:var(--code-txt)}.code-block .chroma .nt{color:var(--code-kw)}.code-block .chroma .na{color:var(--code-str)}.article__tags{display:flex;gap:8px;flex-wrap:wrap;margin:32px 0 0}.prevnext{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:34px 0 0}.prevnext__card{border:1px solid var(--line);border-radius:12px;padding:18px 20px;background:var(--card);cursor:pointer;transition:border-color .15s,transform .15s}.prevnext__card:hover{border-color:var(--acc);transform:translateY(-2px)}.prevnext__card--next{text-align:right}.prevnext__label{font:600 12px var(--mono);color:var(--mut);margin-bottom:8px}.prevnext__title{font:700 15px/1.3 var(--sans)}.related{max-width:1180px;margin:56px auto 0;padding:40px 40px 8px;border-top:1px solid var(--line)}.related__title{font:800 22px var(--sans);letter-spacing:-.5px;margin:0 0 22px}.related__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.to-top{position:fixed;bottom:28px;right:28px;z-index:50;width:44px;height:44px;border-radius:22px;background:var(--ink);color:#fff;border:none;cursor:pointer;box-shadow:0 6px 20px rgba(0,0,0,.2);opacity:0;pointer-events:none;transition:opacity .2s;display:flex;align-items:center;justify-content:center}.to-top.is-visible{opacity:1;pointer-events:auto}.about{max-width:760px;margin:0 auto;padding:56px 40px 0}.about__name{font:800 40px var(--sans);letter-spacing:-1.2px;margin:20px 0 8px}.about__role{font:500 16px var(--mono);color:var(--acc);margin:0 0 24px}.about__blurb{font:20px/1.7 var(--read);color:var(--reading);margin:0 0 40px}.about__cols{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-bottom:40px}.about__col-title{font:800 14px var(--sans);margin:0 0 14px}.about__now{display:flex;flex-direction:column;gap:12px}.about__now-item{display:flex;gap:10px;font:14px/1.5 var(--sans);color:var(--mut)}.about__now-item span{color:var(--acc)}.about__stack{display:flex;flex-wrap:wrap;gap:8px}.stack-chip{font:600 13px var(--mono);color:var(--ink);border:1px solid var(--line);background:var(--card);padding:6px 12px;border-radius:100px}.hire{background:var(--acc-soft);border-radius:16px;padding:28px 30px;display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;margin-bottom:24px}.hire__title{font:800 20px var(--sans);letter-spacing:-.4px;margin:0 0 6px}.hire__sub{font:14px var(--sans);color:var(--mut);margin:0}.hire__actions{display:flex;gap:10px}.hire__actions a{font:700 13px var(--sans);padding:12px 20px;border-radius:9px;cursor:pointer}.hire__actions .is-fill{color:#fff;background:var(--acc);border:none}.hire__actions .is-outline{color:var(--ink);background:var(--card);border:1px solid var(--line)}.hire__actions .is-brand{display:inline-flex;align-items:center;gap:8px;color:#fff;border:none}.hire__actions .brand-ico{flex:none}.hire__actions .is-github{background:#24292f}.hire__actions .is-github:hover{background:#1b1f24}.hire__actions .is-linkedin{background:#0a66c2}.hire__actions .is-linkedin:hover{background:#004182}.about__writing-title{font:800 16px var(--sans);letter-spacing:-.3px;margin:24px 0 16px}.writing-item{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid var(--line);cursor:pointer}.writing-item__title{font:700 16px var(--sans)}.writing-item:hover .writing-item__title{color:var(--acc)}.writing-item__date{font:500 12px var(--mono);color:var(--mut);white-space:nowrap;margin-left:16px}.search{position:fixed;inset:0;z-index:100;background:rgba(26,26,26,.4);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:none;align-items:flex-start;justify-content:center;padding-top:12vh}.search.is-open{display:flex}.search__modal{width:min(620px,92vw);background:var(--card);border-radius:16px;box-shadow:0 24px 70px rgba(0,0,0,.3);overflow:hidden}.search__head{display:flex;align-items:center;gap:12px;padding:18px 22px;border-bottom:1px solid var(--line)}.search__input{flex:1;border:none;outline:none;font:500 16px var(--sans);color:var(--ink);background:0 0}.search__esc{font:500 11px var(--mono);color:var(--mut);border:1px solid var(--line);border-radius:5px;padding:2px 7px}.search__results{max-height:52vh;overflow-y:auto;padding:8px}.search__row{padding:13px 14px;border-radius:10px;cursor:pointer;display:flex;gap:12px;align-items:center}.search__row:hover,.search__row.is-active{background:var(--soft)}.search__thumb{width:46px;height:34px;border-radius:7px}.search__row-title{font:700 14px/1.3 var(--sans);color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search__row-meta{font:500 11px var(--mono);color:var(--mut)}.search__empty{padding:28px;text-align:center;font:500 14px var(--sans);color:var(--mut)}.load-more-wrap{display:flex;justify-content:center;margin-top:30px}.load-more{border:1.5px solid var(--ink);border-radius:100px;padding:12px 28px;font:700 14px var(--sans);background:0 0;cursor:pointer;transition:all .15s}.load-more:hover{background:var(--ink);color:var(--bg)}.is-hidden{display:none!important}@media(max-width:820px){.wrap{padding:0 24px}.two-col{grid-template-columns:1fr;gap:40px}.sidebar{display:none}.nav__tagline{display:none}.nav__links{display:none}.nav__search .kbd{display:none}.nav__menu-btn{display:flex}.hero{padding:36px 24px 28px}.hero__title{font-size:32px;letter-spacing:-1px}.hero__sub{font-size:16px}.list-head__title{font-size:30px}.row{gap:16px;padding:20px 0}.row__thumb{width:96px;height:72px}.row__title{font-size:17px}.row__deck{display:none}.row__tags,.row__dot{display:none}.article__grid{grid-template-columns:1fr;gap:0;padding:0 24px}.toc{display:none}.article__title{font-size:32px}.related{padding:40px 24px 8px}.related__grid{grid-template-columns:1fr}.about{padding:40px 24px 0}.about__name{font-size:32px}.about__cols{grid-template-columns:1fr}.footer__inner{padding:32px 24px}}