@font-face{font-family:Noe Display;src:url(/assets/fonts/noe-display-medium.woff2)format("woff2"),url(/assets/fonts/noe-display-medium.woff)format("woff");font-display:swap}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--color-primary:#3b5bdb;--color-secondary:#43a9a3;--color-text:#373a3c;--color-border:#eceeef;--color-bg:#fff;--color-primary-offset:#2748c7;--color-text-offset:#818a91;--color-bg-offset:#f7f7f9;--font-family-base:-apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-family-display:"Noe Display", Georgia, Times, serif}html{box-sizing:border-box;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;-webkit-tap-highlight-color:#0000;font-size:100%;overflow-y:scroll}*,:before,:after{box-sizing:inherit}body{font-family:var(--font-family-base);color:var(--color-text);background-color:var(--color-bg);margin:0;font-size:1rem;line-height:1.625;transition:color .15s,background-color .15s;overflow:hidden auto}article,aside,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section,summary{display:block}img{vertical-align:middle;border:0}ol,ul,dl{margin:0;padding:0;list-style:none}h1,h2,h3,h4,h5,h6{margin:0;line-height:1.2}h1,h2,h3{font-family:var(--font-family-display);text-rendering:optimizelegibility;font-weight:500}p{margin:0}[hidden],template{display:none!important}a{color:var(--color-primary);text-decoration:none}a:hover,a:focus{color:var(--color-primary-offset)}::selection{background:var(--color-secondary);color:#fff}.container{width:min(96%,1500px);margin-left:auto;margin-right:auto}.layout{flex-direction:column;min-height:100vh;display:flex}.main{flex-direction:column;flex:1 0 auto;display:flex}.sr-skip-link{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;padding:0;position:absolute;overflow:hidden}.sr-skip-link:focus{clip:auto;background:var(--color-bg);border:1px solid var(--color-border);z-index:1000;width:auto;height:auto;padding:.75rem 1rem;position:fixed;top:1rem;left:1rem}.header{padding:1rem 0}.header__inner{justify-content:space-between;align-items:center;gap:1rem;display:flex}.header__brand{color:var(--color-text);align-items:center;font-weight:700;display:flex}.header__name{flex-wrap:wrap;align-items:center;display:flex}.header__avatar{object-fit:cover;border:1px solid var(--color-border);border-radius:50%;width:3rem;height:3rem;margin-right:.5rem;display:block}.nav{align-items:center;display:flex}.nav__menu{flex-wrap:wrap;display:flex}.nav__item{position:relative}.nav__item:after{content:"";background-color:var(--color-border);transform-origin:0;height:5px;transition:transform .3s cubic-bezier(.86,0,.07,1);display:block;position:absolute;bottom:-5px;left:1.25rem;right:1.25rem;transform:scaleX(0)}.nav__item:hover:after{transform:scaleX(1)}.nav__item--active:after{background-color:var(--color-primary);transform:none}.nav__link{white-space:nowrap;color:var(--color-text);align-items:center;padding:.75rem 1.25rem;line-height:1;display:flex}.nav__link:hover,.nav__link:focus{color:var(--color-text)}.nav__num{margin-right:.375rem;font-weight:700;display:block}.nav__toggle{display:none}html{scroll-behavior:smooth}.hero{flex-direction:column;flex:1 0 auto;justify-content:flex-start;padding:1.5rem 0 4rem;display:flex}.hero__inner{flex-direction:column;display:flex}.hero__title{margin-bottom:.33em;line-height:1;font-size:1.7rem!important}.hero__pretitle{text-transform:uppercase;letter-spacing:1px;order:-1;margin-bottom:1rem;font-size:1.1875rem;font-weight:700}.hero__content{font-size:1.5rem;font-weight:300;line-height:1.4}.hero__cta-wrap{justify-content:flex-end;margin-top:3rem;display:flex}.hero__cta{align-items:center;font-size:1rem;font-weight:700;display:inline-flex}.hero__support-text{max-width:52rem;color:var(--color-text-offset);margin-top:2rem;font-size:1rem;line-height:1.8}.hero__support-text--contact{margin-top:1.25rem}.hero__contact-link{margin-top:.75rem;font-size:1rem;font-weight:700;display:inline-flex}.hero__link{display:inline-block;position:relative;color:var(--color-text)!important}.hero__link:before,.hero__link:after{content:"";z-index:-1;height:.5em;display:block;position:absolute;bottom:0;left:0;right:0}.hero__link:before{background-color:var(--color-border)}.hero__link:after{background-color:var(--color-primary);transform-origin:0;transition:transform .3s cubic-bezier(.86,0,.07,1);transform:scaleX(0)}.hero__link:hover:after{transform:scaleX(1)}.hero__link--codista:after{background-color:#26ffae}.hero__link--mastodon:after{background-color:#595aff}.fade-in{backface-visibility:hidden;perspective:1000px;animation:.5s fadeInUp;transform:translate(0,0)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (width>=670px){.header{padding:3.125rem 0}.hero__title{font-size:3.8rem!important}.hero__content{font-size:2rem}}@media (width>=1260px){.hero__br{display:block}}@media (width<=939px){.header__inner{flex-direction:column;align-items:flex-start}}@media (width<=768px){.header{padding:1rem 0}.header__inner{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:.75rem;display:grid}.header__brand,.header__name{min-width:0}.nav{align-items:center;width:auto;display:flex;position:relative}.nav__toggle{border:1px solid var(--color-border);background:var(--color-bg);border-radius:.75rem;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:44px;height:44px;padding:0;display:inline-flex;box-shadow:0 8px 24px #0000000f}.nav__toggle span{background:var(--color-text);border-radius:999px;width:18px;height:2px;display:block}.nav__menu{z-index:20;border:1px solid var(--color-border);background:var(--color-bg);border-radius:1rem;grid-template-columns:1fr;gap:.5rem;width:min(320px,100vw - 2rem);padding:.75rem;display:none;position:absolute;top:calc(100% + .75rem);right:0;box-shadow:0 20px 50px #0000001f}.nav__menu--open{display:grid}.nav__item:after{display:none}.nav__link{border:1px solid var(--color-border);background:var(--color-bg);white-space:normal;border-radius:.75rem;align-items:flex-start;width:100%;min-height:48px;padding:.85rem 1rem;line-height:1.25}.nav__item--active .nav__link{border-color:var(--color-primary);background:var(--color-bg-offset)}.nav__num{min-width:1.5rem;margin-right:.5rem}}@media (width<=520px){.nav__menu{grid-template-columns:1fr}.header__avatar{width:2.75rem;height:2.75rem}.header__name,.nav__link{font-size:.95rem}}@media (width<=380px){.nav__link{padding:.75rem .875rem;font-size:.9rem}}.lead{font-size:1.5rem;font-weight:300;line-height:1.4}.page__header{padding:2rem 0}.page__content{width:100%;max-width:76rem;margin-left:auto;margin-right:auto;padding-bottom:2rem}.page__content--fullwidth{max-width:none}.page__subtitle{font-size:1.5rem;font-weight:300;line-height:1.4}.page__cta-wrap{justify-content:flex-end;margin-top:3rem;display:flex}.page__cta{align-items:center;font-size:1rem;font-weight:700;display:inline-flex}.about__header{margin-bottom:2rem}.experience-card{border:1px solid var(--color-border);background:var(--color-bg);border-radius:1rem;padding:1.5rem;box-shadow:0 12px 40px #0000000d}.experience-card+.experience-card{margin-top:1.5rem}@media (width<=939px){.experience-card{padding:1.25rem}.experience-card__company{align-items:flex-start}}.about-page{max-width:none}.about-page__grid{grid-template-columns:minmax(0,.85fr) minmax(420px,1.15fr);align-items:start;gap:2rem;display:grid}.about-page__education .experience-card+.experience-card{margin-top:1.5rem}.about-page__summary{position:sticky;top:2rem}.about-page__title{margin-bottom:1rem;font-size:1.6rem}.about-page__text{color:var(--color-text-offset);margin-bottom:1rem;line-height:1.8}.page__cta-wrap--left{justify-content:flex-start}@media (width<=939px){.about-page__grid{grid-template-columns:1fr}.about-page__summary{order:-1;position:static}}.experience-card__company{border-bottom:1px solid var(--color-border);border-bottom:1px solid var(--color-border);align-items:center;gap:1rem;padding-bottom:1.25rem;display:flex}.experience-card__logo{object-fit:cover;border:1px solid var(--color-border);background:#fff;border-radius:.75rem;width:64px;height:64px}.experience-card__company-name{margin-bottom:.25rem;font-size:1.4rem}.experience-card__company-duration{color:var(--color-text-offset);font-size:.95rem}.experience-card__roles{margin-top:1.5rem}.experience-role{padding-left:1.5rem;position:relative}.experience-role:before{content:"";background:var(--color-border);width:1px;position:absolute;top:.35rem;bottom:-1.5rem;left:.4rem}.experience-role:after{content:"";background:var(--color-primary);border-radius:999px;width:.8rem;height:.8rem;position:absolute;top:.35rem;left:0}.experience-role:last-child:before{bottom:.5rem}.experience-role--sub{border-top:1px solid var(--color-border);margin-top:2rem;padding-top:1.5rem}.experience-role__title{font-size:1.15rem;font-weight:700;font-family:var(--font-family-base);margin-bottom:.35rem}.experience-role__period{color:var(--color-text-offset);margin-bottom:.9rem;font-size:.95rem}.experience-role__description{color:var(--color-text);margin-bottom:.9rem;line-height:1.75}.experience-role__skills{color:var(--color-text-offset);font-size:.95rem;font-weight:600}@media (width<=939px){.experience-card{padding:1.25rem}.experience-card__company{align-items:flex-start}}.experience-card+.page__cta-wrap{margin-top:2rem}.experience-card *{text-align:left}.page--experience .page__content{max-width:72rem}.about__photo{margin-bottom:2rem;padding-bottom:75%;display:block;position:relative}.responsive-image{object-fit:cover;width:100%;height:100%}.about__intro{max-width:54rem}.about__intro p{margin-bottom:1rem}.about__social{list-style-type:none!important}.about__social li+li{margin-top:.75rem}.postlist{width:100%;max-width:76rem;margin-left:auto;margin-right:auto}.postlist__item{margin-bottom:3rem}.postlist__link{display:block}.postlist__title{margin-bottom:0}.postlist__meta{color:var(--color-text-offset);margin-bottom:1rem;font-size:1.125rem}.postlist__tags{text-transform:uppercase;letter-spacing:3px;font-family:Georgia,Times,serif;font-size:.875em}.postlist__excerpt{font-size:1.125rem;line-height:1.65}.project-group+.project-group{margin-top:4rem}.project-group__header{max-width:76rem;margin:0 auto 1.5rem}.project-group__header,.project-grid{padding-left:.25rem;padding-right:.25rem}.project-group__title{margin-bottom:.5rem;font-size:2rem}.project-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1.25rem;max-width:76rem;margin:0 auto;display:grid}.project-card{border:1px solid var(--color-border);background:var(--color-bg);border-radius:1rem;transition:transform .2s,box-shadow .2s,border-color .2s;box-shadow:0 10px 30px #0000000d}.project-card:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 18px 40px #00000014}.project-card__link{color:inherit;padding:1.25rem;display:block}.project-card__title{margin-bottom:.5rem;font-size:1.35rem}.project-card__description{color:var(--color-text-offset);margin-bottom:1rem;line-height:1.7}.project-card__cta{color:var(--color-primary);font-size:.95rem;font-weight:700;display:inline-flex}@media (width<=768px){.project-grid{grid-template-columns:1fr}}@media (width<=520px){.project-group__title{font-size:1.6rem}}.project-group__description{max-width:56rem;color:var(--color-text-offset);line-height:1.8}.note{border:1px solid var(--color-border);background-color:var(--color-bg);width:100%;max-width:54rem;min-height:100px;margin-left:auto;margin-right:auto;position:relative}.note__title{font-size:2.125rem;font-family:var(--font-family-base);font-weight:700}.note__meta{flex-wrap:wrap;align-items:center;padding:1rem 1rem .25rem;display:flex}.note__meta__divider{padding:0 .25rem;display:inline-block}.note__date{color:var(--color-text-offset)}.note__author{margin:0}.note__author__link{color:inherit;align-items:center;display:flex}.note__author__photo{object-fit:cover;border-radius:50%;width:3rem;height:3rem;margin-right:1rem;display:block}.note__content{padding:0 1rem 1rem}.note__content p{margin-bottom:1rem}.note__content p:last-child,.note__content img:last-child{margin:0!important}.note__footer{color:var(--color-text-offset);background-color:var(--color-bg-offset);border-top:1px solid var(--color-border);padding:1rem;font-size:.875rem;display:flex}.note__stats{align-items:center;gap:2rem;display:flex}.notelist{position:relative}.notelist:before{content:"";background-color:var(--color-border);width:1px;display:block;position:absolute;top:0;bottom:0;left:2.5rem}.notelist__item:not(:last-child){margin-bottom:2rem}.footer{border-top:1px solid var(--color-border);padding:2rem 0;font-size:.875rem}.footer a{color:var(--color-text);text-decoration:underline}.footer a:hover,.footer a:focus{text-decoration:none}.footer__inner{flex-wrap:wrap;align-items:center;display:flex}.footer__item{flex-basis:50%;margin-bottom:.5rem}@media (width<=768px){.footer{padding:1rem 0;font-size:.8rem}.footer__inner{grid-template-columns:repeat(4,minmax(0,1fr));align-items:start;gap:.5rem;display:grid}.footer__item{min-width:0;margin:0}.footer__item strong{margin-bottom:.25rem;font-size:.72rem;line-height:1.2;display:block}.footer__item br{display:none}.footer__item a{word-break:break-word;font-size:.78rem;line-height:1.35;text-decoration:none;display:block}}@media (width<=520px){.footer__inner{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=360px){.footer__inner{grid-template-columns:1fr}}@media (width>=670px){.header{padding:3.125rem 0}.hero__title{font-size:5.875rem}.hero__content,.lead,.page__subtitle{font-size:2rem}.page__header{text-align:center;padding:4rem 0}.page__title{letter-spacing:-2px;font-size:2.8rem}.page__content{padding-bottom:4rem}.postlist__item{margin-bottom:5rem}.note{border-radius:6px}.note__meta{margin-bottom:0;padding-left:5rem}.note__content,.note__footer{padding-left:5rem}.note__author__photo{position:absolute;top:1rem;left:1rem}.footer__inner{flex-wrap:nowrap}.footer__item{flex:none;margin:0;padding-right:2.5rem}}@media (width>=940px){.about__header{align-items:center;margin:0 calc(50% - 50vw) 3rem;display:flex}.about__photo{width:40%;margin:0;padding-bottom:450px}.about__intro{flex:60%;padding:2rem 3rem}}@media (width>=1260px){.hero__br{display:block}.page__header{padding:5rem 0}.page__title{font-size:3.5rem}}@media (width<=939px){.header__inner{flex-direction:column;align-items:flex-start}}.markdown{font-size:1.125rem;line-height:1.65}.markdown>*{margin-bottom:2rem}.markdown p a,.markdown li a,.markdown blockquote a{border-bottom:1px solid;box-shadow:inset 0 -2px}.markdown p a:hover,.markdown p a:focus,.markdown li a:hover,.markdown li a:focus,.markdown blockquote a:hover,.markdown blockquote a:focus{color:#fff;box-shadow:inset 0 -1.25em 0 0 var(--color-primary);border-bottom-color:var(--color-primary);outline:none}.markdown img,.markdown video{max-width:100%;height:auto;color:var(--color-text-offset);text-align:center;margin:0 auto 2rem;font-style:italic;display:block}.markdown .project-inline-preview{border:1px solid var(--color-border);border-radius:.9rem;width:100%;max-width:560px;height:auto;display:block;box-shadow:0 10px 30px #00000014}.markdown img:not(.project-inline-preview){border:1px solid var(--color-border);border-radius:.9rem;box-shadow:0 10px 30px #00000014}.markdown .project-side-preview{grid-template-columns:minmax(0,1fr) 560px;align-items:start;gap:2rem;display:grid}.markdown .project-side-preview__content{min-width:0}.markdown .project-side-preview__media{justify-content:flex-end;align-self:start;display:flex}.markdown .project-side-preview__media .project-inline-preview{text-align:initial;margin-bottom:0;font-style:normal;transform:translateY(.75rem)}@media (width<=939px){.markdown .project-side-preview{grid-template-columns:1fr}.markdown .project-side-preview__media{justify-content:flex-start}.markdown .project-side-preview__media .project-inline-preview{transform:none}}.markdown h2,.markdown h3,.markdown h4{margin-top:1.5em;margin-bottom:.5em;position:relative}.markdown ul,.markdown ol{padding-left:1em;list-style-position:outside}.markdown ul{list-style-type:disc}.markdown ol{list-style-type:decimal}.markdown blockquote{border-left:3px solid var(--color-secondary);margin:2rem 0 2rem -35px;padding-left:35px}.post__header{text-align:center;padding:2rem 0}.post__title{text-wrap:balance;font-size:2.5rem}.post__meta{color:var(--color-text-offset);flex-wrap:wrap;justify-content:center;align-items:center;margin:1rem 0;font-size:1rem;display:flex}.post__tags{text-transform:uppercase;letter-spacing:4px;font-family:Georgia,Times,serif}.post__content,.post__footer,.postsection{width:100%;max-width:76rem;margin-left:auto;margin-right:auto}.post__content>.lead:first-child{text-align:center;max-width:56rem;margin-left:auto;margin-right:auto}.post__footer{flex-wrap:wrap;justify-content:space-between;align-items:center;margin:2rem auto;display:flex}.post__footer-info{color:var(--color-text-offset);margin:1rem 0;font-style:italic}.postsection{border-top:1px solid var(--color-border);padding:2rem 0}.postsection__title{font-size:.875rem;font-family:var(--font-family-base);text-transform:uppercase;letter-spacing:3px;margin-bottom:1rem;font-weight:700}.otherposts__item:not(:last-child){margin-bottom:.25rem}.otherposts__link{color:var(--color-text);padding:.25rem 0;font-size:1.125rem;display:block}.otherposts__title{transition:all .25s;display:block;transform:translate(0)}.otherposts__date{color:var(--color-text-offset);white-space:nowrap;font-size:.75em;display:block}@media (width>=670px){.header{padding:3.125rem 0}.hero__title{font-size:5.875rem}.hero__content,.lead,.page__subtitle{font-size:2rem}.page__header{text-align:center;padding:4rem 0}.page__title{letter-spacing:-2px;font-size:2.8rem}.page__content{padding-bottom:4rem}.postlist__item{margin-bottom:5rem}.note{border-radius:6px}.note__meta{margin-bottom:0;padding-left:5rem}.note__content,.note__footer{padding-left:5rem}.note__author__photo{position:absolute;top:1rem;left:1rem}.footer__inner{flex-wrap:nowrap}.footer__item{flex:none;margin:0;padding-right:2.5rem}}@media (width>=940px){.about__header{align-items:center;margin:0 calc(50% - 50vw) 3rem;display:flex}.about__photo{width:40%;margin:0;padding-bottom:450px}.about__intro{flex:60%;padding:2rem 3rem}}@media (width>=1260px){.hero__br{display:block}.page__header{padding:5rem 0}.page__title{font-size:3.5rem}}@media (width<=939px){.header__inner{flex-direction:column;align-items:flex-start}}.u-mb4{margin-top:2rem;margin-bottom:4rem}.featuredposts{--gradient-bottom:linear-gradient(0deg, #0000 0%, #00000026 50%, #0006 100%);--gradient-full:linear-gradient(0deg, #00000080 0%, #0006 100%)}.featuredposts__list{grid-template-columns:repeat(auto-fill,minmax(245px,1fr));gap:3rem;margin:2rem 0;display:grid}.featuredposts__footer{text-align:right}.featuredposts__see-all{align-items:center;font-size:1.25rem;font-weight:700;display:inline-flex}.featuredpost{background-color:var(--color-bg-offset);border-radius:.5rem;height:300px;transition:transform .2s;display:block;position:relative;overflow:hidden;box-shadow:14px 14px 60px -10px #0000004d}.featuredpost:hover{transform:scale(1.033)}.featuredpost__image{object-fit:cover;object-position:center;width:100%;height:100%;display:block;position:absolute;inset:0}.featuredpost__inner{color:#fff;background-image:var(--gradient-full);border-radius:.5rem;padding:1rem;position:absolute;inset:0;overflow:hidden}.featuredpost__link{display:block;color:#fff!important}.featuredpost__title{font-family:var(--font-family-display);margin-bottom:.5rem;font-size:1.75rem;font-weight:500;line-height:1.4;display:block}@media (pointer:fine){.featuredpost__inner{background-image:var(--gradient-bottom)}.featuredpost:hover .featuredpost__inner,.featuredpost:focus-within .featuredpost__inner{background-image:var(--gradient-full)}.featuredpost__description{pointer-events:none;opacity:0;transition:opacity .2s,transform .2s;transform:translateY(10px)}.featuredpost:hover .featuredpost__description,.featuredpost__link:focus+.featuredpost__description{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){*{transition-duration:0s!important;animation-duration:0s!important}}
