@font-face{font-family:Necto Mono;src:url(/fonts/NectoMono-Regular.woff2) format("woff2"),url(/fonts/NectoMono-Regular.woff) format("woff");font-weight:400;font-style:normal;font-display:block}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:where([hidden]:not([hidden=until-found])){display:none!important}:where(html){-webkit-text-size-adjust:none;color-scheme:dark light}@supports not (min-block-size: 100dvb){:where(html){block-size:100%}}@media (prefers-reduced-motion: no-preference){:where(html:focus-within){scroll-behavior:smooth}}:where(body){block-size:100%;block-size:100dvb;line-height:1.4;font-family:system-ui,sans-serif;-webkit-font-smoothing:antialiased}:where(input,button,textarea,select){font:inherit;color:inherit}:where(textarea){resize:vertical;resize:block}:where(button,label,select,summary,[role=button],[role=option]){cursor:pointer}:where(:disabled){cursor:not-allowed}:where(label:has(>input:disabled),label:has(+input:disabled)){cursor:not-allowed}:where(button){border-style:solid;background-color:transparent;cursor:pointer;border-width:0;font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;line-height:inherit;padding:0;color:var(--color-text)}:where(a){text-underline-offset:.2ex}:where(ul,ol){list-style:none}:where(img,svg,video,canvas,audio,iframe,embed,object){display:block}:where(img,picture,svg){max-inline-size:100%;block-size:auto}:where(p,h1,h2,h3,h4,h5,h6){overflow-wrap:break-word}:where(h1,h2,h3){line-height:calc(1em + .5rem)}:where(hr){border:none;border-block-start:1px solid;color:inherit;block-size:0;overflow:visible}:where(:focus-visible){outline:2px solid var(--color-focus, yellow);outline-offset:2px}:where(.visually-hidden:not(:focus,:active,:focus-within,.not-visually-hidden)){clip-path:inset(50%)!important;height:1px!important;width:1px!important;overflow:hidden!important;position:absolute!important;white-space:nowrap!important;border:0!important}:root{--step-0: clamp(.8rem, .7857rem + .0714vi, .85rem);--step-1: clamp(1rem, .913rem + .4348vi, 1.25rem);--ff-body: "Necto Mono", "Inconsolata", "Bergen Mono", "Courier New", monospace;--ff-logo: "Necto Mono", "Inconsolata", "Bergen Mono", "Courier New", monospace;--fw-light: 300;--fw-regular: 400;--fw-bold: 600;--spacer-xs: .25rem;--spacer-s: .5rem;--spacer-m: 1rem;--spacer-l: 2rem;--header-height: 4rem;--color-background: #f1f1f0;--color-text: black;--color-focus: rgb(255, 234, 94);--box-shadow: rgb(0 0 0 / 8%);--ease-0: .3s}*{font-weight:var(--fw-regular)}html{scroll-behavior:smooth}body{font-family:var(--ff-body);font-size:var(--step-0);color:var(--color-text);background-color:var(--color-background)}.flow>*+*{margin-top:var(--flow-space, .7em)}.lazy__load{opacity:0;transition:1s ease-out;transform:translateY(4%)}.lazy__load-active{opacity:1;transform:translateY(0)}a{display:inline-block;color:var(--color-text);text-decoration:none}p{color:var(--color-text)}h1{font-family:var(--ff-logo);font-size:var(--step-0)}.link{position:relative;white-space:nowrap;cursor:pointer;text-decoration:underline;text-underline-offset:2px;text-decoration-color:var(--color-text);transition:text-decoration-color var(--ease-0)}.link:hover{text-decoration-color:transparent}header{display:flex;position:fixed;align-items:flex-start;justify-content:space-between;padding-top:var(--spacer-m);padding-inline:var(--spacer-l);width:100%;z-index:10}@media (width <=734px){header{padding-inline:var(--spacer-m)}}nav{display:flex;gap:4rem}@media (width <=734px){nav{gap:var(--spacer-xs);flex-direction:column;align-items:flex-end}.nav__projects{display:none}}nav>div{display:flex;gap:1rem}nav a{text-decoration-color:transparent}nav a:hover{text-decoration:underline;text-underline-offset:2px;text-decoration-color:var(--color-text);transition:text-decoration-color var(--ease-0)}.active{text-decoration:underline;text-underline-offset:2px;text-decoration-color:var(--color-text)}#about{display:flex;flex-direction:row-reverse;justify-content:center;align-items:center;gap:0 2rem;min-height:100svh;margin-inline:auto;max-width:60vw}.about__span{text-wrap:balance;max-width:75ch}@media (width <=734px){#about{flex-direction:column;gap:1rem 0rem;max-width:100%;padding-block-start:var(--header-height)}.about__span{text-wrap:unset;padding-inline:var(--spacer-m)}}.about__thumb{display:none;border-radius:2px;max-width:100px;height:auto;aspect-ratio:1 / 1}.link:hover .about__thumb{display:block;position:absolute;bottom:18px;left:0}#selected{--min: 45ch;display:grid;gap:4rem 0rem;grid-template-columns:repeat(auto-fit,minmax(min(100%,var(--min)),1fr))}@media (width <=734px){#selected{padding-block-start:16svh}}.select__section{display:flex;flex-direction:column;align-items:center;padding-inline:var(--spacer-l)}@media (width <=734px){.select__section{justify-content:center;padding-inline:var(--spacer-m);margin-block-end:12rem}}.select__img img{aspect-ratio:380/198;object-fit:fill;border-radius:2px;box-shadow:2px 2px 6px var(--box-shadow)}.select__img img:hover{box-shadow:0 4px 4px var(--box-shadow),0 4px 25px #0000001f;-webkit-transform:matrix(1,0,0,1,0,-2);transform:matrix(1,0,0,1,0,-2);transition:all .2s ease}@media (width <=734px){.select__img{width:100%}}.select__info{width:100%}.select__heading{display:flex;justify-content:space-between;margin-block-start:var(--spacer-xs);margin-block-end:var(--spacer-s);text-transform:capitalize}#all{display:flex;place-items:center;min-height:100svh}.table__wrap{flex:1;border-collapse:collapse;padding-inline:var(--spacer-l)}@media (width <=734px){.table__wrap{padding-inline:var(--spacer-m)}}.table__wrap,.table__wrap tbody,.table__wrap thead{display:block;width:100%}.table__wrap td,.table__wrap th{text-align:left}.table__wrap td:last-child,.table__wrap th:last-child{text-align:right}.table__wrap th span{cursor:pointer}.table__wrap tr{display:flex;justify-content:space-between;padding-block:.25rem;width:100%}.table__wrap tr:first-child{padding-block-start:.5rem}tr.row{padding-block:0rem}.table__wrap th span{text-decoration:underline;text-underline-offset:2px;text-decoration-color:var(--color-text);transition:text-decoration-color var(--ease-0)}.table__wrap th span:hover{text-decoration:none}@media only screen and (width <=734px){.table__wrap tr{display:flex;justify-content:space-between}}.td:not(:last-child){width:22%}.td:last-child{width:fit-content}td.type{text-transform:capitalize}@media only screen and (width <=734px){.td:not(:last-child){width:calc(50% - 1rem)}td.type,th.type{display:none}}.table__wrap tr td a{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}tr{transition:opacity var(--ease-0) ease-in-out}tbody:hover tr:not(:hover){opacity:.4}footer{display:flex;position:sticky;bottom:1.5rem;margin-inline:var(--spacer-l)}@media only screen and (width <=734px){footer{margin-inline:var(--spacer-m);bottom:2rem}}.footer__wrap{display:flex;flex-direction:row-reverse;width:100%;justify-content:space-between}.footer__toggle{display:flex}.footer__social{display:flex;align-items:flex-start;gap:1rem}img.social__img{width:20px;height:20px}.svg{fill:var(--color-text)}@keyframes slide-enter{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}.enter>*{--stagger: 0;--delay: .15s;--start: 0ms;animation:slide-enter 1s both 1;animation-delay:calc(var(--start) + var(--stagger) * var(--delay))}.enter>*:nth-child(1){--stagger: 1}.enter>*:nth-child(2){--stagger: 2}.enter>*:nth-child(3){--stagger: 3}.enter>*:nth-child(4){--stagger: 4}.enter>*:nth-child(5){--stagger: 5}.enter>*:nth-child(6){--stagger: 6}.enter>*:nth-child(7){--stagger: 7}.enter>*:nth-child(8){--stagger: 8}.enter>*:nth-child(9){--stagger: 9}.enter>*:nth-child(10){--stagger: 10}.enter>*:nth-child(11){--stagger: 11}.enter>*:nth-child(12){--stagger: 12}.enter>*:nth-child(13){--stagger: 13}.enter>*:nth-child(14){--stagger: 14}.enter>*:nth-child(15){--stagger: 15}.enter>*:nth-child(16){--stagger: 16}.enter>*:nth-child(17){--stagger: 17}.enter>*:nth-child(18){--stagger: 18}.enter>*:nth-child(19){--stagger: 19}.enter>*:nth-child(20){--stagger: 20}@media (prefers-reduced-motion: no-preference){html:not(.no-sliding) [slide-enter],html:not(.no-sliding) .slide-enter,html:not(.no-sliding) .slide-enter-content>*:not(:has(.table-of-contents)){--enter-stage: 0;--enter-step: 90ms;--enter-initial: 0ms;animation:slide-enter 1s both 1;animation-delay:calc(var(--enter-initial) + var(--enter-stage) * var(--enter-step))}}.title__arrow[data-astro-cid-pdso6hff]{display:inline-flex;opacity:0;visibility:hidden;transform:translateY(2px);transition:opacity var(--ease-0),visibility var(--ease-0)}.project__title[data-astro-cid-pdso6hff]:hover .title__arrow[data-astro-cid-pdso6hff]{opacity:1;visibility:visible}body.darkmode{--color-background: #121212;--color-text: white}input[data-astro-cid-x3pjskd3][type=checkbox]{height:0;width:0;visibility:hidden}:root{--circle: 20px}label[data-astro-cid-x3pjskd3]{cursor:pointer;width:var(--circle);height:var(--circle);display:inline-block;position:relative}label[data-astro-cid-x3pjskd3]:after{content:"";position:absolute;width:var(--circle);height:var(--circle);background-color:var(--color-text);border-radius:calc(var(--circle) / 2);transition:background-color .4s}
