:root,[data-theme=light]{--bg-primary: #ffffff;--bg-hover: #F2F0EE;--text-main: #171717;--text-muted: #707070;--border: #E1DFDD;--accent: rgb(255, 0, 170);--link-hover: #B300B3;--code-bg: #EBE9E7;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "Menlo", "SF Mono", "Fira Code", monospace;--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--ease-in-out-sine: cubic-bezier(.445, .05, .55, .95);--transition-fast: .15s var(--ease-out-expo);--transition-medium: .3s var(--ease-out-expo);--ayo-outer: #27272a;--ayo-fill-top: #1f1f23;--ayo-fill-bottom: #050505;--ayo-text: #ffffff;--ayo-stroke: rgba(255, 255, 255, .25);--ayo-shadow: rgba(0, 0, 0, .3);--ayo-text-shadow: 0 1px 12px rgba(0, 0, 0, .45);--bg-gradient: linear-gradient(180deg, #27272a 0%, #09090b 100%);--fg-gradient: linear-gradient(180deg, #18181b 0%, #000000 100%);--social-email: #EA4335;--social-x: #1DA1F2;--social-linkedin: #0A66C2;--social-github: #181717}[data-theme=dark]{--bg-primary: #101010;--bg-hover: #1A1A1A;--text-main: #EDEDEB;--text-muted: #828280;--border: #2A2A2A;--code-bg: #181818;--link-hover: #FF00FF;--ayo-outer: #e5e5e2;--ayo-fill-top: #ffffff;--ayo-fill-bottom: #f8f8f7;--ayo-text: #1c1c1a;--ayo-stroke: rgba(0, 0, 0, .1);--ayo-shadow: rgba(0, 0, 0, .5);--ayo-text-shadow: none;--social-email: #FF6659;--social-x: #4DB5F4;--social-linkedin: #2D88FF;--social-github: #F0F6FC}::view-transition-group(root){animation:none}::view-transition-old(root),::view-transition-new(root){animation:none;mix-blend-mode:normal;height:100%;width:100%;opacity:1!important}.theme-transition::view-transition-new(root){animation:clip-reveal .6s var(--ease-out-expo) forwards;z-index:1}.theme-transition::view-transition-old(root){animation:none;z-index:0}.theme-to-dark::view-transition-old(root){animation:clip-hide .3s var(--ease-out-expo) forwards;z-index:1}.theme-to-dark::view-transition-new(root){animation:none;z-index:0}html.theme-transition,html.theme-transition *,html.theme-transition body{transition:none!important}@keyframes clip-reveal{0%{clip-path:circle(0px at var(--click-x) var(--click-y))}to{clip-path:circle(125vmax at var(--click-x) var(--click-y))}}@keyframes clip-hide{0%{clip-path:circle(125vmax at var(--click-x) var(--click-y))}to{clip-path:circle(0px at var(--click-x) var(--click-y))}}*{box-sizing:border-box;margin:0;padding:0}html{height:100%;scroll-behavior:smooth}body{background-color:var(--bg-primary);color:var(--text-main);font-family:var(--font-sans);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .2s ease,color .2s ease;min-height:100vh;min-height:100dvh;overflow-x:hidden}::selection{background:var(--text-main);color:var(--bg-primary)}h1,h2,h3,h4,p{font-weight:450;letter-spacing:-.01em}.mono{font-size:13px}.muted{color:var(--text-muted)}a{color:inherit;text-decoration:none;transition:color var(--transition-fast)}.library-wrapper{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh}.page-frame{width:100%;max-width:900px;margin:0 auto;padding:4rem 1.5rem 0}.route-transition-page{grid-area:1 / 1;min-width:0;will-change:opacity}@media (max-width: 768px){.library-wrapper{padding-bottom:2rem}}.library-header{display:flex;flex-direction:column;gap:2.5rem;margin-bottom:5rem}.header-bio{max-width:600px}.header-avatar-group{display:flex;flex-direction:column;align-items:flex-start;gap:14px;margin-bottom:1.5rem}.header-avatar{width:72px;height:72px;object-fit:contain;cursor:pointer}.header-name{font-size:14px;font-weight:700}.header-description{font-size:14px;line-height:1.6;color:var(--text-main)}.header-description a{border-bottom:1px solid var(--border);padding-bottom:1px}@media (hover: hover){.header-description a:hover{border-bottom-color:var(--text-main)}}.email-btn{background:none;border:none;padding:0;font:inherit;cursor:pointer;display:inline-block;border-bottom:1px solid var(--text-muted)}.header-cat-inline{display:inline-flex;align-items:center;gap:3px;vertical-align:middle;margin-left:.5rem}.brand-social{color:var(--text-muted);transition:color var(--transition-fast);text-decoration:none;border-bottom:1px solid transparent;padding-bottom:1px}@media (hover: hover){.brand-social:hover{color:var(--text-main)!important;border-bottom-color:var(--text-main)}}@media (min-width: 768px){.library-header{flex-direction:row;justify-content:space-between;align-items:flex-start}}.header-actions{display:flex;gap:.75rem}.header-cta-btn{background:none;border:none;color:var(--text-muted);font-family:var(--font-sans);font-size:13px;padding:0 0 1px;cursor:pointer;transition:color var(--transition-fast);white-space:nowrap;border-bottom:1px solid transparent;display:flex;align-items:center}@media (hover: hover){.header-cta-btn:hover{color:var(--text-main);border-bottom-color:var(--text-main)}}.header-cta-btn.is-active{color:var(--text-main);border-bottom-color:var(--text-main)}.proj-table{width:100%}.proj-table-header{font-size:12px;font-weight:500;color:var(--text-muted);letter-spacing:.02em;padding-bottom:.6rem;border-bottom:1px solid var(--border);-webkit-user-select:none;user-select:none}.proj-table-item{position:relative}.proj-table-item.full-divider{border-bottom:1px solid color-mix(in srgb,var(--border) 76%,transparent)}.proj-table-item.partial-divider:after{content:"";position:absolute;bottom:0;left:64px;right:0;height:1px;background-color:color-mix(in srgb,var(--border) 68%,transparent)}.proj-table-item:last-child{border-bottom:none}.proj-table-item:last-child:after{display:none}.proj-table-row{display:flex;align-items:baseline;padding:.65rem 0;color:inherit;transition:opacity .25s var(--ease-out-expo),color var(--transition-fast)}.table-has-hover .proj-table-row{opacity:.25}.table-has-hover .proj-table-row:hover{opacity:1!important}.proj-table-year{width:64px;flex-shrink:0;font-size:13px;color:var(--text-muted)}.proj-table-name{flex-grow:1;font-size:14px;color:var(--text-main)}.proj-table-name-inner{display:flex;align-items:flex-start;gap:16px}.proj-table-badges{flex-shrink:0;display:flex;gap:6px;margin-top:1px}.proj-table-date{flex-shrink:0;min-width:3.5rem;margin-left:1rem;text-align:right;font-size:13px;color:var(--text-muted);font-variant-numeric:tabular-nums}.wip-badge,.new-badge{display:inline-flex;align-items:center;font-family:var(--font-mono);font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.05em;padding:2px 6px;border-radius:4px;background:var(--bg-hover);color:var(--text-muted);border:1px solid var(--border);transition:all .3s var(--ease-out-expo);position:relative;overflow:hidden;flex-shrink:0}.new-badge{font-weight:600;background:color-mix(in srgb,var(--accent) 8%,transparent);color:var(--accent);border-color:color-mix(in srgb,var(--accent) 20%,transparent)}.wip-badge.is-shimmering{transform:scale(1.15);color:var(--text-main);border-color:var(--text-muted)}@keyframes wip-shimmer{0%{left:-100%}to{left:100%}}.wip-badge.is-shimmering:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:wip-shimmer .6s forwards}.article-doc-footer-link{color:var(--text-main);transition:color var(--transition-fast);font-size:14px;font-weight:500}.article-doc-footer-link:hover{color:var(--link-hover)}.cat-zzz-inline,.cat-bubbles-inline{display:inline-flex;align-items:flex-end;gap:2px;margin-bottom:2px}.zzz-z,.bubble{font-family:var(--font-mono);color:var(--text-muted);opacity:0}.zzz-z{animation:zzzFloat 3s ease-in-out infinite}.bubble{animation:bubbleFloat 3s ease-in-out infinite}.zzz-z.z1{font-size:9px;animation-delay:0s}.zzz-z.z2{font-size:11px;animation-delay:.7s}.zzz-z.z3{font-size:13px;animation-delay:1.4s}.bubble.b1{font-size:7px;animation-delay:0s}.bubble.b2{font-size:9px;animation-delay:.7s}.bubble.b3{font-size:11px;animation-delay:1.4s}@keyframes zzzFloat{0%{opacity:0;transform:translateY(2px)}30%{opacity:.65}70%{opacity:.4}to{opacity:0;transform:translateY(-10px)}}@keyframes bubbleFloat{0%{opacity:0;transform:translateY(2px)}30%{opacity:.45}70%{opacity:.3}to{opacity:0;transform:translateY(-12px)}}.ayo-widget-button-wrap{position:relative;display:inline-flex;min-width:140px;height:40px;text-decoration:none!important;margin:1.5rem 0;cursor:pointer;transition:transform var(--transition-medium)}.ayo-outer-border{position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:14px;background:var(--ayo-outer);z-index:-2;box-shadow:0 4px 10px var(--ayo-shadow);transition:all var(--transition-medium)}.ayo-widget-button-wrap:hover{transform:translateY(-1px) scale(1.02)}.ayo-widget-button-wrap:hover .ayo-outer-border{filter:brightness(1.2);box-shadow:0 8px 20px var(--ayo-shadow)}.ayo-inner-container{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;border-radius:13px;overflow:hidden;z-index:0}.ayo-inner-stroke{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:13px;padding:1px;background:linear-gradient(180deg,var(--ayo-stroke) 0%,rgba(255,255,255,0) 100%);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;z-index:2;transition:opacity var(--transition-fast)}.ayo-fill{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,var(--ayo-fill-top) 0%,var(--ayo-fill-bottom) 100%);z-index:-1;transition:filter var(--transition-medium)}.ayo-widget-button-wrap:hover .ayo-fill{filter:brightness(1.4) saturate(1.1)}.ayo-content{display:flex;align-items:center;gap:8px;padding:0 16px;color:var(--ayo-text);text-shadow:var(--ayo-text-shadow)}.ayo-text{font-size:14px;font-weight:700;letter-spacing:-.01em}.ayo-icon{width:18px;height:18px}.blog-head{margin-bottom:3rem}.blog-controls{display:flex;flex-direction:column;gap:1.5rem;margin-top:1.5rem}.search-wrapper{position:relative;max-width:400px}.blog-search-input{width:100%;background:var(--bg-hover);border:1px solid transparent;padding:.75rem 1rem;border-radius:8px;color:var(--text-main);font-family:var(--font-sans);font-size:14px;transition:all var(--transition-medium)}.blog-search-input:focus{border-color:var(--border);background:var(--bg-primary);box-shadow:0 4px 20px #0000000d}.search-clear{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer}.blog-tags-filter{display:flex;flex-wrap:wrap;gap:.5rem}.filter-tag-btn{background:var(--bg-hover);border:1px solid var(--border);padding:4px 8px;border-radius:4px;font-family:var(--font-mono);font-size:10px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.filter-tag-btn.active{background:var(--text-main);color:var(--bg-primary);border-color:var(--text-main)}.thought-date-group{margin-bottom:4rem}.thought-date-header,.thought-container{margin-bottom:1.5rem}.thought-summary-inner{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;transition:opacity var(--transition-medium)}.thought-title{font-size:14px;position:relative}.thought-title.has-glow{text-shadow:0 0 8px rgba(0,0,0,.05)}[data-theme=dark] .thought-title.has-glow{text-shadow:0 0 4px rgba(237,237,235,.3)}.thought-meta{display:flex;gap:2.5rem;align-items:center}.thought-tags-group{display:flex;gap:.4rem}.thought-tag{font-size:10px;color:var(--text-muted);border:1px solid var(--border);padding:1px 4px;border-radius:3px}.thought-attachment-link{font-size:12px;color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast)}.thought-attachment-link:hover{color:var(--text-main)}.thought-expanded-inner{padding:.5rem 0 2rem}.thought-expanded-image{display:block;max-width:360px;width:100%;margin-top:1.5rem;border-radius:8px}.hover-preview-container{position:fixed;top:0;left:0;z-index:1000;width:250px;pointer-events:none;visibility:hidden}.clean-image-box{width:100%;position:relative;overflow:hidden;border-radius:6px;box-shadow:0 15px 35px #00000026}.clean-image-box img{width:100%;height:auto;display:block}.article-layout{display:grid;grid-template-columns:180px 1fr;gap:0 5rem;padding-bottom:8rem;max-width:860px}.article-sidebar{height:100%}.article-sidebar-inner{position:sticky;top:6rem;padding-bottom:4rem;max-height:calc(100vh - 4rem);overflow-y:auto;scrollbar-width:none}.article-sidebar-inner::-webkit-scrollbar{display:none}.mobile-only{display:none!important}.sidebar-back-link{display:block;font-size:12px;color:var(--text-muted);margin-bottom:2rem;transition:color var(--transition-fast);padding-top:4px}.sidebar-back-link:hover{color:var(--text-main)}.sidebar-back-icon{display:inline-block;font-size:1.2em;transform:translateY(1px);margin-right:4px}.sidebar-title{font-size:13px;font-weight:500;color:var(--text-muted);margin-bottom:1rem;line-height:1.4}.sidebar-toc ul{list-style:none;display:flex;flex-direction:column;gap:.1rem}.sidebar-toc-link{display:block;font-size:12px;color:var(--text-muted);padding:.3rem 0;line-height:1.4;transition:color var(--transition-fast)}.sidebar-toc-link:hover{color:var(--text-main)}.sidebar-toc-link.is-active{color:var(--text-main);font-weight:500}.article-main{min-width:0;position:relative}@media (max-width: 720px){.article-main{width:100%}}.article-doc-header{margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.article-doc-title{font-size:18px;font-weight:500;line-height:1.25;color:var(--text-main);margin-bottom:.15rem}.article-doc-date{font-size:14px;color:var(--text-muted);margin-bottom:.5rem}.article-doc-meta{font-size:13px;color:var(--text-muted);margin-top:1rem}.article-meta-tags{display:block}.article-meta-sep{color:var(--border)}.article-doc-body p{margin-bottom:1.5rem;line-height:1.7;color:var(--text-main)}.article-doc-body a:not(.article-doc-footer-link){text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px;text-decoration-color:var(--border)}@media (hover: hover){.article-doc-body a:not(.article-doc-footer-link):hover{text-decoration-color:var(--text-main)}}.article-doc-body strong a{text-decoration:none!important;color:var(--text-main);border-bottom:1px solid var(--text-main);padding-bottom:1px;display:inline-flex;align-items:center;gap:.25rem}.article-doc-body strong a:after{content:"↗";font-size:.9em;transition:transform var(--transition-fast)}@media (hover: hover){.article-doc-body strong a:hover:after{transform:translate(2px,-2px)}}.article-doc-body h2{font-size:15px;font-weight:600;letter-spacing:-.01em;margin:3.5rem 0 1.5rem;color:var(--text-main);scroll-margin-top:2rem;display:flex;align-items:center;gap:1rem}.article-doc-body h2:after{content:"";flex:1;height:1px;background:var(--border);opacity:.4}.article-doc-body h3{font-size:14px;font-weight:500;margin:1.5rem 0 .75rem}.article-doc-body strong{font-weight:600}.article-doc-body em{font-style:italic}.article-doc-body blockquote{border-left:1px solid var(--border);padding-left:1rem;margin:2rem 0;font-style:normal;color:var(--text-muted)}.article-doc-body ul,.article-doc-body ol{padding-left:1.5rem;margin-bottom:1.5rem}.article-doc-body li{margin-bottom:.4rem;line-height:1.7}.inline-code{font-family:var(--font-mono, monospace);font-size:.88em;background:var(--code-bg);border:1px solid var(--border);border-radius:4px;padding:.1em .4em;color:var(--text-main)}.article-doc-footer{margin-top:5rem;border-top:1px solid var(--border);padding-top:2.5rem;padding-bottom:3rem}.article-doc-footer-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.75rem}.mdx-media-image{width:100%;height:auto;display:block;border-radius:20px;margin:2rem 0;border:1px solid var(--border)}.mdx-media-video-container{position:relative;margin:2rem 0;border-radius:20px;overflow:hidden;border:1px solid var(--border);background:var(--bg-hover)}.mdx-media-video{width:100%;display:block}.mdx-video-controls{position:absolute;bottom:0;left:0;right:0;padding:3rem 1.25rem 1.25rem;background:linear-gradient(transparent,#0006);display:flex;flex-direction:column;gap:.75rem;z-index:2;opacity:0;transform:translateY(8px);transition:all var(--transition-medium)}.mdx-media-video-container:hover .mdx-video-controls{opacity:1;transform:translateY(0)}.mdx-video-seekbar-container{position:relative;width:100%;height:3px;background:#fff3;border-radius:4px;cursor:pointer;transition:height var(--transition-fast)}.mdx-video-seekbar-container:hover{height:6px}.mdx-video-seekbar{position:absolute;top:-10px;bottom:-10px;left:0;width:100%;opacity:0;z-index:2;cursor:pointer;margin:0}.mdx-video-seekbar-fill{height:100%;background:#fff;border-radius:4px;z-index:1;box-shadow:0 0 8px #fff3}.mdx-video-actions{display:flex;justify-content:flex-end;gap:.5rem}.mdx-video-control-btn{width:32px;height:32px;border-radius:50%;background:#0006;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.mdx-video-control-btn:hover{background:#0009;transform:scale(1.1)}.mdx-video-control-btn:active{transform:scale(.95)}.code-showcase{position:relative;margin:1.5rem 0;border:1px solid var(--border);background:var(--code-bg);border-radius:8px;overflow:hidden}[data-theme=dark] .code-showcase{background:var(--code-bg);border-color:var(--border)}.code-showcase-pre{padding:1.5rem 1.25rem 1.5rem 1.5rem;overflow-x:auto;font-family:var(--font-mono);font-size:13px;line-height:1.6;-webkit-overflow-scrolling:touch}.code-line{display:flex;align-items:baseline;padding-right:1.5rem}.code-line-num{flex-shrink:0;width:3rem;padding-right:1rem;text-align:right;color:#a0a09e;font-size:11px;-webkit-user-select:none;user-select:none;font-variant-numeric:tabular-nums;opacity:.6}.code-line-content{flex:1;min-width:0;white-space:pre}.code-showcase-copy{position:absolute;top:.6rem;right:.6rem;border:1px solid transparent;background:transparent;color:var(--text-muted);width:2.2rem;height:2.2rem;padding:0;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);z-index:10}.code-showcase-copy:hover{background:#0000000a;color:var(--text-main);border-color:#00000014}[data-theme=dark] .code-showcase-copy:hover{background:#ffffff0f;border-color:#ffffff1a}.code-showcase-copy:active{transform:scale(.94)}@media (max-width: 720px){.article-layout{display:block;padding-bottom:4rem}.article-sidebar{display:none}.mobile-only{display:block!important}}
