:root{--bg:#fafaf9;--text:#1a1a1a;--muted:#6b6b6b;--subtle:#e0dfdd;--surface:#ffffff;--border:#e8e7e5;--code-bg:#f5f4f2;--accent:#10b981;--accent-text:#059669;--accent-soft:rgba(16, 185, 129, 0.08);--accent-glow:rgba(16, 185, 129, 0.15);--shadow:rgba(0, 0, 0, 0.06);--shadow-accent:rgba(16, 185, 129, 0.08);--glass:rgba(250, 250, 249, 0.96)}[data-theme=dark]{--bg:#111110;--text:#edebe8;--muted:#777777;--subtle:#2a2a28;--surface:#1a1a19;--border:rgba(255, 255, 255, 0.08);--code-bg:#1e1e1c;--accent-text:#10b981;--shadow:rgba(0, 0, 0, 0.3);--shadow-accent:rgba(16, 185, 129, 0.15);--glass:rgba(17, 17, 16, 0.96)}*,*::before,*::after{box-sizing:border-box}*{margin:0;padding:0}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(16,185,129,.35)}70%{box-shadow:0 0 0 6px rgba(16,185,129,0)}100%{box-shadow:0 0 0 6px rgba(16,185,129,0)}}body{font-family: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%}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: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;word-wrap:normal;overflow-wrap:normal}.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: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:720px;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}.topbar-wrap{position:fixed;top:12px;left:20px;right:20px;z-index:40;background:rgba(250,250,249,.55);-webkit-backdrop-filter:saturate(180%)blur(16px);backdrop-filter:saturate(180%)blur(16px);border:.5px solid var(--border);border-radius:100px;box-shadow:0 4px 24px var(--shadow)}[data-theme=dark] .topbar-wrap{background:rgba(17,17,16,.65)}.topbar{position:relative;padding:5px;display:flex;align-items:center;justify-content:space-between}.topbar-logo{height:38px;padding:0 10px 0 11px;border-radius:100px;display:flex;align-items:center;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .2s cubic-bezier(.4,0,.2,1),transform .15s cubic-bezier(.4,0,.2,1)}.topbar-logo:hover{background:var(--accent-soft);transform:translateY(-1px)}.topbar-logo:active{transform:scale(.96)translateY(0);box-shadow:0 0 0 var(--shadow);transition-duration:.08s}.topbar-logo-svg{height:15px;width:auto;display:block;color:var(--text);transform:translateY(1.5px)}.topbar-actions{display:flex;gap:4px;align-items:center}.topbar-btn{width:38px;height:38px;border-radius:100px;background:0 0;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;transition:background .25s cubic-bezier(.4,0,.2,1),transform .25s cubic-bezier(.4,0,.2,1)}.topbar-btn:hover{background:var(--accent-soft)}.topbar-btn:active{transform:scale(.92)}.topbar-btn svg{width:17px;height:17px;fill:none;stroke:var(--muted);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;transition:stroke .25s cubic-bezier(.4,0,.2,1)}.topbar-btn:hover svg{stroke:var(--accent)}.theme-icon-light,.theme-icon-dark{display:flex;align-items:center;justify-content:center;line-height:0}.theme-icon-dark{display:none}[data-theme=dark] .theme-icon-light{display:none}[data-theme=dark] .theme-icon-dark{display:block}.topbar-wrap::before,.capsule-bar::before{content:"";position:absolute;inset:-.5px;border-radius:inherit;box-shadow:0 0 3px rgba(16,185,129,7%),0 0 1px rgba(16,185,129,.12);animation:navBreathe 4s ease-in-out infinite;pointer-events:none}.desktop-nav{display:none;gap:20px;align-items:center}.desktop-nav-link{font-size:15px;color:var(--muted);text-decoration:none;position:relative;padding-bottom:4px;transition:color .2s cubic-bezier(.4,0,.2,1)}.desktop-nav-link:hover{color:var(--text)}.desktop-nav-link::after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--accent);transition:width .3s cubic-bezier(.4,0,.2,1)}.desktop-nav-link:hover::after{width:100%}.desktop-nav-link.active{color:var(--text)}.desktop-nav-link.active::after{width:100%}.capsule-bar{position:fixed;bottom:16px;left:20px;right:20px;background:rgba(250,250,249,.55);-webkit-backdrop-filter:saturate(180%)blur(16px);backdrop-filter:saturate(180%)blur(16px);border:.5px solid var(--border);border-radius:100px;padding:5px;display:flex;align-items:center;z-index:10;box-shadow:0 4px 24px var(--shadow);transition:box-shadow .2s cubic-bezier(.4,0,.2,1),border-color .2s cubic-bezier(.4,0,.2,1)}[data-theme=dark] .capsule-bar{background:rgba(17,17,16,.65)}.capsule-bar.at-edge{box-shadow:0 -2px 12px var(--shadow),0 4px 24px var(--shadow);border-color:var(--subtle)}.cap{display:flex;align-items:center;justify-content:center;flex:1;height:38px;min-width:44px;padding:0 12px;border-radius:100px;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;overflow:hidden;transition:background .2s cubic-bezier(.4,0,.2,1),transform .1s cubic-bezier(.4,0,.2,1)}.cap svg{width:19px;height:19px;flex-shrink:0;fill:none;stroke:var(--muted);stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;transition:stroke .25s cubic-bezier(.4,0,.2,1)}.cap:hover svg{stroke:var(--text)}.cap:not(.on):active{transform:scale(.94)}.cap.on:active{transform:scale(.95)}.cap-label{font-size:14px;font-weight:500;white-space:nowrap;letter-spacing:-.1px;color:#fff;opacity:0;max-width:0;overflow:hidden;margin-left:0}.cap.on{flex:0 0 105px;background:var(--accent);padding:0 16px}.cap.on svg{stroke:#fff}.cap.on .cap-label{opacity:1;max-width:70px;margin-left:6px}.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:0%;background:var(--accent);border-radius:0 1px 1px 0;transition:width .2s ease}.home{display:flex;align-items:center;justify-content:center;min-height:calc(100dvh - 180px);margin-top:-40px;position:relative;overflow:hidden}@media(min-width:768px){.home{min-height:calc(100dvh - 112px);margin-top:-48px}}.hero{text-align:center;max-width:520px;margin:0 auto;position:relative}.hero-tagline{font-size:14px;color:var(--muted);display:inline-flex;align-items:center;gap:7px;margin-bottom:12px;font-weight:300;padding:4px 14px;border-radius:100px;border:.5px solid var(--border);background:0 0;animation:heroFadeUp .3s ease both .05s;transition:border-color .2s ease,background .2s ease,padding .2s ease;cursor:default;user-select:none}.hero-tagline:hover{border-color:rgba(16,185,129,.3);background:var(--accent-soft);padding:4px 18px}.hero-name{font-size:31px;font-weight:600;letter-spacing:-.5px;line-height:1.3;margin-bottom:12px;animation:heroFadeUp .3s ease both .1s;background:linear-gradient(90deg,var(--text) 0%,var(--accent) 40%,var(--text) 60%,var(--text) 100%);background-size:200% 100%;background-position:100% 0;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;transition:background-position .8s ease,letter-spacing .3s cubic-bezier(.4,0,.2,1)}.hero-name:hover{background-position:-100% 0;letter-spacing:.5px}.hero-subtitle{font-size:clamp(12px,3.6vw,20px);color:var(--muted);font-weight:400;margin-bottom:20px;white-space:nowrap;padding:0 8px;animation:heroFadeUp .3s ease both .15s;cursor:default;user-select:none}.hero-divider{width:40px;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);margin:0 auto 20px;animation:heroDividerGrow .3s ease both .2s,heroDividerPulse 3s ease-in-out infinite .6s;transition:width .3s ease,background .3s ease;position:relative}.hero-divider::after{content:"";position:absolute;inset:-2px 0;background:var(--accent);filter:blur(6px);opacity:0;transition:opacity .25s ease;pointer-events:none}.hero:hover .hero-divider::after{opacity:.4}.hero:hover .hero-divider{width:80px;background:linear-gradient(90deg,transparent,var(--accent),transparent)}.hero-headline{font-size:19px;font-weight:300;line-height:1.6;letter-spacing:-.2px;margin-bottom:24px;color:var(--muted);animation:heroFadeUp .3s ease both .25s;cursor:default;user-select:none}.hero-highlight{background:linear-gradient(90deg,rgba(16,185,129,8%) 0%,rgba(16,185,129,.18) 50%,rgba(16,185,129,8%) 100%);background-size:200% 100%;background-position:0 0;padding:0 4px;border-radius:3px;position:relative;cursor:default;transition:background-position .35s ease,color .2s ease}.hero-highlight:hover{background-position:-100% 0;color:var(--accent-text);text-shadow:0 0 8px rgba(16,185,129,.2)}.hero-tip{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translateX(-50%)translateY(4px);opacity:0;pointer-events:none;background:var(--surface);border:.5px solid var(--border);border-radius:10px;padding:8px 12px;box-shadow:0 4px 20px var(--shadow);white-space:nowrap;z-index:10;transition:opacity .15s ease,transform .15s ease;display:flex;flex-direction:column;gap:2px}.hero-tip::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--surface)}.hero-highlight:hover .hero-tip{opacity:1;transform:translateX(-50%)translateY(0);pointer-events:auto}.hero-highlight.tip-visible .hero-tip{opacity:1;transform:translateX(-50%)translateY(0);pointer-events:auto}.hero-tip-label{font-size:10px;color:var(--accent-text);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.hero-tip-text{font-size:11px;color:var(--muted);font-weight:400;line-height:1.4}.social-links{display:flex;flex-wrap:wrap;gap:6px 10px;font-size:15px;align-items:center;justify-content:center;animation:heroFadeUp .3s ease both .3s}.social-link{color:var(--muted);text-decoration:none;position:relative;white-space:nowrap;transition:color .2s cubic-bezier(.4,0,.2,1);display:inline-flex;align-items:center}.hero-role{display:inline-block;transition:opacity .2s ease,transform .2s ease}.hero-role.swapping{opacity:0;transform:translateY(4px)}.social-icon{display:none}@media(min-width:768px){.social-icon{width:13px;height:13px;display:inline-flex;align-items:center;opacity:0;flex-shrink:0;transform:scale(.4)translateX(-4px);transition:opacity .15s ease,transform .15s ease;margin-right:4px}.social-link:hover .social-icon{opacity:1;transform:scale(1)translateX(0)}}.hero-glow,.hero-cursor-glow{display:none}@keyframes heroFadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes heroDividerGrow{from{width:0;opacity:0}to{width:40px;opacity:1}}@keyframes heroDividerPulse{0%,100%{opacity:.4;transform:scaleX(.85)}50%{opacity:1;transform:scaleX(1)}}@keyframes heroShimmer{0%{background-position:100% 0}100%{background-position:-100% 0}}@media(max-width:480px){.hero-name{font-size:27px}.hero-headline{font-size:17px}.social-links{gap:4px 8px;font-size:14px}.social-sep{width:3px;height:3px;opacity:.3}.social-link--internal,.social-sep--internal{display:none}.hero-peek{width:34px;height:34px}}.hero-name-wrap{display:inline-flex;align-items:center;justify-content:center;gap:0}.hero-peek{width:40px;height:40px;border-radius:50%;object-fit:cover;object-position:center 15%;border:1.5px solid rgba(16,185,129,.4);opacity:0;transform:translateX(-12px)scale(.7);transition:opacity .35s cubic-bezier(.4,0,.2,1),transform .4s cubic-bezier(.34,1.56,.64,1),margin .4s cubic-bezier(.34,1.56,.64,1);margin-right:-8px;flex-shrink:0;pointer-events:none;box-shadow:0 4px 16px rgba(0,0,0,.1)}.hero-name:hover .hero-peek,.hero-name.peek-active .hero-peek{opacity:1;transform:translateX(0)scale(1);margin-right:10px}.social-link::after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--accent);transition:width .25s cubic-bezier(.4,0,.2,1)}.social-link:hover{color:var(--accent)}.social-link:hover::after{width:100%}.social-sep{width:4px;height:4px;border-radius:50%;background:var(--muted);opacity:.4;flex-shrink:0}.now-freshness{display:inline-flex;align-items:center;gap:7px;font-size:13px;color:var(--muted)}.now-dot-fresh{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0;animation:nowPulse 2.5s ease-in-out infinite}.now-dot-stale{width:6px;height:6px;border-radius:50%;background:#f59e0b;flex-shrink:0}@keyframes nowPulse{0%,100%{opacity:.5;transform:scale(.9)}50%{opacity:1;transform:scale(1.2)}}.breathing-dot{width:5px;height:5px;border-radius:50%;background:var(--accent);animation:breathe 3s ease-in-out infinite .6s;flex-shrink:0}@keyframes breathe{0%,100%{opacity:.5;transform:scale(.9)}50%{opacity:1;transform:scale(1.15)}}@keyframes navBreathe{0%,100%{opacity:.5}50%{opacity:.85}}.article-row{display:block;text-decoration:none;color:inherit;padding:14px 0;border-bottom:.5px solid var(--border);transition:padding .2s cubic-bezier(.4,0,.2,1),border-color .2s cubic-bezier(.4,0,.2,1)}.article-row:hover{padding-left:14px;border-color:var(--accent);background:linear-gradient(90deg,rgba(16,185,129,3%),transparent 60%)}.article-list>.article-row:last-child,.writing-group:last-child>.article-row:last-child{border-bottom:none}.article-row-top{display:flex;justify-content:space-between;align-items:baseline}.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:2;-webkit-box-orient:vertical;overflow:hidden}.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}.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}.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:all .25s 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:all .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;animation:pageTitleIn .25s cubic-bezier(.4,0,.2,1)both}.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}}.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)}.giscus-wrapper{margin-top:32px}.giscus-wrapper .divider{margin-bottom:24px}.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;font-family:inherit;transition:all .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:all .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(16,185,129,.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}.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}.article-body h3{margin-top:24px;margin-bottom:8px}.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(16,185,129,.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{clip-path:inset(0 100% 0 0);transition:clip-path .5s cubic-bezier(.4,0,.2,1)}.article-body img.scroll-revealed{clip-path:inset(0 0 0 0)}.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:max-height .25s ease,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:gap .3s cubic-bezier(.4,0,.2,1)}.view-all-link:hover{gap:10px}.view-all-link .arrow-right{color:var(--accent);transition:transform .3s cubic-bezier(.4,0,.2,1)}.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:all .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:hidden;cursor:zoom-in}.diagram-container .mermaid,.diagram-container .plantuml-diagram{display:flex;justify-content:center}.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:1e3px;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;transition:all .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:#10b981;background:#ecfdf5}.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:#1a2e23}[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}pre .copy-btn{position:absolute;top:8px;right:8px;width:30px;height:30px;padding:0;border-radius:8px;border:.5px solid var(--border);color:var(--muted);cursor:pointer;background:var(--surface);display:flex;align-items:center;justify-content:center;transition:background .2s cubic-bezier(.4,0,.2,1),border-color .2s cubic-bezier(.4,0,.2,1),color .2s cubic-bezier(.4,0,.2,1)}pre .copy-btn:hover{border-color:var(--accent);color:var(--accent)}pre .copy-btn.copied{border-color:var(--accent);background:var(--accent);color:#fff}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)}.back-to-top{position:fixed;bottom:72px;right:24px;opacity:0;transform:translateY(10px);pointer-events:none;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:9}.back-to-top.visible{opacity:1;transform:translateY(0);pointer-events:auto}.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:all .25s cubic-bezier(.4,0,.2,1)}.back-to-top button:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}.back-to-top button:active{transform:scale(.96)translateY(0);box-shadow:none;transition-duration:.08s}.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)::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):hover::after{opacity:1;transform:translateY(0)}.external-link .ext-icon{font-size:12px;opacity:0;transform:translateY(2px);transition:all .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%}.project-github-wrap{margin-top:8px}.project-github-icon{display:inline-flex;align-items:center;margin-right:5px}.newsletter-form-wrap{margin-top:20px}.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;animation:pageTitleIn .25s cubic-bezier(.4,0,.2,1)both}.page-title+.text-muted,.page-title+.article-meta{animation:pageTitleIn .25s cubic-bezier(.4,0,.2,1).08s both}.article-header+.divider{animation:pageDividerIn .2s ease .16s both}.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;animation:pageTitleIn .25s cubic-bezier(.4,0,.2,1)both}.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;animation:pageTitleIn .25s cubic-bezier(.4,0,.2,1)both}.page-header-count{text-align:right;font-size:12px;color:var(--muted);animation:pageTitleIn .25s cubic-bezier(.4,0,.2,1)both;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;animation:pageTitleIn .25s cubic-bezier(.4,0,.2,1).08s both}.page-header-freshness{display:flex;justify-content:center;margin-top:8px;animation:pageTitleIn .25s cubic-bezier(.4,0,.2,1).16s both}.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}.exp-section{margin-top:40px}.exp-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1.2px;color:var(--accent-text);margin-bottom:14px}.exp-links{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-start}.exp-ext-link{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:14px;color:var(--muted);text-decoration:none;padding:8px 16px;border-radius:100px;border:.5px solid var(--border);background:0 0;flex:1;transition:all .2s cubic-bezier(.4,0,.2,1)}.exp-ext-link:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}@media(max-width:640px){.exp-section{margin-top:32px}.exp-links{gap:8px}.exp-ext-link{font-size:13px;padding:7px 14px}}@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)}main{padding-top:80px;padding-bottom:100px}@media(min-width:768px){.capsule-bar{display:none}.desktop-nav{display:flex}.topbar-wrap{top:0;left:0;right:0;background:rgba(250,250,249,.4);-webkit-backdrop-filter:saturate(180%)blur(16px);backdrop-filter:saturate(180%)blur(16px);border:none;border-bottom:.5px solid transparent;border-radius:0;box-shadow:none;transition:border-color .2s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1)}[data-theme=dark] .topbar-wrap{background:rgba(17,17,16,.4)}.topbar-wrap.scrolled{border-bottom-color:var(--border);box-shadow:0 1px 8px var(--shadow)}.topbar-wrap::before{display:none}.topbar{max-width:720px;margin:0 auto;padding:8px 20px}main{padding-top:64px;padding-bottom:40px}}@media(min-width:1024px){.container{max-width:720px}.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}}@media(min-width:640px){.hero-tagline{font-size:16px;padding:6px 18px;gap:8px}.hero-name{font-size:38px}.hero-subtitle{font-size:17px}.hero-headline{font-size:22px}.social-links{gap:8px 14px;font-size:16px}}::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}.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{display:none!important}body{background:#fff;color:#000}.container{max-width:100%}}