@import url("https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;1,9..144,300;1,9..144,400;1,9..144,500&display=swap");@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap");@import url("https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500&display=swap");:root{--color-bg:#faf7f2;--color-bg-card:#f2ede4;--color-bg-card-hover:#e8e0d4;--color-text:#100e0a;--color-muted:#5c5248;--color-accent:#100e0a;--color-accent-soft:#3d3830;--color-border:#100e0a;--color-border-light:#d8d0c4;--color-nav-bg:#100e0a;--color-nav-text:#f4edd8;--font-display:"Fraunces",Georgia,serif;--font-sans:"Inter",system-ui,sans-serif;--font-mono:"JetBrains Mono",ui-monospace,monospace;--radius:0.15rem;--panel-bg:#faf7f2;--panel-border:#100e0a;--panel-shadow:#100e0a}[data-theme=dark]{--color-bg:#0c0a07;--color-bg-card:#181410;--color-bg-card-hover:#221d17;--color-text:#f2e8d4;--color-muted:#8a7e6e;--color-accent:#f2e8d4;--color-accent-soft:#d8cdb8;--color-border:#f2e8d4;--color-border-light:#2a2218;--color-nav-bg:#0c0a07;--color-nav-text:#f2e8d4;--panel-bg:#0c0a07;--panel-border:#2a2218;--panel-shadow:#f2e8d4}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:var(--font-sans);color:var(--color-text);line-height:1.7;transition:background-color .3s ease,color .3s ease}.section-canvas,body{background-color:var(--color-bg)}.section-canvas{min-height:100dvh}[data-section=home]{--color-accent:#d946ef;--color-accent-soft:#e879f9}[data-section=projects]{--color-accent:#4f46e5;--color-accent-soft:#6366f1}[data-section=blog]{--color-accent:#d97706;--color-accent-soft:#f59e0b}[data-theme=dark] [data-section=home]{--color-accent:#e879f9;--color-accent-soft:#f0abfc}[data-theme=dark] [data-section=projects]{--color-accent:#818cf8;--color-accent-soft:#a5b4fc}[data-theme=dark] [data-section=blog]{--color-accent:#fbbf24;--color-accent-soft:#fcd34d}a{color:var(--color-accent);text-decoration:none}a:hover{color:var(--color-accent-soft);text-decoration:underline;text-underline-offset:3px}.page{max-width:840px;margin:0 auto;padding:2.5rem 1.5rem;position:relative}.nav-header{background:color-mix(in srgb,var(--color-accent) 6%,var(--color-bg));border-bottom:1px solid color-mix(in srgb,var(--color-accent) 20%,var(--color-border-light));position:-webkit-sticky;position:sticky;top:0;z-index:20}.nav-inner{display:flex;flex-wrap:wrap;gap:1.5rem;align-items:center;max-width:840px;margin:0 auto;padding:.9rem 1.5rem}.nav-logo{font-family:var(--font-sans);font-weight:600;font-size:.925rem;margin-right:.25rem;letter-spacing:-.01em;transition:opacity .15s}.nav-logo,.nav-logo:hover{color:var(--color-text);text-decoration:none}.nav-logo:hover{opacity:.65}.nav-link{color:var(--color-muted);text-decoration:none;font-size:.875rem;font-weight:400;padding:.2rem 0;transition:color .15s}.nav-link:hover{color:var(--color-text);text-decoration:none}.nav-link--active{color:var(--color-text);font-weight:500}.nav-stripe{display:none}.theme-toggle{margin-left:auto;background:none;border:1px solid var(--color-border-light);border-radius:50%;width:1.875rem;height:1.875rem;display:inline-flex;align-items:center;justify-content:center;color:var(--color-muted);cursor:pointer;transition:color .15s,border-color .15s;padding:0;flex-shrink:0}.theme-toggle:hover{color:var(--color-text);border-color:var(--color-border)}.theme-toggle-placeholder{width:1.875rem;height:1.875rem;margin-left:auto;flex-shrink:0}.page--home{max-width:840px;margin:0 auto;padding:3.5rem 1.5rem 5rem}.home-intro{display:flex;gap:3rem;align-items:flex-start}.home-intro-text{flex:1 1;min-width:0}.home-name{font-family:var(--font-display);font-style:italic;font-weight:500;font-size:clamp(1.9rem,4vw,2.5rem);letter-spacing:-.03em;margin:0 0 .15em;line-height:1.1;color:var(--color-text)}.home-name-accent{color:var(--color-accent)}.home-tagline{font-size:.8125rem;color:var(--color-muted);margin:0 0 1.25rem;line-height:1.5;letter-spacing:.01em}.home-lead{font-size:.9375rem;line-height:1.75;color:var(--color-text);margin:0 0 .8rem}.home-lead a{color:var(--color-accent);text-decoration:underline;text-underline-offset:2px}.home-lead a:hover{opacity:.8}.home-intro-photo{position:relative;width:185px;flex-shrink:0;aspect-ratio:3/4;overflow:hidden;box-shadow:6px 6px 0 color-mix(in srgb,var(--color-accent) 40%,transparent)}.home-intro-photo img{object-position:center 15%!important}.home-ctas{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1.25rem}.home-cta-btn{font-size:.875rem;font-weight:500;color:var(--color-accent);text-decoration:underline;text-underline-offset:3px;background:none;border:none;padding:0;cursor:pointer;display:inline;transition:opacity .15s}.home-cta-btn:hover{opacity:.7;text-decoration:underline}.home-divider{height:1px;background:var(--color-border-light);margin:2.5rem 0}.org-wrap{position:relative;display:inline-block;vertical-align:baseline}.org-link{color:var(--color-text);text-decoration:underline;-webkit-text-decoration-style:dotted;text-decoration-style:dotted;-webkit-text-decoration-color:var(--color-accent);text-decoration-color:var(--color-accent);text-underline-offset:2px;transition:color .15s}.org-link:hover{color:var(--color-accent);-webkit-text-decoration-style:solid;text-decoration-style:solid;text-decoration:underline}.org-tooltip{position:absolute;bottom:calc(100% + 8px);left:0;z-index:50;background:var(--color-bg);border:1px solid var(--color-border-light);border-radius:8px;padding:.65rem .875rem;min-width:190px;max-width:260px;box-shadow:0 4px 20px rgba(0,0,0,.12);display:flex;flex-direction:column;gap:.15rem;pointer-events:none;visibility:hidden;opacity:0;transition:opacity .12s,visibility .12s;white-space:normal}@media (hover:none){.org-tooltip{pointer-events:auto}}.org-wrap--open .org-tooltip{visibility:visible;opacity:1}.org-tooltip-visit{display:none;margin-top:.4rem;font-size:.78rem;font-weight:500;color:var(--color-accent);text-decoration:underline;text-underline-offset:2px}@media (hover:none){.org-tooltip-visit{display:inline}}.org-tooltip-name{font-size:.8125rem;font-weight:600;color:var(--color-text);line-height:1.3}.org-tooltip-role{font-size:.75rem;color:var(--color-accent);font-weight:500}.org-tooltip-desc{font-size:.78rem;color:var(--color-muted);line-height:1.5;margin-top:.2rem}.home-lead--muted{color:var(--color-muted);font-size:.875rem}.home-connect{margin-top:2.5rem}.home-connect-label{display:block;font-size:.75rem;font-weight:600;color:var(--color-text);margin-bottom:.75rem}.social-links{display:flex;flex-wrap:wrap;gap:1rem}.social-link-btn{display:inline-flex;align-items:center;gap:.4rem;font-size:.875rem;color:var(--color-muted);text-decoration:none;transition:color .15s}.social-link-btn:hover{color:var(--color-text);text-decoration:none}.social-link-icon{display:flex;align-items:center;opacity:.7}.home-footer{margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--color-border-light)}.footer-icons{display:flex;flex-wrap:wrap;gap:.6rem}.footer-icon{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:50%;background:transparent;border:1px solid var(--color-border-light);color:var(--color-muted);transition:color .15s,border-color .15s}.footer-icon:hover{color:var(--color-accent);border-color:var(--color-accent)}.footer-icon:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.home-footer-copy{margin:0;font-size:.8125rem;color:var(--color-muted)}@media (max-width:580px){.page--home{padding:2rem 1.25rem 4rem}.home-intro{flex-direction:column;gap:1.25rem}.home-intro-photo{order:-1;width:140px;aspect-ratio:3/4;flex-shrink:0}.home-name{font-size:1.65rem}.org-tooltip{min-width:170px;max-width:220px}}.page-content{padding:0}.page-content .wrapper{max-width:840px;margin:0 auto;padding:3.5rem 1.5rem 5rem;background:transparent}.post-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-border-light);position:relative}.post-header:after{display:none}.post-title{font-family:var(--font-sans);font-weight:700;font-size:clamp(1.6rem,4vw,2.2rem);margin:0;letter-spacing:-.02em;line-height:1.2;color:var(--color-text);display:block}.post-intro{font-size:.9375rem;color:var(--color-muted);line-height:1.7;margin:.75rem 0 0;max-width:56ch}.post-content{margin:0}.toc{padding:0}.toc-heading{display:block;font-family:var(--font-sans);font-size:.6875rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--color-muted);margin-bottom:.6rem}.toc-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:0;border-left:2px solid var(--color-border)}.toc-item{padding:0}.toc-item--h3{padding-left:.75rem}.toc-link{display:block;font-family:var(--font-sans);font-size:.8rem;color:var(--color-muted);text-decoration:none;line-height:1.4;padding:.25rem 0 .25rem .75rem;border-left:2px solid transparent;margin-left:-2px;transition:color .15s,border-color .15s}.toc-link:hover{color:var(--color-accent);border-left-color:var(--color-accent)}@media (max-width:720px){.toc{padding:.75rem 1rem;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius)}}.project-filters{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1.5rem;margin-top:1.5rem}.project-filter-btn{font-family:var(--font-sans);font-size:.8125rem;font-weight:400;padding:.3rem .875rem;border-radius:999px;border:1px solid var(--color-border-light);background:transparent;color:var(--color-muted);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.project-filter-btn:hover{border-color:var(--color-accent);color:var(--color-accent)}.project-filter-btn--active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.projects{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:1.75rem;gap:1.75rem;align-items:start}@media (max-width:640px){.projects{grid-template-columns:1fr}}.project-box{background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:6px;overflow:hidden;transition:box-shadow .2s,border-color .2s;display:flex;flex-direction:column}.project-box:hover{box-shadow:0 4px 20px rgba(0,0,0,.07);border-color:var(--color-border)}.project-image-box{position:relative;aspect-ratio:16/9;overflow:hidden;background:var(--color-bg-card-hover);flex-shrink:0}.project-image-link{display:block;width:100%;height:100%;text-decoration:none}.project-image-link:hover .project-image{opacity:.88;transform:scale(1.02)}.project-image{object-fit:cover;transition:opacity .25s,transform .35s}.project-image--placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--color-muted);font-size:.65rem;font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase}.project-body{padding:1.25rem 1.5rem;display:flex;flex-direction:column;flex:1 1}.project-summary{display:flex;align-items:flex-start;gap:.75rem}.project-summary-text{flex:1 1;min-width:0}.project-title-h2{font-family:var(--font-sans);font-weight:600;font-size:.9375rem;margin:0 0 .2rem;letter-spacing:-.01em;line-height:1.3;color:var(--color-text);display:inline-block}.project-tagline{font-size:.875rem;color:var(--color-text);margin:0 0 .6rem;line-height:1.45}.project-meta-row{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem}.project-date{font-family:var(--font-mono);font-size:.62rem;color:var(--color-text);letter-spacing:.06em;margin-right:.15rem}.project-tag{font-size:.62rem;font-weight:500;color:var(--color-accent);border:1px solid var(--color-accent);border-radius:999px;padding:.1em .6em;opacity:.8;line-height:1.7}.project-toggle{font-size:1.35rem;line-height:1;font-weight:300;color:var(--color-muted);background:none;border:none;cursor:pointer;padding:0;flex-shrink:0;transition:color .15s;margin-top:.15rem}.project-toggle:hover{color:var(--color-accent)}.project-details{display:grid;grid-template-rows:0fr;transition:grid-template-rows .28s ease}.project-details--open{grid-template-rows:1fr}.project-details-inner{overflow:hidden;padding-top:0;transition:padding-top .28s ease}.project-details--open .project-details-inner{padding-top:1rem}.project-detail-desc{font-size:.9rem;color:var(--color-text);line-height:1.72;margin:0 0 .5rem;padding-top:.75rem;border-top:1px solid var(--color-border-light)}.project-role-label,.project-tech-label{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--color-accent);margin:.85rem 0 .3rem;display:block}.project-role-list{margin:0 0 .5rem;padding-left:1.1rem;font-size:.875rem;color:var(--color-text);line-height:1.65}.project-role-list li{margin-bottom:.25rem}.project-tech-stack{font-size:.78rem;color:var(--color-text);margin:0 0 .75rem!important;font-family:var(--font-mono);letter-spacing:.02em}.project-links{display:flex;gap:1.25rem;margin-top:.5rem;padding-top:.75rem;border-top:1px solid var(--color-border-light)}.project-link{font-size:.825rem;font-weight:600;color:var(--color-accent);text-decoration:none;transition:opacity .15s}.project-link:hover{opacity:.75;text-decoration:none}.photo-placeholder{background:var(--color-bg-card);display:flex;align-items:center;justify-content:center;color:var(--color-muted);font-size:.75rem;font-family:var(--font-mono);overflow:hidden}.photo-placeholder img{width:100%;height:100%;object-fit:cover}.card{background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:var(--radius);padding:1.25rem 1.5rem;transition:background .2s}.card:hover{background:var(--color-bg-card-hover)}.page-accent{border-left:4px solid var(--color-accent);padding-left:1.25rem}.accent-stripe{height:4px;background:linear-gradient(90deg,var(--color-accent) 0,var(--color-accent-soft) 100%)}.about-layout{display:grid;grid-gap:2rem;gap:2rem;grid-template-columns:1fr 280px}@media (max-width:720px){.about-layout{grid-template-columns:1fr}}.about-sidebar{display:flex;flex-direction:column;gap:1rem}.heading{font-family:var(--font-display);font-weight:500;font-style:italic;letter-spacing:0}.label{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.05em;text-transform:uppercase;color:var(--color-accent)}.blog-external-link{display:inline-flex;align-items:center;gap:.4rem;font-size:.9375rem;font-weight:500;color:var(--color-accent);text-decoration:underline;text-underline-offset:3px;background:none;border:none;padding:0;margin-top:1.5rem}.blog-external-link:hover{opacity:.75;text-decoration:underline}.page--blog{max-width:840px;margin:0 auto;padding:3.5rem 1.5rem 5rem}.blog-header{margin-bottom:2.5rem}.blog-title{font-family:var(--font-display);font-style:italic;font-weight:500;font-size:clamp(1.9rem,4vw,2.5rem);letter-spacing:-.03em;margin:0 0 .4rem;line-height:1.1;color:var(--color-text)}.blog-subtitle{font-size:.9375rem;color:var(--color-muted);margin:0}.blog-layout{display:grid;grid-template-columns:1fr 200px;grid-gap:3rem;gap:3rem;align-items:start}@media (max-width:680px){.blog-layout{grid-template-columns:1fr}.blog-sidebar{order:-1}}.blog-sidebar{display:flex;flex-direction:column;gap:1.5rem}.blog-search{font-family:var(--font-sans);font-size:.875rem;color:var(--color-text);background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:var(--radius);padding:.45rem .7rem;width:100%;outline:none;transition:border-color .15s}.blog-search:focus{border-color:var(--color-accent)}.blog-sidebar-section{display:flex;flex-direction:column;gap:.5rem}.blog-sidebar-heading{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--color-muted)}.blog-sidebar-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.1rem}.blog-sidebar-item{font-family:var(--font-sans);font-size:.875rem;color:var(--color-muted);background:none;border:none;padding:.15rem 0;cursor:pointer;text-align:left;transition:color .15s;width:100%}.blog-sidebar-item:hover{color:var(--color-text)}.blog-sidebar-item--active{color:var(--color-accent);font-weight:500}.blog-filter-chips{display:flex;flex-wrap:wrap;gap:.35rem}.blog-chip--btn{background:none;border:none;padding:0;cursor:pointer;font-family:inherit}.blog-chip--btn:hover{opacity:.75}.blog-chip--active.blog-chip--cat{background:var(--color-accent);color:var(--color-bg);border-color:var(--color-accent)}.blog-chip--active.blog-chip--tag{background:var(--color-text);color:var(--color-bg);border-color:var(--color-text)}.blog-clear-btn{font-family:var(--font-sans);font-size:.8rem;color:var(--color-muted);background:none;border:none;padding:0;cursor:pointer;text-decoration:underline;text-underline-offset:2px;transition:color .15s;text-align:left}.blog-clear-btn:hover{color:var(--color-text)}.cat-dropdown{position:relative;width:100%}.cat-dropdown-btn{display:flex;justify-content:space-between;align-items:center;width:100%;font-family:var(--font-sans);font-size:.875rem;color:var(--color-muted);background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:var(--radius);padding:.45rem .7rem;cursor:pointer;text-align:left;transition:border-color .15s,color .15s}.cat-dropdown-btn--open,.cat-dropdown-btn:hover{border-color:var(--color-accent);color:var(--color-text)}.cat-dropdown-btn--active{color:var(--color-text);font-weight:500}.cat-dropdown-chevron{font-size:.6rem;color:var(--color-muted);flex-shrink:0}.cat-dropdown-panel{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--color-bg);border:1px solid var(--color-border-light);border-radius:var(--radius);box-shadow:0 4px 16px rgba(0,0,0,.1);z-index:30;padding:.35rem 0}.cat-dropdown-item{display:flex;align-items:center;gap:.6rem;padding:.45rem .75rem;font-size:.875rem;color:var(--color-text);cursor:pointer;transition:background .1s}.cat-dropdown-item:hover{background:var(--color-bg-card)}.cat-dropdown-checkbox{accent-color:var(--color-accent);width:.9rem;height:.9rem;flex-shrink:0;cursor:pointer}.blog-no-results{color:var(--color-muted);font-style:italic;font-size:.9375rem;margin:.5rem 0}.blog-year-group{margin-bottom:1.5rem}.blog-year-marker{display:flex;align-items:center;gap:.75rem;margin-bottom:.25rem}.blog-year-label{font-family:var(--font-mono);font-size:.72rem;font-weight:500;letter-spacing:.08em;color:var(--color-accent);flex-shrink:0}.blog-year-marker:after{content:"";flex:1 1;height:1px;background:var(--color-border-light)}.blog-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.blog-item{background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:6px;padding:1.1rem 1.25rem;transition:border-color .15s,box-shadow .15s}.blog-item:hover{border-color:color-mix(in srgb,var(--color-accent) 50%,var(--color-border-light));box-shadow:0 2px 8px rgba(0,0,0,.05)}.blog-item-link{display:flex;flex-direction:column;gap:.2rem;text-decoration:none}.blog-item-link:hover .blog-item-title{color:var(--color-accent);text-decoration:none}.blog-item-link:hover{text-decoration:none}.blog-item-date{font-family:var(--font-mono);font-size:.72rem;color:var(--color-muted);letter-spacing:.04em}.blog-item-title{font-family:var(--font-sans);font-size:1rem;font-weight:600;color:var(--color-text);line-height:1.35;transition:color .15s}.blog-item-desc{font-size:.875rem;color:var(--color-muted);line-height:1.55;margin-top:.1rem}.blog-item-chips{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.65rem}.blog-chip{font-size:.68rem;font-weight:500;padding:.15em .65em;border-radius:999px;line-height:1.7}.blog-chip--cat{background:color-mix(in srgb,var(--color-accent) 12%,transparent);color:var(--color-accent);border:1px solid color-mix(in srgb,var(--color-accent) 30%,transparent)}.blog-chip--tag{background:transparent;color:var(--color-muted);border:1px solid var(--color-border-light)}.page--post{max-width:680px;margin:0 auto;padding:3rem 1.5rem 6rem}.page--post-with-toc{max-width:960px}.post-body{display:flex;gap:3rem;align-items:start}.post-article-wrap,.post-body .prose{min-width:0;flex:1 1}.post-toc-sidebar{width:200px;flex-shrink:0;position:-webkit-sticky;position:sticky;top:5rem;max-height:calc(100vh - 6rem);overflow-y:auto}@media (max-width:720px){.post-body{flex-direction:column;gap:1.5rem}.post-toc-sidebar{width:100%;position:static;max-height:none;order:-1}}.post-back{display:inline-block;font-size:.875rem;color:var(--color-muted);text-decoration:none;margin-bottom:2rem;transition:color .15s}.post-back:hover{color:var(--color-accent);text-decoration:none}.post-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;margin-top:.6rem}.post-meta-date{font-family:var(--font-mono);font-size:.75rem;color:var(--color-muted);letter-spacing:.04em}.prose{font-size:1.0625rem;line-height:1.85;color:var(--color-text);margin-top:3rem}.prose p{margin:0 0 1.5em}.prose p:last-child{margin-bottom:0}.prose h1,.prose h2,.prose h3,.prose h4{font-family:var(--font-sans);font-style:normal;font-weight:700;letter-spacing:-.02em;line-height:1.25;color:var(--color-text);margin:2.5em 0 .75em}.prose h1{font-size:1.6rem}.prose h2{font-size:1.3rem}.prose h3{font-size:1.1rem}.prose h4{font-size:1rem;font-weight:600}.prose a{color:var(--color-accent);text-decoration:underline;text-underline-offset:3px}.prose a:hover{opacity:.8}.prose strong{font-weight:600}.prose em{font-style:italic}.prose ol,.prose ul{padding-left:1.5rem;margin:0 0 1.5em}.prose li{margin-bottom:.5em}.prose li>p{margin:0}.prose blockquote{border-left:3px solid var(--color-accent);margin:2em 0;padding:.75em 0 .75em 1.25rem;color:var(--color-muted);font-style:italic}.prose blockquote p{margin:0}.prose code{font-family:var(--font-mono);font-size:.875em;border:1px solid var(--color-border-light);border-radius:3px;padding:.15em .4em}.prose code,.prose pre{background:var(--color-bg-card)}.prose pre{border:1px solid var(--color-border-light);border-radius:6px;padding:1.25rem 1.5rem;overflow-x:auto;margin:1.5em 0}.prose pre code{background:none;border:none;padding:0;font-size:.875rem}.prose hr{border:none;border-top:1px solid var(--color-border-light);margin:2em 0}.prose img{max-width:100%;border-radius:4px;display:block;margin:1.5em auto}.prose table{width:100%;border-collapse:collapse;font-size:.9rem;margin:1.5em 0}.prose td,.prose th{border:1px solid var(--color-border-light);padding:.5em .75em;text-align:left}.prose th{background:var(--color-bg-card);font-weight:600;font-size:.8rem;font-family:var(--font-mono);letter-spacing:.04em}.prose .katex{font-size:1.05em}.prose .katex-display{overflow-x:auto;margin:1.5em 0}@media (max-width:640px){.page--blog,.page--post{padding:2rem 1.25rem 4rem}}.post-prev-next{display:flex;justify-content:space-between;gap:1rem;margin-top:3rem;padding-top:2rem;border-top:1px solid var(--color-border-light)}.post-prev-next-btn{display:flex;align-items:center;gap:.65rem;text-decoration:none;color:var(--color-muted);max-width:45%;transition:color .15s}.post-prev-next-btn:hover{color:var(--color-accent);text-decoration:none}.post-prev-next-btn--newer{margin-left:auto;text-align:right}.post-prev-next-arrow{font-size:1.1rem;flex-shrink:0;color:var(--color-accent)}.post-prev-next-inner{display:flex;flex-direction:column;gap:.1rem}.post-prev-next-label{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;color:var(--color-muted)}.post-prev-next-title{font-size:.875rem;font-weight:500;color:var(--color-text);line-height:1.3}.post-prev-next-btn:hover .post-prev-next-title{color:var(--color-accent)}.post-footer{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--color-border-light);display:flex;flex-direction:column;gap:1.75rem}.post-license{font-size:.875rem;color:var(--color-muted);margin:0}.post-license a{color:var(--color-accent)}.post-footer-widget{display:flex;flex-direction:column;gap:.75rem}.post-footer-heading{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--color-muted)}.further-reading-list{display:flex;flex-direction:column;gap:.65rem}.further-reading-card{display:flex;flex-direction:column;gap:.2rem;background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:6px;padding:.9rem 1rem;text-decoration:none;transition:border-color .15s}.further-reading-card:hover{border-color:color-mix(in srgb,var(--color-accent) 50%,var(--color-border-light));text-decoration:none}.further-reading-date{font-family:var(--font-mono);font-size:.68rem;color:var(--color-muted);letter-spacing:.04em}.further-reading-title{font-size:.9rem;font-weight:600;font-family:var(--font-sans);color:var(--color-text);line-height:1.35}.further-reading-desc{font-size:.8125rem;color:var(--color-muted);line-height:1.5;margin-top:.1rem}.comments-section{margin-top:4rem;padding-top:2.5rem;border-top:1px solid var(--color-border-light)}.comments-heading{font-family:var(--font-display);font-style:italic;font-weight:500;font-size:1.375rem;letter-spacing:-.02em;margin:0 0 1.75rem;color:var(--color-text)}.comments-list{list-style:none;padding:0;margin:0 0 2.5rem;display:flex;flex-direction:column;gap:0}.comment{padding:1.25rem 0;border-top:1px solid var(--color-border-light)}.comment:last-child{border-bottom:1px solid var(--color-border-light);margin-bottom:.25rem}.comment-meta{display:flex;align-items:baseline;gap:.75rem;margin-bottom:.5rem}.comment-author{font-weight:600;font-size:.9rem;color:var(--color-text)}.comment-date{font-family:var(--font-mono);font-size:.7rem;color:var(--color-muted);letter-spacing:.04em}.comment-content{font-size:.9375rem;line-height:1.75;color:var(--color-text);margin:0;white-space:pre-wrap}.comment-actions{display:flex;align-items:center;gap:1rem;margin-top:.5rem}.comment-like-btn{font-family:var(--font-sans);font-size:.8125rem;color:var(--color-muted);background:none;border:none;padding:0;cursor:pointer;transition:color .15s;display:flex;align-items:center;gap:.3em}.comment-like-btn:hover{color:#e11d48}.comment-like-btn--liked{color:#e11d48;cursor:default}.comment-reply-trigger{font-family:var(--font-sans);font-size:.8125rem;color:var(--color-muted);background:none;border:none;padding:0;cursor:pointer;transition:color .15s}.comment-reply-trigger:hover{color:var(--color-accent)}.comment-replies{list-style:none;margin:.75rem 0 0 1.5rem;display:flex;flex-direction:column;gap:.75rem;border-left:2px solid var(--color-border);padding:0 0 0 1rem}.comment--reply{padding:0;border:none;background:none;box-shadow:none}.comment-reply-form{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--color-border)}.comment-form--compact .comment-textarea{min-height:80px}.comments-thanks{font-size:.9375rem;color:var(--color-muted);font-style:italic;margin:0 0 2rem}.comment-form{display:flex;flex-direction:column;gap:1rem}.comment-form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:1rem;gap:1rem;align-items:end}.comment-label{display:flex;flex-direction:column;gap:.35rem;font-size:.8125rem;font-weight:500;color:var(--color-text)}.comment-label-note{font-weight:400;color:var(--color-muted)}.comment-input,.comment-textarea{font-family:var(--font-sans);font-size:.9375rem;color:var(--color-text);background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:var(--radius);padding:.55rem .75rem;transition:border-color .15s;outline:none;width:100%}.comment-input:focus,.comment-textarea:focus{border-color:var(--color-accent)}.comment-input:disabled,.comment-textarea:disabled{opacity:.5;cursor:not-allowed}.comment-textarea{resize:vertical;min-height:7rem;line-height:1.65}.comment-error{font-size:.875rem;color:#dc2626;margin:0}[data-theme=dark] .comment-error{color:#f87171}.comment-submit{font-family:var(--font-sans);font-size:.875rem;font-weight:500;color:var(--color-bg);background:var(--color-accent);border:1px solid var(--color-accent);border-radius:var(--radius);padding:.5rem 1.25rem;cursor:pointer;transition:opacity .15s}.comment-submit:hover{opacity:.85}.comment-submit:disabled{opacity:.5;cursor:not-allowed}.comment-add-btn{font-family:var(--font-sans);font-size:.875rem;font-weight:500;color:var(--color-accent);background:transparent;border:1px solid var(--color-accent);border-radius:var(--radius);padding:.5rem 1.25rem;cursor:pointer;transition:background .15s,color .15s}.comment-add-btn:hover{background:var(--color-accent);color:var(--color-bg)}.comment-form-actions{display:flex;align-items:center;gap:.75rem}.comment-cancel-btn{font-family:var(--font-sans);font-size:.875rem;font-weight:400;color:var(--color-muted);background:transparent;border:none;padding:.5rem .25rem;cursor:pointer;transition:color .15s}.comment-cancel-btn:hover{color:var(--color-text)}.comment-cancel-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width:540px){.comment-form-row{grid-template-columns:1fr}}.reading-progress{top:0;left:0;height:3px;background:var(--color-accent);z-index:9999;transition:width .1s linear}.glow-cursor,.reading-progress{position:fixed;pointer-events:none}.glow-cursor{width:480px;height:480px;border-radius:50%;z-index:0;opacity:0;transform:translate(-50%,-50%);background:radial-gradient(circle,color-mix(in srgb,var(--color-accent) 12%,transparent) 0,transparent 70%);transition:opacity .3s;will-change:left,top}[data-theme=dark] .glow-cursor{background:radial-gradient(circle,color-mix(in srgb,var(--color-accent) 18%,transparent) 0,transparent 70%)}.back-to-top{position:fixed;bottom:2rem;right:2rem;width:2.5rem;height:2.5rem;border-radius:50%;background:var(--color-card);border:1px solid var(--color-border);color:var(--color-muted);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:100;opacity:0;pointer-events:none;transform:translateY(8px);transition:opacity .2s,transform .2s,color .15s,border-color .15s}.back-to-top--visible{opacity:1;pointer-events:auto;transform:translateY(0)}.back-to-top:hover{color:var(--color-accent);border-color:var(--color-accent)}.post-top-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem}.post-top-bar .post-back{margin-bottom:0}.share-btn{font-family:var(--font-sans);font-size:.8125rem;font-weight:500;color:var(--color-muted);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius);padding:.3rem .85rem;cursor:pointer;transition:color .15s,border-color .15s}.share-btn--copied,.share-btn:hover{color:var(--color-accent);border-color:var(--color-accent)}.post-reading-time,.post-views{font-family:var(--font-mono);font-size:.75rem;color:var(--color-muted);letter-spacing:.04em}.copy-btn{position:absolute;top:.6rem;right:.6rem;font-family:var(--font-sans);font-size:.7rem;font-weight:500;color:var(--color-muted);background:var(--color-bg);border:1px solid var(--color-border);border-radius:calc(var(--radius) / 1.5);padding:.2rem .55rem;cursor:pointer;opacity:0;transition:opacity .15s,color .15s}.prose pre{position:relative}.prose pre:hover .copy-btn{opacity:1}.copy-btn--done{color:var(--color-accent)}.reveal-target{animation:revealFadeUp .5s ease both;animation-play-state:paused}@keyframes revealFadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.toc-link--active{color:var(--color-accent)!important;border-left-color:var(--color-accent)!important;font-weight:500}