@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;700&family=Syne:wght@500;700&display=swap";:root{interpolate-size:allow-keywords;--clr-bg: #f4f7f3;--clr-surface: #ffffff;--clr-text: #182419;--clr-muted: #415848;--clr-primary: #0f8f67;--clr-accent: #ffffff;--clr-border: color-mix(in srgb, var(--clr-text) 14%, transparent);--clr-primary-emphasis: color-mix(in srgb, var(--clr-primary) 72%, var(--clr-text));--clr-primary-soft: color-mix(in srgb, var(--clr-primary) 14%, transparent);--clr-primary-soft-strong: color-mix(in srgb, var(--clr-primary) 22%, transparent);--surface-94: color-mix(in srgb, var(--clr-surface) 94%, transparent);--surface-92: color-mix(in srgb, var(--clr-surface) 92%, transparent);--surface-90: color-mix(in srgb, var(--clr-surface) 90%, transparent);--surface-88: color-mix(in srgb, var(--clr-surface) 88%, transparent);--surface-86: color-mix(in srgb, var(--clr-surface) 86%, transparent);--surface-78: color-mix(in srgb, var(--clr-surface) 78%, transparent);--surface-with-bg-12: color-mix(in srgb, var(--clr-surface) 88%, var(--clr-bg) 12%);--surface-with-bg-8: color-mix(in srgb, var(--clr-surface) 92%, var(--clr-bg) 8%);--surface-with-bg-20: color-mix(in srgb, var(--clr-surface) 80%, var(--clr-bg) 20%);--border-primary-soft: color-mix(in srgb, var(--clr-primary) 36%, var(--clr-border));--border-primary-strong: color-mix(in srgb, var(--clr-primary) 62%, var(--clr-border));--shadow-link: 0 0 4px color-mix(in srgb, var(--clr-primary) 50%, transparent);--shadow-soft: 0 18px 50px -32px color-mix(in srgb, var(--clr-text) 30%, transparent);--ff-base: "Space Grotesk", "Segoe UI", sans-serif;--ff-heading: "Syne", "Space Grotesk", sans-serif;--ff-reading: "Satoshi", sans-serif;--ff-mono: "Cascadia Code", "Consolas", "Courier New", monospace;--fs-base: 1.06rem;--radius-pill: 999px;--content-boundary: 83ch}[data-theme=dark]{--clr-bg: #081311;--clr-surface: #10211c;--clr-text: #e7f8ef;--clr-muted: #9ac5b0;--clr-primary: #6af0c0;--clr-accent: #ffffff;--clr-border: color-mix(in srgb, var(--clr-text) 17%, transparent);--shadow-soft: 0 22px 65px -35px rgba(0, 0, 0, .7)}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0}body{min-height:100vh;background:radial-gradient(1200px 600px at 8% -8%,color-mix(in srgb,var(--clr-accent) 19%,transparent),transparent 56%),radial-gradient(900px 500px at 92% 4%,color-mix(in srgb,var(--clr-primary) 22%,transparent),transparent 50%),linear-gradient(170deg,var(--clr-bg),color-mix(in srgb,var(--clr-bg) 88%,#ffffff 12%));color:var(--clr-text);font-family:var(--ff-base);font-size:var(--fs-base);line-height:1.6;transition:background-color .4s ease,color .4s ease}main{display:grid;gap:2rem}h1,h2,h3,p{margin:0}h1,h2,h3{color:var(--clr-text);line-height:1.1;font-family:var(--ff-heading);letter-spacing:-.02em}h1{font-size:clamp(2rem,5vw,3.4rem)}h2{font-size:clamp(1.4rem,3.2vw,2rem)}p{color:var(--clr-muted)}.hero>:where(h1,h2,h3,p,ul,ol),.recent-posts>:where(h1,h2,h3,p,ul,ol),.post-list li>:where(h3,p,.date){max-inline-size:var(--content-boundary)}.hero p,.recent-posts p,.post-list li p{text-align:justify;text-justify:inter-word}a{color:var(--clr-primary)}a:focus-visible,button:focus-visible{outline:2px solid var(--clr-primary-emphasis);outline-offset:3px}.container{width:min(100% - 2rem,920px);margin-inline:auto;padding-bottom:3rem}.site-header{margin-block:1.5rem 3.25rem;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem}.site-nav{position:relative;anchor-scope:--nav-link;padding-block-end:.45rem}.nav-list{margin:0;padding:0;list-style:none;display:flex;gap:.45rem;anchor-name:--nav-link}.nav-list li{position:relative;z-index:1}.nav-list a{position:relative;display:inline-flex;align-items:center;padding:.45rem .95rem;border-radius:.65rem;color:var(--clr-text);text-decoration:none;font-size:.92rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;transition:color .3s ease}.nav-list a:hover,.nav-list a:focus-visible{color:var(--clr-primary-emphasis);anchor-name:--nav-link}.site-nav:after{content:"";position:absolute;z-index:0;border-radius:.65rem;opacity:1;background-color:var(--clr-primary-soft);position-anchor:--nav-link;inset-block-start:anchor(end);inset-inline-start:anchor(start);inset-inline-end:anchor(end);inset-block-end:anchor(end);block-size:1px;transition:background-color .4s,block-size .4s,opacity .4s,inset .4s,inset-inline .4s .5s}.site-nav:has(a:hover,a:focus-visible):after{block-size:auto;inset-block-start:anchor(start);background-color:var(--clr-primary-soft-strong);transition:background-color .4s,block-size .4s .4s,opacity .4s,inset .4s,inset-block .4s .5s}.site-nav:not(:has(a:hover,a:focus-visible)) .nav-list a{transition:anchor-name 0ms;transition-delay:.01s;transition-behavior:allow-discrete}@supports not (position-anchor: --nav-link){.site-nav:after{display:none}.nav-list a:hover,.nav-list a:focus-visible{background-color:var(--clr-primary-soft)}}.theme-label{padding-left:12px}.theme-toggle{display:inline-flex;align-items:center;gap:.6rem;border:0;border-radius:var(--radius-pill);padding:.5rem .9rem;font-family:var(--ff-base);font-weight:600;color:var(--clr-text);background:color-mix(in srgb,var(--clr-surface) 88%,transparent);box-shadow:inset 0 0 0 2px color-mix(in srgb,var(--clr-primary) 35%,transparent);cursor:pointer;transition:transform .25s ease,background-color .35s ease}.theme-dot{inline-size:1rem;block-size:1rem;border-radius:50%;background:var(--clr-primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--clr-text) 12%,transparent);transition:transform .35s ease,background-color .35s ease}[data-theme=dark] .theme-dot{transform:translate(.8rem);background:var(--clr-accent)}.theme-toggle:hover,.theme-toggle:focus-visible{transform:translateY(-1px)}.hero,.recent-posts{border-radius:1.25rem;border:1px solid var(--clr-border);background:var(--surface-92);box-shadow:var(--shadow-soft);padding:clamp(1.2rem,2.4vw,2.1rem)}.hero{display:grid;gap:1rem}.eyebrow{font-size:.8rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:color-mix(in srgb,var(--clr-primary) 80%,var(--clr-text))}.contact-links{display:flex;justify-content:space-around;flex-wrap:wrap;gap:6rem}.contact-link{display:inline-flex;align-items:center;gap:.55rem;max-inline-size:var(--content-boundary);padding:.58rem .9rem;border-radius:.75rem;border:1px solid var(--border-primary-soft);background:var(--surface-90);color:var(--clr-text);text-decoration:none;font-size:.92rem;font-weight:700;transition:transform .2s ease,border-color .2s ease,color .2s ease}.contact-link:hover,.contact-link:focus-visible{transform:translateY(-1px);border-color:var(--border-primary-strong);color:var(--clr-primary);outline:none}.contact-icon{inline-size:1.05rem;block-size:1.05rem}.about-intro{display:grid;grid-template-columns:auto 1fr;align-items:start;gap:1.35rem}.about-avatar{inline-size:min(34vw,190px);block-size:auto;border-radius:1rem;border:1px solid var(--clr-border);box-shadow:var(--shadow-soft);background:var(--surface-88)}.about-copy{display:grid;gap:.8rem}.about-actions{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:.35rem}.about-actions .cool-button{margin-top:0}.about-details{display:grid;gap:1rem}.about-list{margin:0;padding-left:1.25rem;color:var(--clr-muted);display:grid;gap:.55rem}.about-list li{max-inline-size:var(--content-boundary)}.cool-button{position:relative;margin-top:.75rem;display:inline-grid;place-items:center;min-inline-size:15rem;padding:.9rem 1.6rem;text-decoration:none;color:var(--clr-text);font-weight:700;letter-spacing:.04em;border-radius:var(--radius-pill);box-shadow:inset 0 0 0 2px color-mix(in srgb,var(--clr-primary) 52%,transparent);background-color:var(--surface-86);overflow:clip;anchor-scope:--active-cell;isolation:isolate}.readme-btn{display:flex;justify-content:space-between}.readme-btn .btn-label{padding:0rem 6rem}.sr-only{position:absolute;inline-size:1px;block-size:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.btn-label{position:relative;z-index:2;pointer-events:none}.btn-cells{position:absolute;inset:0;z-index:1;display:grid;grid-template-columns:repeat(10,1fr)}.btn-cells span{display:block;inline-size:100%;block-size:100%;position:relative}.btn-cells span:hover{anchor-name:--active-cell}.btn-cells:not(:hover) span{transition:anchor-name 0ms;transition-delay:.4s;transition-behavior:allow-discrete}.btn-cells:before{--size: 2.8rem;content:"";position:absolute;position-anchor:--active-cell;left:anchor(left);bottom:anchor(top);inline-size:var(--size);block-size:var(--size);border-radius:50%;background:color-mix(in srgb,var(--clr-primary) 46%,var(--clr-accent) 16%);transition:all .9s ease,inset .1s;transform:scale(0);opacity:.5}.btn-cells:hover:before{opacity:1;transform:scale(40)}.btn-cells:has(>:nth-child(11):hover):before{bottom:calc(anchor(center) - var(--size) / 2);left:calc(anchor(center) - var(--size))}.btn-cells:has(>:nth-child(20):hover):before{bottom:calc(anchor(center) - var(--size) / 2);right:calc(anchor(center) - var(--size))}.btn-cells:has(>:nth-child(n+21):hover):before{bottom:calc(anchor(bottom) - var(--size))}.btn-cells:not(:hover):before{transition:opacity .4s,inset 50ms,transform .4s;transition-delay:.4s,.4s,0s}.recent-posts{display:grid;gap:.65rem}.section-head{display:flex;align-items:center;justify-content:space-between;gap:.8rem}.manim-link{display:inline-flex;align-items:center;padding:0rem 32px;border-radius:999px;background:var(--surface-86);box-shadow:var(--shadow-link);text-decoration:none;color:var(--clr-primary);font-size:.95rem;font-weight:600;white-space:nowrap;transition:color .25s ease,padding .25s ease,box-shadow .25s ease,background-color .25s ease}.manim-link:hover,.manim-link:focus-visible{padding:.5rem 2rem;background:var(--surface-78)}body.blog-post-page .post-header,body.blog-post-page .post-content{inline-size:100%;max-inline-size:var(--content-boundary);margin-inline:auto;font-family:var(--ff-reading)}body.blog-post-page .post-header h1,body.blog-post-page .post-content :where(h1,h2,h3,h4){font-family:var(--ff-reading);letter-spacing:0}body.blog-post-page .post-content :where(p,li){text-align:justify;text-justify:auto}body.blog-post-page .post-content :where(p,li,li p){color:color-mix(in srgb,var(--clr-text) 88%,var(--clr-muted))}body.blog-post-page .post-header h1{font-size:clamp(2rem,4.5vw,2.95rem);line-height:1.2}body.blog-post-page .post-meta{margin-top:.65rem;font-size:.9rem;text-align:left;color:var(--clr-muted)}body.blog-post-page .post-meta time{font-weight:600;color:color-mix(in srgb,var(--clr-text) 80%,var(--clr-muted))}body.blog-post-page .post-content{min-width:0;font-size:clamp(1.1rem,1.03rem + .25vw,1.26rem);line-height:1.9}body.blog-post-page .post-content>*+*{margin-block-start:1.05em}body.blog-post-page .post-content :where(h2,h3,h4){margin-top:2em;margin-bottom:.45em;line-height:1.3}body.blog-post-page .post-content h2{font-size:clamp(1.55rem,1.25rem + 1vw,2rem)}body.blog-post-page .post-content h3{font-size:clamp(1.28rem,1.1rem + .55vw,1.55rem)}body.blog-post-page .post-content h4{font-size:1.1rem}body.blog-post-page .post-content :where(ul,ol){padding-inline-start:1.5rem}body.blog-post-page .post-content li+li{margin-top:.45rem}body.blog-post-page .post-content a{color:var(--clr-primary);text-decoration:underline;text-decoration-thickness:.08em;text-underline-offset:.16em}body.blog-post-page .post-content blockquote{margin:1.5rem 0;padding:.4rem 0 .4rem 1rem;border-inline-start:.25rem solid color-mix(in srgb,var(--clr-primary) 55%,transparent);background:var(--surface-94);color:color-mix(in srgb,var(--clr-text) 75%,var(--clr-muted));font-style:italic}body.blog-post-page .post-content blockquote p{color:inherit}body.blog-post-page .post-content pre{margin:1.25rem 0;display:block;inline-size:100%;max-inline-size:100%;overflow-x:auto;overflow-y:hidden;padding:.9rem 1rem;border:1px solid var(--clr-border);border-radius:.75rem;background:var(--surface-with-bg-12);-webkit-overflow-scrolling:touch}body.blog-post-page .post-content pre code{display:block;inline-size:max-content;min-inline-size:100%;font-family:var(--ff-mono);font-size:.92rem;line-height:1.5}body.blog-post-page .post-content :not(pre)>code{padding:.1rem .35rem;border-radius:.35rem;border:1px solid var(--clr-border);background:var(--surface-with-bg-20);font-family:var(--ff-mono);font-size:.9em}body.blog-post-page .post-content kbd{padding:.08rem .35rem;border:1px solid var(--clr-border);border-radius:.35rem;background:var(--surface-with-bg-8);font-family:var(--ff-mono);font-size:.84em}body.blog-post-page .post-content hr{border:0;border-top:1px solid var(--clr-border);margin:1.5rem 0}body.blog-post-page .post-content table{inline-size:100%;border-collapse:collapse;margin:1.25rem 0;display:block;overflow-x:auto}body.blog-post-page .post-content :where(th,td){border:1px solid var(--clr-border);padding:.45rem .65rem;text-align:left}body.blog-post-page .post-content th{background:var(--surface-with-bg-8)}body.blog-post-page .post-content .lesson-note{margin:1.3rem 0;padding:.9rem 1rem;border:1px solid var(--clr-border);border-radius:.7rem;background:var(--surface-with-bg-8)}body.blog-post-page .post-content .lesson-note>:first-child{margin-top:0}body.blog-post-page .post-content .lesson-note>:last-child{margin-bottom:0}body.blog-post-page .post-content .lesson-note--tip{border-inline-start:.25rem solid color-mix(in srgb,var(--clr-primary) 62%,transparent)}body.blog-post-page .post-content .lesson-note--warning{border-inline-start:.25rem solid color-mix(in srgb,var(--clr-accent) 60%,transparent)}footer{margin-top:2.4rem;padding-top:1.1rem;border-top:1px solid var(--clr-border)}footer p{font-size:.92rem}.post-list{list-style:none;padding:0;margin-top:1.2rem}.post-list li{padding-block:1.05rem;border-bottom:1px solid var(--clr-border);display:flex;flex-direction:column;gap:.35rem}.post-list a{font-size:1.2rem;color:var(--clr-text);text-decoration:none}.post-list a:hover,.post-list a:focus-visible{color:var(--clr-primary)}.post-list .date{font-size:.92rem;color:var(--clr-muted)}.post-list .post-list-empty{border-bottom:0;padding-block:.35rem 0;color:var(--clr-muted)}#mouse-overlay{position:fixed;inset:0;pointer-events:none;z-index:9998;opacity:0;transition:opacity .5s ease}[data-theme=dark] #mouse-overlay{opacity:1}[data-theme=dark][data-glow=off] #mouse-overlay{opacity:0}@media(prefers-reduced-motion:reduce){.nav-list a,.site-nav:after,.theme-toggle,.theme-dot,.cool-button,.contact-link,#mouse-overlay{transition:none}}::view-transition-old(root),::view-transition-new(root){animation:none;mix-blend-mode:normal}.theme-transitioning{overflow:hidden}@media(max-width:640px){.site-header{align-items:flex-start}.nav-list{flex-wrap:wrap}.theme-toggle{width:100%;justify-content:center}.cool-button{width:100%}.section-head{align-items:flex-start;flex-direction:column}.about-intro{grid-template-columns:1fr}.about-avatar{inline-size:min(56vw,210px)}.about-actions{flex-direction:column}.about-actions .cool-button{width:100%}body.blog-post-page .post-header h1{font-size:clamp(1.75rem,7.5vw,2.3rem)}body.blog-post-page .post-content{font-size:1.06rem;line-height:1.8}}
