@font-face{font-family:DM Sans;src:url(/assets/DMSans-VariableFont_opsz_wght-4BQFAdbR.woff2)format("woff2");font-weight:100 1000;font-display:swap}@font-face{font-family:"Source Serif 4";src:url(/assets/SourceSerif4-VariableFont_opsz_wght-79uAtdDp.woff2)format("woff2");font-weight:200 900;font-display:swap}:root{--font-sans:"DM Sans", ui-sans-serif, system-ui, -apple-system, sans-serif;--font-serif:"Source Serif 4", ui-serif, Georgia, Cambria, serif;--background:oklch(98.89% .0067 115.7);--foreground:oklch(27.49% .0751 252.86);--muted:oklch(53.65% .0706 253.27);--space-page-y:clamp(4rem, 10vw, 8rem);--space-page-x:clamp(1rem, 5vw, 4rem);--content-width:36.25rem}*{box-sizing:border-box}html{background:var(--background);min-width:320px;color:var(--foreground);font-family:var(--font-sans);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0}::selection{background:oklch(90.32% .0717 117.21)}.page{padding-inline:var(--space-page-x)}header{margin-top:var(--space-page-y)}main{gap:var(--space-page-y);width:100%;margin-top:var(--space-page-y);margin-bottom:var(--space-page-y);flex-direction:column;display:flex}header,section{width:100%;max-width:var(--content-width);margin-inline:auto}h1,h2,p{margin:0}h1,h2{font-size:1rem;font-weight:500}h2{font-family:var(--font-serif);margin-bottom:1.5rem}p{max-width:var(--content-width);color:var(--muted);font-size:1rem;font-weight:400;line-height:1.65}a{color:var(--muted);transition:color .3s}a:hover{color:var(--foreground)}a:focus-visible{color:var(--foreground);outline-offset:.1875rem;outline:.125rem solid}.project-link{color:inherit;border-radius:.5rem;margin-left:-1rem;margin-right:-1rem;padding:.5rem 1rem;text-decoration:none;display:block}.project-link:hover,.project-link:focus-visible{background-color:color-mix(in oklab, var(--foreground), transparent 96%)}.project-title{color:var(--foreground);display:block}.project-description{color:var(--muted)}@keyframes content-enter{0%{opacity:0;transform:translateY(.75rem)}to{opacity:1;transform:translateY(0)}}header,main section{animation:.6s cubic-bezier(.22,1,.36,1) both content-enter}header{animation-delay:80ms}main section:first-of-type{animation-delay:.18s}main section:nth-of-type(2){animation-delay:.28s}@media (prefers-reduced-motion:reduce){header,main section{animation:none}}
