*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}:root{--bg-body:rgb(245, 245, 244);--color-text-body:rgba(0, 0, 0, 0.5);--color-heading:rgb(0, 0, 0);--color-border:rgba(0, 0, 0, 0.15);--color-hover-bg:rgba(0, 0, 0, 0.05);--color-underline:rgba(0, 0, 0, 0.15);--color-underline-hover:rgba(0, 0, 0, 0.25);--header-bg:hsla(60, 5%, 96%, 0.75);--prose-body:#374151;--prose-headings:#111827;--prose-bold:#111827;--prose-links:#111827;--prose-quotes:#111827;--prose-quote-border:#e5e7eb;--prose-pre-bg:#1f2937;--prose-pre-code:#e5e7eb;--prose-hr:#e5e7eb}html.dark{--bg-body:rgb(28, 25, 23);--color-text-body:hsla(0, 0%, 100%, 0.75);--color-heading:rgb(255, 255, 255);--color-border:hsla(0, 0%, 100%, 0.2);--color-hover-bg:hsla(0, 0%, 100%, 0.1);--color-underline:hsla(0, 0%, 100%, 0.3);--color-underline-hover:hsla(0, 0%, 100%, 0.5);--header-bg:rgba(28, 25, 23, 0.25);--prose-body:#d1d5db;--prose-headings:#ffffff;--prose-bold:#ffffff;--prose-links:#ffffff;--prose-quotes:#f3f4f6;--prose-quote-border:#374151;--prose-pre-bg:rgba(0, 0, 0, 0.5);--prose-pre-code:#d1d5db;--prose-hr:#374151}html{line-height:1.5;-webkit-text-size-adjust:100%;tab-size:4;font-family:Inter,ui-sans-serif,system-ui,sans-serif,apple color emoji,segoe ui emoji,segoe ui symbol,noto color emoji;-webkit-tap-highlight-color:transparent;overflow-y:scroll;color-scheme:light;scroll-padding-top:5.5rem;scroll-behavior:smooth}html.dark{color-scheme:dark}body{width:100%;height:100%;background-color:var(--bg-body);color:var(--color-text-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;display:flex;flex-direction:column;transition:background-color .3s ease,color .3s ease}main{flex:1;padding-top:8rem;padding-bottom:8rem}a{color:inherit;text-decoration:inherit}ul,ol{list-style:none}.container{width:100%;margin-left:auto;margin-right:auto;max-width:640px;padding-left:1.25rem;padding-right:1.25rem}.page-sections{display:flex;flex-direction:column;gap:4rem}.section-with-list{display:flex;flex-direction:column;gap:1.5rem}.section-intro{display:flex;flex-direction:column;gap:1rem}.homepage-content p{margin:0}.flex-between-center{display:flex;flex-wrap:wrap;row-gap:.5rem;align-items:center;justify-content:space-between}.post-list{display:flex;flex-direction:column;gap:1rem}.work-list{display:flex;flex-direction:column;gap:1rem}.social-list{display:flex;flex-wrap:wrap;gap:.5rem;list-style:none}.social-item{display:flex;gap:.5rem;white-space:nowrap}.text-nowrap{white-space:nowrap}.line-clamp-1{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.font-semibold{font-weight:600}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-2xl{font-size:1.5rem;line-height:2rem}.opacity-75{opacity:.75}.text-black-white{color:var(--color-heading)}.underline-link{display:inline-block;color:inherit;text-decoration:underline;text-underline-offset:2px;text-decoration-color:var(--color-underline);transition:color .3s ease,text-decoration-color .3s ease}.underline-link:hover{color:var(--color-heading);text-decoration-color:var(--color-underline-hover)}.site-header{position:fixed;top:0;left:0;right:0;z-index:50;padding-top:1.25rem;padding-bottom:1.25rem;background-color:var(--header-bg);backdrop-filter:blur(4px)saturate(2);-webkit-backdrop-filter:blur(4px)saturate(2);transition:background-color .3s ease}.site-header-wrapper{display:flex;flex-wrap:wrap;row-gap:.5rem;justify-content:space-between;align-items:center}.site-logo{display:inline-block;font-weight:600;color:var(--color-text-body);transition:color .3s ease}.site-logo:hover{color:var(--color-heading)}.site-nav{display:flex;gap:.25rem;align-items:center}.site-nav a{color:var(--color-text-body);text-decoration:underline;text-underline-offset:2px;text-decoration-color:var(--color-underline);transition:color .3s ease,text-decoration-color .3s ease}.site-nav a:hover{color:var(--color-heading);text-decoration-color:var(--color-underline-hover)}.site-nav .separator{color:var(--color-text-body);opacity:.5}.site-footer{padding-top:1.25rem;padding-bottom:1.25rem;font-size:.875rem;line-height:1.25rem}.site-footer-wrapper{position:relative}.footer-back-to-top{position:absolute;right:0;top:-5rem}.footer-bottom{display:flex;justify-content:space-between;align-items:center}.theme-toggles{display:flex;flex-wrap:wrap;gap:.25rem;align-items:center}.theme-toggle-btn{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:9999px;border:none;background:0 0;color:inherit;cursor:pointer;transition:background-color .3s ease}.theme-toggle-btn:hover{background-color:var(--color-hover-bg)}.theme-toggle-btn svg{transition:stroke .3s ease}.theme-toggle-btn:hover svg{stroke:var(--color-heading)}.arrow-card{position:relative;display:flex;flex-wrap:nowrap;padding:.75rem 2.5rem .75rem 1rem;border-radius:.5rem;border:1px solid var(--color-border);color:var(--color-text-body);transition:background-color .3s ease,border-color .3s ease,color .3s ease;text-decoration:none}.arrow-card:hover{background-color:var(--color-hover-bg);border-color:var(--color-border);color:var(--color-heading)}.arrow-card-content{display:flex;flex-direction:column;flex:1;overflow:hidden}.arrow-card-title{font-weight:600}.arrow-card-desc{font-size:.875rem;opacity:.75}.arrow-card-icon{position:absolute;top:50%;right:.5rem;transform:translateY(-50%);width:1.25rem;height:1.25rem;stroke-width:2;fill:none;stroke:currentColor}.arrow-card-line{transform:translateX(-.25rem)scaleX(0);transform-origin:19px 12px;transition:transform .3s ease}.arrow-card:hover .arrow-card-line{transform:translateX(0)scaleX(1)}.arrow-card-arrow{transform:translateX(-.25rem);transition:transform .3s ease}.arrow-card:hover .arrow-card-arrow{transform:translateX(0)}.btn-back{position:relative;display:inline-flex;align-items:center;width:fit-content;padding:.375rem .75rem .375rem 1.75rem;border-radius:.25rem;border:1px solid var(--color-border);color:var(--color-text-body);background:0 0;cursor:pointer;font-family:inherit;font-size:inherit;text-decoration:none;transition:background-color .3s ease,border-color .3s ease,color .3s ease}.btn-back:hover{background-color:var(--color-hover-bg);color:var(--color-heading)}.btn-back-icon{position:absolute;top:50%;left:.5rem;transform:translateY(-50%);width:1rem;height:1rem;stroke-width:2;fill:none;stroke:currentColor}.btn-back-line{transform:translateX(.25rem)scaleX(0);transform-origin:5px 12px;transition:transform .3s ease}.btn-back:hover .btn-back-line{transform:translateX(0)scaleX(1)}.btn-back-arrow{transform:translateX(.25rem);transition:transform .3s ease}.btn-back:hover .btn-back-arrow{transform:translateX(0)}.btn-to-top{padding-left:2rem}.btn-to-top-icon{transform:translateY(-50%)rotate(90deg)}#back-to-top{pointer-events:none;opacity:0;transition:opacity .3s ease}html.scrolled #back-to-top{pointer-events:auto;opacity:1}.animate,.homepage-content>*{transform:translateY(.75rem);opacity:0;transition:transform .7s cubic-bezier(0,0,.2,1),opacity .7s cubic-bezier(0,0,.2,1)}.animate.show,.homepage-content>*.show{transform:translateY(0);opacity:1}.post-header{margin-top:2.5rem;margin-bottom:2.5rem;display:flex;flex-direction:column;gap:.25rem}.post-meta{display:flex;align-items:center;gap:.375rem}.project-nav{display:flex;gap:.25rem;align-items:center}article{max-width:65ch;color:var(--prose-body);line-height:1.75;font-size:1rem}article p{font-family:Lora,ui-serif,Georgia,Cambria,times new roman,Times,serif;margin-top:1.25em;margin-bottom:1.25em}article a{font-family:Inter,ui-sans-serif,system-ui,sans-serif;color:var(--prose-links);text-decoration:underline;text-underline-offset:2px;text-decoration-color:var(--color-underline);font-weight:500;transition:color .3s ease,text-decoration-color .3s ease}article a:hover{color:var(--color-heading);text-decoration-color:var(--color-underline-hover)}article strong{color:var(--prose-bold);font-weight:600}article h1,article h2,article h3,article h4,article h5,article h6{font-weight:600;color:var(--prose-headings);line-height:1.3333333}article h1{font-size:2.25em;margin-top:0;margin-bottom:.8888889em;line-height:1.1111111}article h2{font-size:1.5em;margin-top:2em;margin-bottom:1em}article h3{font-size:1.25em;margin-top:1.6em;margin-bottom:.6em}article h4{font-size:1em;margin-top:1.5em;margin-bottom:.5em}article ul{list-style-type:disc;margin-top:1.25em;margin-bottom:1.25em;padding-inline-start:1.625em}article ol{list-style-type:decimal;margin-top:1.25em;margin-bottom:1.25em;padding-inline-start:1.625em}article li{margin-top:.5em;margin-bottom:.5em}article li::marker{color:var(--color-text-body)}article hr{border:0;border-top:1px solid var(--prose-hr);margin-top:3em;margin-bottom:3em}article blockquote{font-weight:500;font-style:italic;color:var(--prose-quotes);border-inline-start:.25rem solid var(--prose-quote-border);padding-inline-start:1em;margin-top:1.6em;margin-bottom:1.6em}article blockquote p::before{content:open-quote}article blockquote p::after{content:close-quote}article code{color:var(--prose-headings);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,liberation mono,courier new,monospace;font-weight:600;font-size:.875em;background-color:var(--color-hover-bg);padding:.2em .4em;border-radius:.25rem}article p code::before,article p code::after{content:"`"}article pre,.highlight pre{color:var(--prose-pre-code)!important;background-color:var(--prose-pre-bg)!important;overflow-x:auto;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,liberation mono,courier new,monospace;font-weight:400;font-size:.875em;line-height:1.7142857;margin-top:1.7142857em;margin-bottom:1.7142857em;border-radius:.375rem;padding:.8571429em 1.1428571em}article pre code{background-color:initial;border-width:0;border-radius:0;padding:0;font-weight:inherit;color:inherit;font-size:inherit;font-family:inherit;line-height:inherit}article pre code::before,article pre code::after{content:none}article img{display:block;max-width:100%;height:auto;margin:2em auto;border-radius:.375rem}article table{width:100%;table-layout:auto;border-collapse:collapse;margin-top:2em;margin-bottom:2em;font-size:.85em;line-height:1.5;text-align:left}article thead{border-bottom:2px solid var(--color-border)}article th{font-weight:600;color:var(--prose-headings);padding:.75rem 1rem;vertical-align:bottom}article td{padding:.75rem 1rem;vertical-align:top;border-bottom:1px solid var(--color-border)}article tbody tr:last-child td{border-bottom:none}