:root{--sileo-spring-easing: linear( 0, .002 .6%, .007 1.2%, .015 1.8%, .026 2.4%, .041 3.1%, .06 3.8%, .108 5.3%, .157 6.6%, .214 8%, .467 13.7%, .577 16.3%, .631 17.7%, .682 19.1%, .73 20.5%, .771 21.8%, .808 23.1%, .844 24.5%, .874 25.8%, .903 27.2%, .928 28.6%, .952 30.1%, .972 31.6%, .988 33.1%, 1.01 35.7%, 1.025 38.5%, 1.034 41.6%, 1.038 45%, 1.035 50.1%, 1.012 64.2%, 1.003 73%, .999 83.7%, 1 );--sileo-duration: .6s;--sileo-height: 40px;--sileo-width: 350px;--sileo-state-success: oklch(.723 .219 142.136);--sileo-state-loading: oklch(.556 0 0);--sileo-state-error: oklch(.637 .237 25.331);--sileo-state-warning: oklch(.795 .184 86.047);--sileo-state-info: oklch(.685 .169 237.323);--sileo-state-action: oklch(.623 .214 259.815)}[data-sileo-toast]{position:relative;cursor:pointer;pointer-events:auto;touch-action:none;border:0;background:transparent;padding:0;width:var(--sileo-width);height:var(--_h, var(--sileo-height));opacity:0;transform:translateZ(0) scale(.95);transform-origin:center;contain:layout style;overflow:visible}[data-sileo-toast][data-state=loading]{cursor:default}[data-sileo-toast][data-ready=true]{opacity:1;transform:translateZ(0) scale(1);transition:transform calc(var(--sileo-duration) * .66) var(--sileo-spring-easing),opacity calc(var(--sileo-duration) * .66) var(--sileo-spring-easing),margin-bottom calc(var(--sileo-duration) * .66) var(--sileo-spring-easing),margin-top calc(var(--sileo-duration) * .66) var(--sileo-spring-easing),height var(--sileo-duration) var(--sileo-spring-easing)}[data-sileo-viewport][data-position^=top] [data-sileo-toast]:not([data-ready=true]){transform:translateY(-6px) scale(.95)}[data-sileo-viewport][data-position^=bottom] [data-sileo-toast]:not([data-ready=true]){transform:translateY(6px) scale(.95)}[data-sileo-toast][data-ready=true][data-exiting=true]{opacity:0;pointer-events:none}[data-sileo-viewport][data-position^=top] [data-sileo-toast][data-ready=true][data-exiting=true]{transform:translateY(-6px) scale(.95)}[data-sileo-viewport][data-position^=bottom] [data-sileo-toast][data-ready=true][data-exiting=true]{transform:translateY(6px) scale(.95)}[data-sileo-canvas]{position:absolute;left:0;right:0;pointer-events:none;transform:translateZ(0);contain:layout style;overflow:visible}[data-sileo-canvas][data-edge=top]{bottom:0;transform:scaleY(-1) translateZ(0)}[data-sileo-canvas][data-edge=bottom]{top:0}[data-sileo-svg]{overflow:visible}[data-sileo-header]{position:absolute;z-index:20;display:flex;align-items:center;padding:.5rem;height:var(--sileo-height);overflow:hidden;left:var(--_px, 0px);transform:var(--_ht);max-width:var(--_pw)}[data-sileo-toast][data-ready=true] [data-sileo-header]{transition:transform var(--sileo-duration) var(--sileo-spring-easing),left var(--sileo-duration) var(--sileo-spring-easing),max-width var(--sileo-duration) var(--sileo-spring-easing)}[data-sileo-header][data-edge=top]{bottom:0}[data-sileo-header][data-edge=bottom]{top:0}[data-sileo-header-stack]{position:relative;display:inline-flex;align-items:center;height:100%}[data-sileo-header-inner]{display:flex;align-items:center;gap:.5rem;white-space:nowrap;opacity:1;filter:blur(0px);transform:translateZ(0)}[data-sileo-header-inner][data-layer=current]{position:relative;z-index:1;animation:sileo-header-enter var(--sileo-duration) var(--sileo-spring-easing) both}[data-sileo-header-inner][data-layer=current]:not(:only-child),[data-sileo-header-inner][data-exiting=true]{will-change:opacity,filter}[data-sileo-header-inner][data-layer=prev]{position:absolute;left:0;top:0;z-index:0;pointer-events:none}[data-sileo-header-inner][data-exiting=true]{animation:sileo-header-exit calc(var(--sileo-duration) * .7) ease forwards}[data-sileo-badge]{display:flex;height:24px;width:24px;flex-shrink:0;align-items:center;justify-content:center;padding:2px;box-sizing:border-box;border-radius:9999px;color:var(--sileo-tone, currentColor);background-color:var(--sileo-tone-bg, transparent)}[data-sileo-title]{font-size:.825rem;line-height:1rem;font-weight:500;text-transform:capitalize;color:var(--sileo-tone, currentColor)}:is([data-sileo-badge],[data-sileo-title],[data-sileo-button])[data-state]{--_c: var(--sileo-state-success)}:is([data-sileo-badge],[data-sileo-title],[data-sileo-button])[data-state=loading]{--_c: var(--sileo-state-loading)}:is([data-sileo-badge],[data-sileo-title],[data-sileo-button])[data-state=error]{--_c: var(--sileo-state-error)}:is([data-sileo-badge],[data-sileo-title],[data-sileo-button])[data-state=warning]{--_c: var(--sileo-state-warning)}:is([data-sileo-badge],[data-sileo-title],[data-sileo-button])[data-state=info]{--_c: var(--sileo-state-info)}:is([data-sileo-badge],[data-sileo-title],[data-sileo-button])[data-state=action]{--_c: var(--sileo-state-action)}:is([data-sileo-badge],[data-sileo-title])[data-state]{--sileo-tone: var(--_c);--sileo-tone-bg: color-mix(in oklch, var(--_c) 20%, transparent)}[data-sileo-content]{position:absolute;left:0;z-index:10;width:100%;pointer-events:none;opacity:var(--_co, 0)}[data-sileo-content]:not([data-visible=true]){content-visibility:hidden}[data-sileo-toast][data-ready=true] [data-sileo-content]{transition:opacity calc(var(--sileo-duration) * .08) ease calc(var(--sileo-duration) * .04)}[data-sileo-content][data-edge=top]{top:0}[data-sileo-content][data-edge=bottom]{top:var(--sileo-height)}[data-sileo-content][data-visible=true]{pointer-events:auto}[data-sileo-toast][data-ready=true] [data-sileo-content][data-visible=true]{transition:opacity calc(var(--sileo-duration) * .6) ease calc(var(--sileo-duration) * .3)}[data-sileo-description]{width:100%;text-align:left;padding:1rem;font-size:.875rem;line-height:1.25rem;contain:layout style paint;content-visibility:auto}[data-sileo-button]{display:flex;align-items:center;justify-content:center;height:1.75rem;padding:0 .625rem;margin-top:.75rem;border-radius:9999px;border:0;font-size:.75rem;font-weight:500;cursor:pointer;color:var(--sileo-btn-color, currentColor);background-color:var(--sileo-btn-bg, transparent);transition:background-color .15s ease}[data-sileo-button]:hover{background-color:var(--sileo-btn-bg-hover, transparent)}[data-sileo-button][data-state]{--sileo-btn-color: var(--_c);--sileo-btn-bg: color-mix(in oklch, var(--_c) 15%, transparent);--sileo-btn-bg-hover: color-mix(in oklch, var(--_c) 25%, transparent)}[data-sileo-icon=spin]{animation:sileo-spin 1s linear infinite}@keyframes sileo-spin{to{transform:rotate(360deg)}}@keyframes sileo-header-enter{0%{opacity:0;filter:blur(6px)}to{opacity:1;filter:blur(0px)}}@keyframes sileo-header-exit{0%{opacity:1;filter:blur(0px)}to{opacity:0;filter:blur(6px)}}[data-sileo-viewport]{position:fixed;z-index:50;display:flex;gap:.75rem;padding:.75rem;pointer-events:none;max-width:calc(100vw - 1.5rem);contain:layout style}[data-sileo-viewport][data-position^=top] [data-sileo-toast]:not([data-ready=true]){margin-bottom:calc(-1 * (var(--sileo-height) + .75rem))}[data-sileo-viewport][data-position^=bottom] [data-sileo-toast]:not([data-ready=true]){margin-top:calc(-1 * (var(--sileo-height) + .75rem))}[data-sileo-viewport][data-position^=top]{top:0;flex-direction:column-reverse}[data-sileo-viewport][data-position^=bottom]{bottom:0;flex-direction:column}[data-sileo-viewport][data-position$=left]{left:0;align-items:flex-start}[data-sileo-viewport][data-position$=right]{right:0;align-items:flex-end}[data-sileo-viewport][data-position$=center]{left:50%;transform:translate(-50%);align-items:center}@media (prefers-reduced-motion: no-preference){[data-sileo-toast][data-ready=true]:hover,[data-sileo-toast][data-ready=true][data-exiting=true]{will-change:transform,opacity,height}}@media (prefers-reduced-motion: reduce){[data-sileo-viewport],[data-sileo-viewport] *,[data-sileo-viewport] *:before,[data-sileo-viewport] *:after{animation-duration:.01ms;animation-iteration-count:1;transition-duration:.01ms}}[data-sileo-viewport][data-theme=dark] [data-sileo-description]{color:#00000080}[data-sileo-viewport][data-theme=light] [data-sileo-description]{color:#ffffff80}@font-face{font-family:Newsreader;font-style:italic;font-weight:400;font-display:swap;src:url(/newsreader-italic-full.woff2) format("woff2");unicode-range:U+0000-02FF,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@media (hover: none){@font-face{font-family:Newsreader;font-style:italic;font-weight:400;font-display:swap;src:url(/pt-serif-italic-cyrillic.woff2) format("woff2");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;border:0 solid}:root{--font-sans: SF Mono, Cascadia Code, JetBrains Mono, Fira Code, monospace;--font-newsreader: "Newsreader", serif;--color-grey-50: #f7f6f6;--color-grey-100: #e6e2e1;--color-grey-200: #cdc5c2;--color-grey-300: #aca19c;--color-grey-400: #8a7d77;--color-grey-500: #70615c;--color-grey-600: #584e49;--color-grey-700: #48423d;--color-grey-800: #3c3633;--color-grey-900: #342f2d;--color-grey-950: #1c1917}:root{--c-bg: #FFFFFF;--c-border: #E0E7F1;--c-nav-text: #000000;--c-nav-hov: #666666;--c-nav-active: #000000;--c-text: #6A6A6A;--c-muted: #BBBBBB;--c-heading: #141414;--c-proj-name: var(--color-grey-900);--c-proj-icon: var(--color-grey-400);--c-decor: var(--color-grey-300);--c-decor-hov: var(--color-grey-500);--c-social: var(--color-grey-500);--c-social-hov: var(--color-grey-900);--c-footer-text: #000000;--c-footer-hov: #666666;--c-footer-dim: #342F2D;--c-divider: #E0E7F1;--c-date: var(--color-grey-600);--c-toggle-bg: #F5F7FA;--c-toggle-active-bg: #E3E6EB;--c-toggle-active-text: var(--color-grey-800);--c-toggle-inactive: var(--color-grey-600);--c-wave: var(--color-grey-800);--c-tag-border: var(--color-grey-200);--c-tag-bg: var(--color-grey-100);--c-tag-text: var(--color-grey-700)}html.dark{--c-bg: #232328;--c-border: #3A3A3F;--c-nav-text: #ACACAF;--c-nav-hov: var(--color-grey-100);--c-nav-active: var(--color-grey-100);--c-text: var(--color-grey-100);--c-muted: #ACACAF;--c-heading: var(--color-grey-100);--c-proj-name: var(--color-grey-100);--c-proj-icon: var(--color-grey-500);--c-decor: var(--color-grey-700);--c-decor-hov: var(--color-grey-500);--c-social: #ACACAF;--c-social-hov: #0098EA;--c-footer-text: #acacaf;--c-footer-hov: #ffffff;--c-footer-dim: #E6E2E1;--c-divider: #3A3A3F;--c-date: var(--color-grey-300);--c-toggle-bg: #2D2D32;--c-toggle-active-bg: #3B3B41;--c-toggle-active-text: var(--color-grey-100);--c-toggle-inactive: var(--color-grey-300);--c-wave: var(--color-grey-100);--c-tag-border: rgba(255,255,255,.12);--c-tag-bg: rgba(255,255,255,.07);--c-tag-text: var(--color-grey-300)}html{-webkit-text-size-adjust:100%;line-height:1.5;font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background-color:var(--c-bg);color:var(--c-text)}a{color:inherit;text-decoration:inherit}img,svg,video{display:block;vertical-align:middle}em{font-family:var(--font-newsreader);font-style:italic}.inline-link{text-decoration-line:underline;text-decoration-thickness:1px}.nav-link{color:var(--c-nav-text)!important}.nav-link:hover{color:var(--c-nav-hov)!important}.nav-link.active{color:var(--c-nav-hov)!important;font-weight:500}.footer-link{color:var(--c-footer-dim);text-decoration:none;transition:color .15s}.footer-link:hover{color:#0098ea}.lang-toggle{background:none;border:none;padding:0;cursor:pointer;font-size:12px;font-family:inherit;color:var(--c-footer-dim);transition:color .15s}.lang-toggle:hover{color:var(--c-footer-hov)}.social-link{display:flex;align-items:center;gap:4px;color:var(--c-social);transition:color .15s;margin-top:8px;margin-bottom:8px}.social-link:hover{color:var(--c-social-hov)}.project-row:hover .proj-name{text-decoration:underline}.decor-link{text-decoration:underline;text-decoration-color:var(--c-decor);text-underline-offset:2px;color:inherit;transition:text-decoration-color .15s}.decor-link:hover{text-decoration-color:var(--c-decor-hov)}.post-row{display:flex;width:100%;justify-content:space-between;gap:16px;padding:12px 0;color:var(--c-text);text-decoration:none;border-top:1px solid var(--c-divider);transition:opacity .15s}.post-row:first-child{border-top:none}.post-row:hover{opacity:.7}.post-date{flex-shrink:0;color:var(--c-date)}.archive-link{font-size:14px;color:var(--c-date);text-decoration:none}.archive-link:hover{text-decoration:underline;text-decoration-thickness:1px}.blog-subtitle{font-weight:500;font-size:24px;letter-spacing:-.025em;color:#bbb}html.dark .blog-subtitle{color:#505255}.prose{color:var(--c-text);line-height:1.7}.prose p{margin-bottom:16px}.prose p:last-child{margin-bottom:0}.prose h2{font-size:16px;font-weight:500;color:var(--c-heading);margin-top:28px;margin-bottom:10px}.prose h3{font-size:14px;font-weight:500;color:var(--c-heading);margin-top:22px;margin-bottom:8px}.prose ol,.prose ul{margin-bottom:16px;padding-left:0;list-style-position:inside}.prose li{margin-bottom:6px;line-height:1.6;padding-left:0}.prose em{font-style:italic!important;font-family:Newsreader,Georgia,serif!important}.prose strong{font-weight:600;color:var(--c-heading)}.prose a{color:var(--c-heading);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}.prose a:hover{opacity:.7}.prose code{font-family:inherit;background:var(--c-toggle-bg);padding:1px 5px;border-radius:4px;font-size:.9em}.back-link{display:inline-flex;align-items:center;gap:4px;font-size:14px;color:var(--c-muted);text-decoration:none;margin-bottom:32px;transition:color .15s}.back-link:hover{color:var(--c-heading)}.toggle-wrap{display:flex;width:fit-content;align-items:center;gap:2px;overflow:hidden;border-radius:6px;background-color:var(--c-toggle-bg);padding:2px}.toggle-btn{display:flex;width:24px;height:24px;align-items:center;justify-content:center;border-radius:4px;border:none;cursor:pointer;transition:opacity .15s;background:transparent;color:var(--c-toggle-inactive)}.toggle-btn:hover{opacity:.5}.toggle-btn.active{background-color:var(--c-toggle-active-bg);color:var(--c-toggle-active-text)}.toggle-btn.active:hover{opacity:1}@media (max-width: 639px){main{padding-top:0!important}}.tech-badge{display:inline-flex;align-items:center;gap:6px;border-radius:9999px;background:#fafafa;padding:2px 6px;font-family:var(--font-sans);font-size:12px;color:var(--c-text);border:1px solid var(--c-border);text-decoration:none;-webkit-user-select:none;user-select:none;transition:opacity .15s}.tech-badge:hover{opacity:.7}html.dark .tech-badge{background:#18181b}.chatgpt-icon-dark,html.dark .chatgpt-icon-light{display:none}html.dark .chatgpt-icon-dark{display:block}.codex-icon-dark,html.dark .codex-icon-light{display:none}html.dark .codex-icon-dark{display:block}.shadcn-icon-dark,html.dark .shadcn-icon-light{display:none}html.dark .shadcn-icon-dark{display:block}.motion-icon-dark,html.dark .motion-icon-light{display:none}html.dark .motion-icon-dark{display:block}.tag{display:inline-flex;align-items:center;padding:2px 8px;border-radius:6px;border:1px solid var(--c-tag-border);background:var(--c-tag-bg);color:var(--c-tag-text);font-size:.85em;line-height:1.6;vertical-align:middle}ul[role=list]{padding:0;margin:0}.project-row{display:flex;width:100%;min-width:0;flex-direction:column;gap:4px;text-decoration:none;color:inherit}.project-desc{display:block}@media (min-width: 640px){.project-row{flex-direction:row;align-items:center;gap:12px}.project-desc{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}}
