@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}}
