@font-face{font-family:inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/fonts/inter-latin.woff2)format('woff2');unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:jetbrains mono;font-style:normal;font-weight:400 700;font-display:swap;src:url(/fonts/jetbrains-mono-latin.woff2)format('woff2');unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--bg:#faf9f5;--text:#1a1a18;--muted:#6f6f66;--faint:#b0b0a8;--subtle:#e0dfdd;--surface:#ffffff;--border:#e2e8f0;--code-bg:#f5f4f0;--accent:#2563eb;--accent-rgb:37, 99, 235;--accent-text:#2563eb;--accent-soft:rgba(37, 99, 235, 0.08);--accent-glow:rgba(37, 99, 235, 0.15);--shadow:rgba(0, 0, 0, 0.06);--shadow-accent:rgba(37, 99, 235, 0.08);--glass:rgba(250, 249, 245, 0.96)}[data-theme=dark]{--bg:#161514;--text:#edebe8;--muted:#777777;--subtle:#2a2a28;--surface:#1e1d1c;--border:rgba(255, 255, 255, 0.08);--code-bg:#1e1e1c;--accent:#5b8dee;--accent-rgb:91, 141, 238;--accent-text:#5b8dee;--shadow:rgba(0, 0, 0, 0.3);--shadow-accent:rgba(91, 141, 238, 0.15);--glass:rgba(22, 21, 20, 0.96)}*,*::before,*::after{box-sizing:border-box}*{margin:0;padding:0}body:not(.home-page) .nav-wrap,body:not(.home-page) .nav-wrap *,body:not(.home-page) footer,body:not(.home-page) footer *{transition-duration:.05s !important;transition-delay:0s !important}html{background:var(--bg);scrollbar-gutter:stable}@media(prefers-reduced-motion:no-preference){html{scroll-behavior:smooth}}.preload *,.preload *::before,.preload *::after{transition-duration:0s !important}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;animation:focusPulse .35s cubic-bezier(.4,0,.2,1)}@keyframes focusPulse{0%{box-shadow:0 0 rgba(var(--accent-rgb),.35)}70%{box-shadow:0 0 0 6px rgba(var(--accent-rgb),0)}100%{box-shadow:0 0 0 6px rgba(var(--accent-rgb),0)}}body{font-family:inter,system-ui,-apple-system,sf pro text,segoe ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;text-align:left;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}h1{font-size:28px;font-weight:300;letter-spacing:-.5px;line-height:1.3;margin-bottom:.5em}h2{font-size:22px;font-weight:600;letter-spacing:-.3px;line-height:1.35;margin-bottom:.4em}h3{font-size:19px;font-weight:600;letter-spacing:-.3px;line-height:1.4;margin-bottom:.3em}h4{font-size:16px;font-weight:600;letter-spacing:-.2px;line-height:1.45;margin-bottom:.3em}p{margin-bottom:1em}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}code{font-family:jetbrains mono,ui-monospace,sf mono,menlo,consolas,monospace;font-size:.9em;background:var(--code-bg);padding:2px 6px;border-radius:4px}pre{background:var(--code-bg);padding:16px 20px;border-radius:8px;overflow-x:auto;white-space:pre;word-wrap:normal;-webkit-overflow-scrolling:touch}pre code{background:0 0;padding:0;border-radius:0;font-size:15px;white-space:pre-wrap;overflow-wrap:break-word;word-break:break-word}.highlight{overflow-x:auto;-webkit-overflow-scrolling:touch}blockquote{border-left:2px solid transparent;padding-left:16px;color:var(--muted);position:relative}blockquote::before{content:"";position:absolute;left:0;top:0;width:2px;height:0;background:var(--accent);transition:height .4s cubic-bezier(.4,0,.2,1)}blockquote.scroll-drawn::before{height:100%}hr{border:none;height:.5px;background:var(--border)}ul,ol{padding-left:1.5em;margin-bottom:1em}.text-hero{font-size:24px;font-weight:300;line-height:1.38;letter-spacing:-.3px}.text-heading{font-size:19px;font-weight:600;line-height:1.4;letter-spacing:-.3px}.text-body{font-size:16px;font-weight:400;line-height:1.7}.text-muted{font-size:15px;font-weight:400;line-height:1.6;color:var(--muted)}.text-caption{font-size:13px;font-weight:400;line-height:1.5;color:var(--muted)}.text-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--accent-text)}.text-code{font-size:14px;font-family:jetbrains mono,ui-monospace,sf mono,menlo,consolas,monospace;line-height:1.6}.text-logo{font-size:17px;font-weight:600;letter-spacing:-.5px}@media(min-width:640px){.text-hero{font-size:28px}}.container{max-width:840px;margin:0 auto;padding-left:20px;padding-right:20px}.container-wide{max-width:960px;margin:0 auto;padding-left:20px;padding-right:20px}.divider{height:.5px;background:var(--border);margin:0 0 20px}.glass{background:var(--glass);-webkit-backdrop-filter:saturate(180%)blur(20px);backdrop-filter:saturate(180%)blur(20px)}.capsule{border-radius:100px}.nav-wrap{position:fixed;top:16px;left:50%;transform:translateX(-50%);z-index:100;display:inline-flex;align-items:center;background:rgba(250,249,245,.38);backdrop-filter:saturate(360%)contrast(1.14)blur(16px);-webkit-backdrop-filter:saturate(360%)contrast(1.14)blur(16px);border:.5px solid rgba(255,255,255,.72);border-radius:100px;padding:5px 6px;box-shadow:0 2px 28px rgba(0,0,0,7%),inset 0 0 0 .5px rgba(255,255,255,.95),inset 0 1px rgba(255,255,255,.55);white-space:nowrap;gap:2px;animation:navIn .6s cubic-bezier(.4,0,.2,1)both 0ms}[data-theme=dark] .nav-wrap{background:rgba(13,13,12,.48);backdrop-filter:saturate(300%)contrast(1.1)blur(24px);-webkit-backdrop-filter:saturate(300%)contrast(1.1)blur(24px);border-color:rgba(255,255,255,.13);box-shadow:0 2px 28px rgba(0,0,0,.38),inset 0 0 0 .5px rgba(255,255,255,.2),inset 0 1px rgba(255,255,255,.22)}@keyframes navIn{from{opacity:0;transform:translateX(-50%)translateY(-10px)}to{opacity:1;transform:translateX(-50%)translateY(0)}}.nav-logo{height:34px;padding:0 12px;border-radius:100px;display:flex;align-items:center;justify-content:center;cursor:pointer;margin-right:10px;text-decoration:none;transition:background .2s}.nav-logo:hover{background:rgba(0,0,0,5%)}.nav-logo svg{height:14px;width:auto;color:var(--text);display:block;transform:translateY(1.5px)}.nav-links{display:flex;gap:2px;margin-right:4px}.nav-link{font-size:13px;color:var(--muted);padding:7px 12px;border-radius:100px;cursor:pointer;text-decoration:none;transition:background .18s,color .18s}.nav-link:hover{background:rgba(26,26,24,7%);color:var(--text)}.nav-link.on{background:var(--accent);color:#fff;font-weight:600}.nav-link.on:hover{background:var(--accent);color:#fff}[data-theme=dark] .nav-link:hover{background:rgba(255,255,255,8%)}[data-theme=dark] .nav-link.on:hover{background:var(--accent)}.nav-sep{width:.5px;height:14px;background:rgba(0,0,0,8%);margin:0 3px;align-self:center;flex-shrink:0}[data-theme=dark] .nav-sep{background:rgba(255,255,255,.12)}.nav-btn{width:34px;height:34px;border-radius:100px;display:flex;align-items:center;justify-content:center;color:var(--muted);cursor:pointer;background:0 0;border:none;transition:background .15s,transform .2s cubic-bezier(.34,1.56,.64,1)}.nav-btn:hover{background:rgba(0,0,0,6%);transform:scale(1.1)}.nav-btn:active{transform:scale(.88);transition-duration:.08s}.nav-btn svg{stroke:var(--muted)}[data-theme=dark] .nav-btn:hover{background:rgba(255,255,255,8%)}.nav-theme-icon-light,.nav-theme-icon-dark{display:flex;align-items:center;justify-content:center}.nav-theme-icon-dark{display:none}[data-theme=dark] .nav-theme-icon-light{display:none}[data-theme=dark] .nav-theme-icon-dark{display:flex}@media(max-width:480px){.nav-link{padding:7px 8px;font-size:12px}.nav-logo{padding:0 10px;margin-right:6px}}footer{border-top:.5px solid var(--border);padding:18px 0;background:0 0}.ftr{max-width:840px;margin:0 auto;padding:0 48px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:20px}.ftr-langs{display:flex;align-items:center;gap:2px}.lang-btn{font-size:11px;font-weight:400;color:var(--muted);background:0 0;border:none;cursor:pointer;font-family:inherit;padding:3px 7px;border-radius:4px;transition:color .15s,background .15s;line-height:1.5}.lang-btn:hover{color:var(--text);background:rgba(0,0,0,4%)}.lang-btn.on{color:var(--accent);font-weight:600}[data-theme=dark] .lang-btn:hover{background:rgba(255,255,255,6%)}.lang-div{font-size:11px;color:rgba(26,26,24,.15);user-select:none;padding:0 1px}.ftr-date{font-size:11px;color:var(--muted);white-space:nowrap}.ftr-socs{display:flex;align-items:center;gap:14px;justify-content:flex-end}.ftr-soc{display:flex;color:var(--muted);cursor:pointer;opacity:.45;text-decoration:none;transition:color .2s,transform .2s cubic-bezier(.34,1.56,.64,1),opacity .15s}.ftr-soc:hover{color:var(--accent);transform:scale(1.14)translateY(-2px);opacity:1}.ftr-socs:hover .ftr-soc{opacity:.22}.ftr-socs:hover .ftr-soc:hover{opacity:1}.ftr-soc.gh:hover{color:var(--text)}.ftr-soc.li:hover{color:#0a66c2}.ftr-soc.xx:hover{color:var(--text)}@media(max-width:600px){.ftr{grid-template-columns:1fr;justify-items:center;gap:12px;padding:0 20px;text-align:center}.ftr-date{text-align:center !important}}.reading-progress-bar{position:fixed;top:0;left:0;right:0;height:2px;z-index:50;background:0 0}.reading-progress-fill{height:100%;width:100%;transform:scaleX(0);transform-origin:0 0;background:var(--accent);border-radius:0 1px 1px 0;will-change:transform;transition:transform .1s linear}.hero{text-align:center;max-width:520px;margin:0 auto;position:relative}.article-row{display:block;text-decoration:none;color:inherit;padding:14px 0;border-bottom:.5px solid var(--border);transition:border-color .2s cubic-bezier(.4,0,.2,1),background-color .2s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1);will-change:transform;content-visibility:auto;contain-intrinsic-size:0 64px}.article-row:hover{transform:translateX(10px);border-color:var(--accent);background:linear-gradient(90deg,rgba(var(--accent-rgb),.03),transparent 60%)}.article-row:active{transform:scale(.99);transition-duration:.05s}.article-list>.article-row:last-child,.writing-group:last-child>.article-row:last-child{border-bottom:none}.article-row-top{display:grid;grid-template-columns:32px 1fr auto;align-items:baseline;gap:0 10px}.article-row-title{font-size:16px;font-weight:400;letter-spacing:-.1px;line-height:1.35;transition:color .2s cubic-bezier(.4,0,.2,1)}.article-row:hover .article-row-title{color:var(--accent)}.article-row-title::after{content:" \2192";opacity:0;display:inline-block;transform:translateX(-4px);transition:opacity .15s cubic-bezier(.4,0,.2,1),transform .15s cubic-bezier(.4,0,.2,1);color:var(--accent)}.article-row:hover .article-row-title::after{opacity:1;transform:translateX(0)}.article-row-date{font-size:11px;padding:2px 8px;border-radius:100px;background:var(--code-bg);color:var(--muted);font-variant-numeric:tabular-nums;font-weight:500;flex-shrink:0}.article-row-excerpt{font-size:14px;color:var(--muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;max-height:0;opacity:0;transition:opacity .2s ease;margin-top:0}.article-row:hover .article-row-excerpt{max-height:24px;opacity:1;margin-top:4px}.article-row-right{display:flex;align-items:center;gap:6px;flex-shrink:0;margin-left:12px}.article-row-right .meta-dot{display:none}.article-row-reading{font-size:11px;padding:2px 8px;border-radius:100px;background:var(--code-bg);color:var(--muted);white-space:nowrap;font-weight:500}.article-row-tag{font-size:11px;padding:2px 8px;border-radius:100px;background:var(--accent-soft);color:var(--accent-text);font-weight:500;white-space:nowrap}.type-badge{font-size:11px;padding:2px 10px;border-radius:100px;font-weight:500;flex-shrink:0;white-space:nowrap}.type-badge--article{background:var(--code-bg);color:var(--muted)}.type-badge--note{background:rgba(59,130,246,.1);color:#3b82f6}[data-theme=dark] .type-badge--note{background:rgba(59,130,246,.15);color:#60a5fa}.back-link{font-size:15px;color:var(--muted);text-decoration:none;display:inline-block;margin-bottom:8px;transition:color .2s cubic-bezier(.4,0,.2,1)}.back-link:hover{color:var(--text)}.tag-pills-divider{width:1px;height:20px;background:var(--border);flex-shrink:0;align-self:center}.wl-section-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--accent-text);margin-bottom:8px}.reading-time-badge{font-size:9px;padding:2px 7px;border-radius:100px;background:var(--accent-soft);color:var(--accent-text);font-weight:500}.projects-index .article-row-top{display:flex;align-items:baseline;gap:10px}.projects-index .article-row-top .article-row-title{flex:1}.article-row-badges{display:flex;align-items:center;gap:6px;flex-shrink:0}.projects-index .article-row .reading-time-badge{background:var(--code-bg);color:var(--muted);transition:background .2s cubic-bezier(.4,0,.2,1),color .2s cubic-bezier(.4,0,.2,1)}.projects-index .article-row:hover .reading-time-badge{background:var(--accent-soft);color:var(--accent-text)}.tag-pills{display:flex;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:16px 0 4px}.tag-pills::-webkit-scrollbar{display:none}.tag-pill{font-size:13px;padding:5px 14px;border-radius:100px;border:1px solid var(--border);color:var(--muted);background:0 0;white-space:nowrap;flex-shrink:0;cursor:pointer;transition:border-color .2s cubic-bezier(.4,0,.2,1),color .2s cubic-bezier(.4,0,.2,1),background-color .2s cubic-bezier(.4,0,.2,1),transform .15s cubic-bezier(.4,0,.2,1)}button.tag-pill{font-family:inherit;line-height:inherit}.tag-pill--search{padding:5px 10px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);background:0 0;border-radius:100px;color:var(--muted);cursor:pointer;transition:border-color .25s cubic-bezier(.4,0,.2,1),color .25s cubic-bezier(.4,0,.2,1),background-color .25s cubic-bezier(.4,0,.2,1)}.tag-pill--search:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.tag-pill:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.tag-pill:active{transform:scale(.96);transition-duration:.08s}.tag-pill.active{border-color:var(--accent);background:var(--accent);color:#fff}.writing-search-container{margin-bottom:4px}.writing-search-container .pagefind-ui{--pagefind-ui-scale:0.9;--pagefind-ui-primary:var(--accent);--pagefind-ui-text:var(--text);--pagefind-ui-background:var(--surface);--pagefind-ui-border:var(--border);--pagefind-ui-tag:var(--accent-soft);--pagefind-ui-border-width:1px;--pagefind-ui-border-radius:10px;--pagefind-ui-font:system-ui, -apple-system, sans-serif}.writing-search-container .pagefind-ui__search-input{border-radius:10px;font-size:14px}.writing-search-container .pagefind-ui__result{border-top:.5px solid var(--border);padding:12px 0}.writing-search-container .pagefind-ui__result-title{font-size:15px;font-weight:400}.writing-filters{display:flex;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:12px 0 16px}.writing-filters::-webkit-scrollbar{display:none}.writing-group{margin-bottom:8px}.writing-group-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--accent-text);margin:20px 0 4px;text-align:center}.writing-group:first-child .writing-group-label{margin-top:4px}@media(max-width:640px){.article-row{padding:11px 0}.article-row-title{font-size:15px}.article-row-right{margin-left:8px}.article-row-right .article-row-tag,.article-row-right .article-row-reading{display:none}.projects-index .project-status{display:none}.projects-index .article-row-excerpt{max-height:60px;opacity:1;margin-top:4px}}.year-sep{display:flex;align-items:center;gap:14px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--accent-text);margin-top:28px;margin-bottom:14px;user-select:none}.year-sep--first{margin-top:6px}.year-sep::before,.year-sep::after{content:"";flex:1;height:1px;background:rgba(var(--accent-rgb),.35)}.year-sep-line{display:none}.month-sep{height:.5px;background:rgba(var(--accent-rgb),.12);margin:0}.article-row-month{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);padding-top:2px;line-height:1.35;opacity:.55}.recently-read{margin-bottom:20px;padding-bottom:16px;border-bottom:.5px solid var(--border)}.recently-read-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--accent-text);margin-bottom:8px}.recently-read-items{display:flex;flex-direction:column;gap:4px}.recently-read-item{font-size:14px;color:var(--muted);text-decoration:none;padding:6px 0;transition:color .2s ease}.recently-read-item:hover{color:var(--accent)}.writing{display:flex;flex-direction:column}.art{display:block;padding:15px 0;border-bottom:.5px solid var(--border);text-decoration:none;cursor:pointer;transition:transform .25s cubic-bezier(.34,1.56,.64,1)}.art:first-child{border-top:.5px solid var(--border)}.art:hover{transform:translateX(9px)}.art-meta{display:flex;align-items:baseline;gap:14px}.art-date{font-size:11px;color:var(--faint);min-width:64px;flex-shrink:0;font-variant-numeric:tabular-nums;transition:color .2s;white-space:nowrap}.art-title{flex:1;font-size:15px;font-weight:400;color:var(--text);letter-spacing:-.1px;transition:color .2s}.art:hover .art-title{color:var(--accent)}.art-excerpt{margin-left:78px;font-size:13px;color:var(--muted);font-weight:300;line-height:1.6;max-height:0;overflow:hidden;opacity:0;transition:max-height .32s cubic-bezier(.4,0,.2,1),opacity .25s ease,margin-top .25s ease;margin-top:0}.art:hover .art-excerpt{max-height:52px;opacity:1;margin-top:6px}.art.tp:hover .art-date{color:#2563eb}.art.ts:hover .art-date{color:#dc2626}.art.tg:hover .art-date{color:#0080a0}.art.td:hover .art-date{color:#7c3aed}.art.te:hover .art-date{color:#059669}.tag{font-size:11px;padding:3px 10px;border-radius:100px;font-weight:500;white-space:nowrap;text-transform:uppercase;letter-spacing:.3px;flex-shrink:0;transition:box-shadow .2s}.tag-go{background:rgba(0,163,196,.1);color:#0080a0}.tag-payments{background:rgba(37,99,235,8%);color:#2563eb}.tag-security{background:rgba(220,38,38,8%);color:#dc2626}.tag-distributed-systems{background:rgba(124,58,237,.1);color:#7c3aed}.tag-engineering-practices{background:rgba(5,150,105,.1);color:#059669}.art:hover .tag-go{box-shadow:0 0 0 3px rgba(0,163,196,.12)}.art:hover .tag-payments{box-shadow:0 0 0 3px rgba(37,99,235,.1)}.art:hover .tag-security{box-shadow:0 0 0 3px rgba(220,38,38,.1)}.art:hover .tag-distributed-systems{box-shadow:0 0 0 3px rgba(124,58,237,.1)}.art:hover .tag-engineering-practices{box-shadow:0 0 0 3px rgba(5,150,105,.1)}.proj-list:hover .proj{opacity:.3}.proj-list:hover .proj:hover{opacity:1}.proj{display:flex;align-items:baseline;padding:14px 0;border-bottom:.5px solid var(--border);text-decoration:none;cursor:pointer;gap:14px;transition:opacity .18s}.proj:first-child{border-top:.5px solid var(--border)}.proj-num{font-size:11px;color:rgba(26,26,24,7%);font-variant-numeric:tabular-nums;letter-spacing:.5px;flex-shrink:0;min-width:22px;transition:color .2s}.proj:hover .proj-num{color:var(--accent)}.proj-nw{position:relative;flex-shrink:0}.proj-nw::after{content:'';position:absolute;bottom:-1px;left:0;width:0;height:1px;background:var(--accent);transition:width .3s cubic-bezier(.4,0,.2,1)}.proj:hover .proj-nw::after{width:100%}.proj-name{font-size:15px;font-weight:500;color:var(--text);letter-spacing:-.1px;transition:color .2s}.proj:hover .proj-name{color:var(--accent)}.proj-note{flex:1;font-size:12px;color:var(--faint);padding-left:4px;transition:color .2s}.proj:hover .proj-note{color:var(--muted)}.feat-block{padding:40px 0 32px}.feat-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--faint);margin-bottom:16px}.feat-quote{font-size:17px;font-weight:300;line-height:1.55;letter-spacing:-.25px;color:var(--text);margin-bottom:16px}.feat-quote em{font-style:normal;color:var(--accent)}.feat-quote p{margin-bottom:0}.feat-attr{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--faint)}.feat-attr::before{content:''}.feat-dot{width:5px;height:5px;border-radius:50%;background:#f59e0b;flex-shrink:0}.feat-dot.fresh{background:var(--accent);animation:featDotPulse 3s ease-in-out infinite}@keyframes featDotPulse{0%,100%{opacity:.35;transform:scale(.8)}50%{opacity:.9;transform:scale(1.1)}}.section-split{display:flex;flex-direction:column}.section-row{display:grid;grid-template-columns:100px 1fr;gap:16px;padding:16px 0;border-bottom:.5px solid var(--border)}.section-row:last-child{border-bottom:none}.section-key{font-size:12px;font-weight:600;color:var(--text);letter-spacing:-.1px;padding-top:2px}.section-val{font-size:13px;font-weight:300;color:var(--muted);line-height:1.65}.section-val p{margin-bottom:0}.section-pills{display:flex;gap:6px;flex-wrap:wrap}.section-pill{font-size:11px;padding:4px 12px;border-radius:100px;border:.5px solid var(--border);color:var(--muted);transition:border-color .18s,color .18s,background .18s;cursor:default}.section-link-pills{display:flex;gap:6px;flex-wrap:wrap}.about-section{display:grid;grid-template-columns:200px 1fr;gap:52px;padding:56px 0;border-top:.5px solid var(--border)}.about-section-right{font-size:15px;font-weight:300;line-height:1.65;color:var(--muted)}.about-entry{margin-bottom:20px}.about-entry:last-child{margin-bottom:0}.about-entry-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--faint);margin-bottom:5px}.about-entry-name{font-size:14px;font-weight:500;color:var(--text);margin-bottom:2px}.about-entry-detail{font-size:13px;font-weight:300;color:var(--muted)}.about-entry-pills{margin-top:8px}@media(max-width:640px){.about-section{grid-template-columns:1fr;gap:16px;padding:40px 0}}.section-group{padding:10px 0 6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.9px;color:var(--faint);border-bottom:.5px solid var(--border);margin-top:4px}.section-group:first-child{margin-top:0}.edu-entry{display:flex;flex-direction:column;gap:1px}.edu-school{font-size:13px;font-weight:500;color:var(--text)}.edu-detail{font-size:12px;font-weight:300;color:var(--muted);margin-top:2px}.edu-badge{display:inline-block;font-size:10px;font-weight:600;letter-spacing:.3px;color:var(--accent-text);background:var(--accent-soft);padding:2px 8px;border-radius:4px;margin-top:5px;width:fit-content}@media(max-width:600px){.section-row{grid-template-columns:72px 1fr;gap:12px}.feat-quote{font-size:15px}.feat-block{padding:28px 0 24px}}.selection-share{position:absolute;z-index:60;display:flex;gap:2px;padding:4px;background:var(--glass);-webkit-backdrop-filter:saturate(180%)blur(20px);backdrop-filter:saturate(180%)blur(20px);border:.5px solid var(--border);border-radius:10px;box-shadow:0 4px 16px var(--shadow);opacity:0;pointer-events:none;transform:translateY(4px);transition:opacity .15s ease,transform .15s ease}.selection-share.visible{opacity:1;pointer-events:auto;transform:translateY(0)}.selection-share-btn{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:background .15s ease,color .15s ease}.selection-share-btn:hover{background:var(--accent-soft);color:var(--accent)}.share-bar{display:flex;gap:10px;margin-top:20px;padding-top:16px;border-top:.5px solid var(--border)}.share-btn{display:flex;align-items:center;gap:5px;font-size:13px;color:var(--muted);cursor:pointer;padding:6px 14px;border-radius:100px;border:.5px solid var(--border);background:0 0;transition:border-color .2s cubic-bezier(.4,0,.2,1),color .2s cubic-bezier(.4,0,.2,1),background-color .2s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1)}.share-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.share-btn:active{transform:scale(.96);transition-duration:.08s}.share-btn.copied{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.toc{display:none}.toc-title{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:8px}.toc ul{list-style:none;padding:0}.toc li{font-size:14px;padding:4px 0 4px 14px;color:var(--muted);border-left:2px solid var(--border);transition:color .2s cubic-bezier(.4,0,.2,1),border-color .2s cubic-bezier(.4,0,.2,1),padding-left .2s cubic-bezier(.4,0,.2,1)}.toc li:hover{color:var(--text);border-left-color:var(--accent);padding-left:18px}.toc li.active{color:var(--accent-text);border-left-color:var(--accent);font-weight:500}.toc a{color:inherit;text-decoration:none}@keyframes headingHighlight{0%{box-shadow:0 0 0 3px var(--accent),0 0 12px rgba(var(--accent-rgb),.2)}100%{box-shadow:0 0 0 3px transparent,0 0 12px transparent}}.heading-flash{border-radius:4px;animation:headingHighlight 1.2s cubic-bezier(.4,0,.2,1)forwards}.toc-mobile{margin-bottom:20px;border:.5px solid var(--border);border-radius:10px;overflow:hidden}@media(min-width:1200px){.toc-mobile{display:none}}.toc-mobile-toggle{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);cursor:pointer;list-style:none;user-select:none;transition:color .2s ease}.toc-mobile-toggle::-webkit-details-marker{display:none}.toc-mobile-toggle::after{content:"+";font-size:16px;font-weight:300;color:var(--muted);transition:transform .2s ease,color .2s ease}.toc-mobile[open] .toc-mobile-toggle::after{content:"-";color:var(--accent)}.toc-mobile[open] .toc-mobile-toggle{color:var(--accent-text);border-bottom:.5px solid var(--border)}.toc-mobile-content{padding:8px 16px 12px}.toc-mobile-content ul{list-style:none;padding:0;margin:0}.toc-mobile-content li{font-size:14px;padding:5px 0 5px 12px;color:var(--muted);border-left:2px solid var(--border);transition:color .2s ease,border-color .2s ease,padding-left .2s ease}.toc-mobile-content li:hover{color:var(--text);border-left-color:var(--accent);padding-left:16px}.toc-mobile-content a{color:inherit;text-decoration:none}.article{padding:0}.article-header{margin-bottom:20px}.article-title{font-size:26px;font-weight:400;line-height:1.3;letter-spacing:-.4px;margin-bottom:10px}.article-meta{display:flex;gap:10px;align-items:center;font-size:13px;color:var(--muted);margin-bottom:20px}.meta-dot{width:2px;height:2px;border-radius:50%;background:var(--subtle)}.article-body{font-size:16px;line-height:1.7;text-align:justify}.article-body p{margin-bottom:16px}.article-body h2{margin-top:32px;margin-bottom:12px;scroll-margin-top:88px}.article-body h3{margin-top:24px;margin-bottom:8px;scroll-margin-top:88px}.article-body a{color:var(--accent-text);position:relative;transition:color .15s ease}.article-body a::before{content:"";position:absolute;bottom:-1px;left:0;width:0;height:1.5px;background:linear-gradient(90deg,var(--accent),rgba(var(--accent-rgb),.4));transition:width .25s cubic-bezier(.4,0,.2,1)}.article-body a:hover{color:var(--accent)}.article-body a:hover::before{width:100%}.article-body img{max-width:100%;height:auto}.img-blur-up{background-size:cover;background-position:50%;filter:blur(8px);transition:filter .4s ease}.img-blur-up.loaded{filter:none}.article-nav{display:flex;justify-content:space-between;margin-top:32px;padding-top:16px;border-top:.5px solid var(--border)}.article-nav-link{display:flex;flex-direction:column;gap:2px;font-size:14px;color:var(--muted);text-decoration:none;max-width:45%;transition:color .2s cubic-bezier(.4,0,.2,1)}.article-nav-link:hover{color:var(--accent)}.article-nav-link.next{text-align:right;align-items:flex-end}.anav-dir{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.3px;color:var(--muted)}.anav-title{font-size:14px;color:var(--text);font-weight:400;transition:color .15s ease;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.article-nav-link:hover .anav-title{color:var(--accent)}.anav-peek{font-size:11px;color:var(--muted);max-height:0;overflow:hidden;opacity:0;transition:opacity .2s ease;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.article-nav-link:hover .anav-peek{max-height:40px;opacity:1}@media(max-width:640px){.anav-peek{display:none}}.view-all-link{display:flex;align-items:center;gap:6px;font-size:15px;font-weight:500;color:var(--text);text-decoration:none;margin-top:12px;transition:transform .2s ease}.view-all-link:hover{transform:translateX(4px)}.view-all-link .arrow-right{color:var(--accent)}.view-all-link:hover .arrow-right{transform:translateX(4px)}.heading-anchor{position:absolute;left:-24px;top:50%;transform:translateY(-50%);opacity:0;color:var(--muted);transition:opacity .2s ease,color .2s ease;display:flex;align-items:center}.article-body .heading-anchor{position:absolute;color:var(--muted);text-decoration:none}.article-body .heading-anchor::before,.article-body .heading-anchor:hover::before{display:none}h2:hover .heading-anchor,h3:hover .heading-anchor{opacity:1}.heading-anchor:hover{color:var(--accent)}@media(max-width:768px){.heading-anchor{display:none}}.footnote-tooltip{position:absolute;z-index:70;max-width:320px;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 16px var(--shadow);font-size:15px;line-height:1.5;color:var(--text);opacity:0;pointer-events:none;transform:translateY(4px);transition:opacity .15s ease,transform .15s ease}.footnote-tooltip.visible{opacity:1;transform:translateY(0)}.footnote-tooltip p{margin-bottom:0}.article-body img{cursor:zoom-in;border-radius:8px;transition:transform .2s ease}.article-body img:hover{transform:scale(1.01)}.tldr-block{border-left:2px solid var(--accent);background:var(--accent-soft);padding:12px 16px;border-radius:0 8px 8px 0;margin-bottom:24px}.tldr-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--accent-text);display:block;margin-bottom:4px}.tldr-content{font-size:15px;line-height:1.6;color:var(--text)}.tldr-content p:last-child{margin-bottom:0}.lightbox{position:fixed;inset:0;z-index:90;display:flex;align-items:center;justify-content:center}.lightbox[hidden]{display:none}.lightbox-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.8);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.lightbox-content{position:relative;z-index:1;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;gap:16px}.lightbox-body{width:min(88vw,960px);overflow:auto;max-height:84vh;background:var(--surface);border-radius:16px;padding:32px}.lightbox[data-mode=image] .lightbox-body{background:0 0;border-radius:0;padding:0;display:flex;align-items:center;justify-content:center}.lightbox[data-mode=image] .lightbox-body img{max-width:92vw;max-height:88vh;height:auto;border-radius:8px;box-shadow:0 24px 80px rgba(0,0,0,.6)}.lightbox[data-mode=image] .lightbox-btn[data-action=download-svg],.lightbox[data-mode=image] .lightbox-btn[data-action=download-png]{display:none}.lightbox-body svg,.lightbox-body img{max-width:100%;height:auto}.lightbox-controls{display:flex;gap:8px;align-items:center}.lightbox-btn{padding:8px 18px;border-radius:100px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.1);color:#fff;font-size:14px;font-family:inherit;cursor:pointer;transition:border-color .2s ease,color .2s ease,background-color .2s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.lightbox-btn:hover{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.45)}.lightbox-close{width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;font-size:20px;border-radius:50%}.diagram-container{position:relative;margin:24px 0;border:1px solid var(--border);border-radius:12px;padding:24px;background:var(--surface);overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;cursor:zoom-in}@media(max-width:640px){.diagram-container{padding:16px;border-radius:8px}}.diagram-container .mermaid,.diagram-container .plantuml-diagram{display:flex;justify-content:center;min-width:min-content}.diagram-container svg{max-width:100%;height:auto;display:block}.mermaid:not([data-processed]){visibility:hidden;position:relative;min-height:120px}.mermaid:not([data-processed])::after{content:'';visibility:visible;position:absolute;inset:0;border-radius:8px;background:linear-gradient(90deg,var(--code-bg) 25%,var(--surface) 50%,var(--code-bg) 75% );background-size:200% 100%;animation:diagramShimmer 1.5s ease infinite}@keyframes diagramShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}.lightbox-body svg{width:85vw;max-width:1000px;height:auto}.diagram-actions{position:absolute;top:8px;right:8px;opacity:0;transition:opacity .2s ease}.diagram-container:hover .diagram-actions{opacity:1}.diagram-action{width:32px;height:32px;border-radius:8px;border:.5px solid var(--border);background:var(--surface);color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;background:0 0;transition:color .2s ease,background-color .2s ease}.diagram-action:hover{border-color:var(--accent);color:var(--accent)}[data-theme=dark] .plantuml-diagram{filter:invert(1)hue-rotate(180deg)}.callout{display:flex;gap:12px;padding:16px;border-left:3px solid;border-radius:0 8px 8px 0;margin:24px 0}.callout-icon{font-size:18px;flex-shrink:0;line-height:1.6}.callout-body{flex:1;font-size:15px;line-height:1.6;text-align:justify}.callout-body p:last-child{margin-bottom:0}.callout--info{border-color:#3b82f6;background:#eff6ff}.callout--warning{border-color:#f59e0b;background:#fffbeb}.callout--tip{border-color:var(--accent);background:var(--accent-soft)}.callout--note{border-color:#6b7280;background:#f9fafb}.callout--insight{border-color:#8b5cf6;background:#f5f3ff}[data-theme=dark] .callout--info{background:#1e293b}[data-theme=dark] .callout--warning{background:#292524}[data-theme=dark] .callout--tip{background:var(--accent-soft)}[data-theme=dark] .callout--note{background:#1f2937}[data-theme=dark] .callout--insight{background:#1e1b2e}.compare{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:24px 0}@media(max-width:640px){.compare{grid-template-columns:1fr}}.compare-side{padding:16px;border-radius:8px;border:1px solid var(--border);background:var(--surface)}.compare-title{font-size:13px;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin-bottom:8px;font-weight:600}.compare-body{font-size:15px;line-height:1.6;text-align:justify}.compare-body p:last-child{margin-bottom:0}pre{position:relative}.code-actions{position:absolute;top:8px;right:8px;display:inline-flex;align-items:center;gap:0;padding:3px;border-radius:100px;background:rgba(255,255,255,.82);border:.5px solid rgba(255,255,255,.9);box-shadow:0 0 0 .5px rgba(0,0,0,7%),0 1px 5px rgba(0,0,0,8%),inset 0 1px #fff;backdrop-filter:blur(10px)saturate(160%);-webkit-backdrop-filter:blur(10px)saturate(160%);z-index:2}.code-actions.has-lang{padding-left:10px}[data-theme=dark] .code-actions{background:rgba(255,255,255,7%);border:.5px solid rgba(255,255,255,.13);box-shadow:0 0 0 .5px rgba(0,0,0,.3),0 1px 6px rgba(0,0,0,.4),inset 0 1px rgba(255,255,255,9%)}.code-lang{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:rgba(26,26,24,.48);white-space:nowrap;font-family:inter,system-ui,sans-serif;padding-right:8px;border-right:.5px solid rgba(0,0,0,9%);pointer-events:none}[data-theme=dark] .code-lang{color:rgba(255,255,255,.38);border-right-color:rgba(255,255,255,8%)}pre .copy-btn{width:26px;height:26px;padding:0;border-radius:100px;border:none;background:0 0;color:rgba(26,26,24,.42);cursor:pointer;display:flex;align-items:center;justify-content:center;margin-left:3px;transition:color .2s cubic-bezier(.4,0,.2,1),background .15s cubic-bezier(.4,0,.2,1)}[data-theme=dark] pre .copy-btn{color:rgba(255,255,255,.35)}pre .copy-btn:hover{color:var(--accent);background:rgba(37,99,235,8%)}[data-theme=dark] pre .copy-btn:hover{color:#7ab8ff;background:rgba(37,99,235,.12)}pre .copy-btn.copied{color:#059669;background:rgba(16,185,129,8%)}pre .copy-btn .check-icon polyline{stroke-dasharray:28;stroke-dashoffset:28;animation:draw-check .3s cubic-bezier(.4,0,.2,1)forwards}@keyframes draw-check{to{stroke-dashoffset:0}}.highlight .kw,.highlight .k{color:var(--accent)}.highlight .s,.highlight .s2{color:#c4956a}.highlight .c,.highlight .cm{color:var(--muted)}.highlight .mi,.highlight .mf{color:#6366f1}.highlight .nb{color:var(--accent)}[data-theme=dark] .highlight .s,[data-theme=dark] .highlight .s2{color:#e9a97c}[data-theme=dark] .highlight .mi,[data-theme=dark] .highlight .mf{color:#818cf8}pre.code-collapsed{max-height:400px;overflow:hidden}pre.code-collapsed .code-expand-btn{display:flex}.code-expand-btn{display:none;position:absolute;bottom:8px;left:50%;transform:translateX(-50%);font-size:12px;color:var(--muted);padding:4px 14px;border-radius:100px;border:.5px solid var(--border);background:var(--surface);cursor:pointer;font-family:inherit;z-index:2;transition:border-color .2s ease,color .2s ease,background-color .2s ease}.code-expand-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}pre.code-collapsed::before{content:"";position:absolute;bottom:0;left:0;right:0;height:60px;background:linear-gradient(transparent,var(--code-bg));pointer-events:none;z-index:1}.back-to-top{position:fixed;bottom:76px;left:50%;transform:translateX(-50%)translateY(10px);opacity:0;pointer-events:none;transition:opacity .3s cubic-bezier(.4,0,.2,1),transform .3s cubic-bezier(.4,0,.2,1);z-index:9;white-space:nowrap}.back-to-top.visible{opacity:1;transform:translateX(-50%)translateY(0);pointer-events:auto}@media(min-width:768px){.back-to-top{bottom:76px}}.back-to-top button{display:flex;align-items:center;gap:6px;font-size:14px;color:var(--muted);padding:6px 12px;border-radius:100px;border:1px solid var(--border);background:var(--surface);cursor:pointer;font-family:inherit;transition:border-color .25s cubic-bezier(.4,0,.2,1),color .25s cubic-bezier(.4,0,.2,1),transform .25s cubic-bezier(.4,0,.2,1),box-shadow .25s cubic-bezier(.4,0,.2,1)}.back-to-top button:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 16px var(--shadow-accent)}.back-to-top button:active{transform:scale(.96)translateY(0);box-shadow:none;transition-duration:.08s}[data-theme=dark] .back-to-top button{background:rgba(13,13,12,.48);border-color:rgba(255,255,255,.13);backdrop-filter:saturate(300%)contrast(1.1)blur(24px);-webkit-backdrop-filter:saturate(300%)contrast(1.1)blur(24px);box-shadow:0 2px 20px rgba(0,0,0,.35),inset 0 0 0 .5px rgba(255,255,255,.2),inset 0 1px rgba(255,255,255,.22)}[data-theme=dark] .back-to-top button:hover{border-color:rgba(255,255,255,.18);box-shadow:0 2px 24px rgba(0,0,0,.42),inset 0 0 0 .5px rgba(255,255,255,.26),inset 0 1px rgba(255,255,255,.28)}.btt-sep{width:1px;height:14px;background:var(--border)}.btt-pct{font-size:11px;font-weight:600;font-variant-numeric:tabular-nums;color:var(--accent-text);min-width:28px;text-align:right}a[target=_blank]:not(.social-link):not(.article-row):not(.article-nav-link):not(.soc-btn):not(.cta):not(.ftr-soc):not(.nav-logo):not(.nav-link)::after{content:"\2197";font-size:12px;opacity:0;display:inline-block;transform:translateY(2px);margin-left:2px;transition:opacity .2s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1)}a[target=_blank]:not(.social-link):not(.article-row):not(.article-nav-link):not(.soc-btn):not(.cta):not(.ftr-soc):not(.nav-logo):not(.nav-link):hover::after{opacity:1;transform:translateY(0)}.external-link .ext-icon{font-size:12px;opacity:0;transform:translateY(2px);transition:opacity .2s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1)}.external-link:hover .ext-icon{opacity:1;transform:translateY(0)}.skip-link{position:absolute;top:-100%;left:16px;background:var(--accent);color:#fff;padding:8px 16px;border-radius:8px;z-index:200;text-decoration:none;font-size:15px;transition:top .2s cubic-bezier(.4,0,.2,1)}.skip-link:focus{top:16px}.tech-badge{display:inline-flex;align-items:center;gap:4px}.tech-badge-icon{display:inline-flex;align-items:center;flex-shrink:0;width:12px;height:12px}.tech-badge-icon svg{width:100%;height:100%}.video-container{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:12px;margin:20px 0;background:var(--code-bg)}.video-container iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none;border-radius:12px}.project-github-wrap{margin-top:8px}.project-github-icon{display:inline-flex;align-items:center;margin-right:5px}.newsletter-form-wrap{margin-top:20px}.cta{position:relative;height:32px;display:inline-flex;align-items:center;gap:7px;padding:0 14px 0 10px;border-radius:100px;border:none;background:var(--surface);box-shadow:0 0 0 .5px rgba(0,0,0,9%),0 1px 3px rgba(0,0,0,7%),inset 0 1px rgba(255,255,255,.9);cursor:pointer;text-decoration:none;color:var(--muted);font-size:13px;font-weight:500;letter-spacing:-.1px;white-space:nowrap;flex-shrink:0;transition:color .18s,box-shadow .2s,transform .25s cubic-bezier(.34,1.56,.64,1),opacity .15s}.cta:hover{color:var(--text);box-shadow:0 0 0 .5px rgba(0,0,0,.12),0 4px 12px rgba(0,0,0,.1),inset 0 1px rgba(255,255,255,.9);transform:translateY(-2px)}.cta:active{transform:scale(.96)translateY(0);box-shadow:0 0 0 .5px rgba(0,0,0,9%),0 1px 2px rgba(0,0,0,6%),inset 0 1px rgba(255,255,255,.9);transition-duration:.08s}[data-theme=dark] .cta{background:rgba(13,13,12,.48);backdrop-filter:saturate(300%)contrast(1.1)blur(24px);-webkit-backdrop-filter:saturate(300%)contrast(1.1)blur(24px);box-shadow:0 2px 16px rgba(0,0,0,.3),inset 0 0 0 .5px rgba(255,255,255,.2),inset 0 1px rgba(255,255,255,.18)}[data-theme=dark] .cta:hover{box-shadow:0 2px 20px rgba(0,0,0,.38),inset 0 0 0 .5px rgba(255,255,255,.22),inset 0 1px rgba(255,255,255,.22)}[data-theme=dark] .cta:active{box-shadow:0 1px 8px rgba(0,0,0,.25),inset 0 0 0 .5px rgba(255,255,255,.16),inset 0 1px rgba(255,255,255,.14)}.cta-icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .2s cubic-bezier(.34,1.56,.64,1)}.cta:hover .cta-icon{transform:scale(1.1)}.search-modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;visibility:hidden;opacity:0;pointer-events:none;transition:opacity .2s cubic-bezier(.4,0,.2,1),visibility .2s cubic-bezier(.4,0,.2,1)}.search-modal.open{visibility:visible;opacity:1;pointer-events:auto}.search-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.search-modal-content{position:relative;z-index:1;width:90%;max-width:560px;background:var(--surface);border-radius:16px;padding:16px;border:.5px solid var(--border);box-shadow:0 16px 48px var(--shadow);transform:scale(.97)translateY(4px);transition:transform .2s cubic-bezier(.4,0,.2,1)}.search-modal.open .search-modal-content{transform:scale(1)translateY(0)}.pagefind-ui{--pagefind-ui-scale:0.9;--pagefind-ui-primary:var(--accent);--pagefind-ui-text:var(--text);--pagefind-ui-background:var(--surface);--pagefind-ui-border:var(--border);--pagefind-ui-tag:var(--accent-soft);--pagefind-ui-border-width:1px;--pagefind-ui-border-radius:8px;--pagefind-ui-font:system-ui, -apple-system, sans-serif}.error-page{text-align:center;padding:120px 20px}.error-title{font-size:72px;font-weight:300;color:var(--muted);margin-bottom:12px;position:relative;display:inline-block;cursor:default}.error-title::before,.error-title::after{content:"404";position:absolute;top:0;left:0;width:100%;height:100%;opacity:0}.error-title::before{color:var(--accent)}.error-title::after{color:#ef4444}.error-title:hover::before{opacity:.6;animation:glitch1 .3s steps(2)infinite}.error-title:hover::after{opacity:.4;animation:glitch2 .3s steps(2)infinite}.error-title.glitch-once::before{opacity:.6;animation:glitch1 .3s steps(2)2}.error-title.glitch-once::after{opacity:.4;animation:glitch2 .3s steps(2)2}@keyframes glitch1{0%{transform:translate(0)}25%{transform:translate(-2px,1px)}50%{transform:translate(2px,-1px)}75%{transform:translate(-1px,-1px)}100%{transform:translate(0)}}@keyframes glitch2{0%{transform:translate(0)}25%{transform:translate(1px,-2px)}50%{transform:translate(-1px,2px)}75%{transform:translate(2px,1px)}100%{transform:translate(0)}}.error-desc{font-size:16px;color:var(--muted);margin-bottom:24px}@keyframes pageTitleIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pageDividerIn{from{opacity:0}to{opacity:1}}.page-title{font-size:24px;font-weight:500;letter-spacing:-.3px;margin-bottom:20px;text-align:center}.page-header-row{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;margin-bottom:8px;min-height:36px}.page-header-back{display:inline-flex;align-items:center;gap:5px;font-size:13px;color:var(--muted);text-decoration:none;white-space:nowrap;transition:color .15s ease}.page-header-back:hover{color:var(--accent)}.page-header-back svg{flex-shrink:0}.page-header-title{font-size:24px;font-weight:500;letter-spacing:-.3px;text-align:center}.page-header-count{text-align:right;font-size:12px;color:var(--muted);display:none}@media(min-width:768px){.page-header-count{display:block}}.page-header-sub{text-align:center;font-size:13px;color:var(--muted);margin-bottom:0}.page-header-freshness{display:flex;justify-content:center;margin-top:8px}.page-header-freshness-inline{display:flex;justify-content:flex-end;align-items:center}@media(max-width:768px){.page-header-row{display:flex;flex-direction:column;align-items:center;gap:4px}.page-header-row>span:first-child:empty{display:none}.page-header-freshness-inline{justify-content:center}.page-header-back{align-self:flex-start}}.tag-description{max-width:520px;margin:0 auto 20px;text-align:center;font-size:15px;line-height:1.6}@keyframes staggerIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes scrollBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(4px)}}.scroll-reveal{opacity:0;transform:translateY(6px)}.scroll-reveal.visible{opacity:1;transform:translateY(0);transition:opacity .25s cubic-bezier(.4,0,.2,1),transform .25s cubic-bezier(.4,0,.2,1)}@keyframes spaFadeOut{from{opacity:1}to{opacity:0}}@keyframes skeletonPulse{0%,100%{opacity:.4}50%{opacity:.9}}.spa-skeleton{padding:0}.spa-skeleton-line{height:14px;border-radius:6px;background:var(--subtle);animation:skeletonPulse 1.4s ease-in-out infinite;margin-bottom:12px}.spa-skeleton-line:nth-child(1){width:65%}.spa-skeleton-line:nth-child(2){width:35%;animation-delay:.1s}.spa-skeleton-line:nth-child(3){width:100%;margin-top:24px;animation-delay:.15s}.spa-skeleton-line:nth-child(4){width:100%;animation-delay:.2s}.spa-skeleton-line:nth-child(5){width:90%;animation-delay:.25s}.spa-skeleton-line:nth-child(6){width:100%;animation-delay:.3s}.spa-skeleton-line:nth-child(7){width:75%;animation-delay:.35s}@keyframes spaFadeIn{from{opacity:0;transform:translateY(10px)scale(1.03);filter:blur(8px)}to{opacity:1;transform:translateY(0)scale(1);filter:blur(0)}}main.spa-exiting{opacity:0;transform:translateY(-3px);transition:opacity 80ms ease-out,transform 80ms ease-out;pointer-events:none}main{padding-top:80px;padding-bottom:60px;flex:1}@media(min-width:768px){.container{padding-left:48px;padding-right:48px}}@media(min-width:1024px){.container{max-width:840px}.container-wide{max-width:960px}}@media(min-width:1200px){.article-layout{position:relative}.toc{display:block;position:absolute;left:-220px;top:0;width:180px}.toc-inner{position:sticky;top:100px}}::view-transition-old(root),::view-transition-new(root){animation:none;mix-blend-mode:normal}::view-transition-old(root){z-index:1}::view-transition-new(root){z-index:9999}main.spa-enter{animation:spaFadeIn .3s cubic-bezier(.22,1,.36,1)both}.katex-display{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;padding:4px 0}.katex-display>.katex{max-width:100%}@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}}@media print{.topbar-wrap,.capsule-bar,.reading-progress-bar,.back-to-top,.search-modal,.toc,.toc-mobile,.share-bar,.selection-share,.article-nav,.recently-read,.writing-filters,.code-actions,.code-expand-btn,.diagram-actions,#spa-progress{display:none !important}body{background:#fff;color:#000}.container{max-width:100%}pre{break-inside:avoid;max-height:none !important;overflow:visible !important}img{break-inside:avoid}.article-body a[href^=http]::after{content:" (" attr(href)")";font-size:.8em;color:#666}}