@font-face{font-family:Hanken Grotesk;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/a6c19694cd327cd4-s.p.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:Hanken Grotesk;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/851c4691abdf3def-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Hanken Grotesk;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/c427e953679ae21d-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Hanken Grotesk;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/313510e2713fb214-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Hanken Grotesk Fallback;src:local("Arial");ascent-override:99.07%;descent-override:30.02%;line-gap-override:0.00%;size-adjust:100.94%}.__className_cf8499{font-family:Hanken Grotesk,Hanken Grotesk Fallback,system-ui,sans-serif;font-style:normal}.__variable_cf8499{--font-sans:"Hanken Grotesk","Hanken Grotesk Fallback",system-ui,sans-serif}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(/_next/static/media/886030b0b59bc5a7-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(/_next/static/media/0aa834ed78bf6d07-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(/_next/static/media/67957d42bae0796d-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(/_next/static/media/f911b923c6adde36-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(/_next/static/media/939c4f875ee75fbb-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(/_next/static/media/bb3ef058b751a6ad-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:JetBrains Mono Fallback;src:local("Arial");ascent-override:75.79%;descent-override:22.29%;line-gap-override:0.00%;size-adjust:134.59%}.__className_3c557b{font-family:JetBrains Mono,JetBrains Mono Fallback,monospace;font-style:normal}.__variable_3c557b{--font-mono:"JetBrains Mono","JetBrains Mono Fallback",monospace}@font-face{font-family:DSEG7Classic;src:url(/_next/static/media/37dc784befd8c6a3-s.p.woff2) format("woff2");font-display:swap;font-weight:500;font-style:normal}@font-face{font-family:DSEG7Classic;src:url(/_next/static/media/e87fc350ab4b586c-s.p.woff2) format("woff2");font-display:swap;font-weight:500;font-style:italic}@font-face{font-family:DSEG7Classic Fallback;src:local("Arial");ascent-override:62.50%;descent-override:0.00%;line-gap-override:5.63%;size-adjust:159.99%}.__className_ae8c6c{font-family:DSEG7Classic,DSEG7Classic Fallback,monospace}.__variable_ae8c6c{--font-segm7:"DSEG7Classic","DSEG7Classic Fallback",monospace}@font-face{font-family:DSEG14Classic;src:url(/_next/static/media/50bd1bc76b82116e-s.p.woff2) format("woff2");font-display:swap;font-weight:500;font-style:normal}@font-face{font-family:DSEG14Classic;src:url(/_next/static/media/a1847a1b56d7f4f2-s.p.woff2) format("woff2");font-display:swap;font-weight:500;font-style:italic}@font-face{font-family:DSEG14Classic Fallback;src:local("Arial");ascent-override:62.50%;descent-override:0.00%;line-gap-override:5.63%;size-adjust:159.99%}.__className_a54582{font-family:DSEG14Classic,DSEG14Classic Fallback,monospace}.__variable_a54582{--font-segm14:"DSEG14Classic","DSEG14Classic Fallback",monospace}@font-face{font-family:Discordia;src:url(/_next/static/media/c50e20543700a1af-s.p.woff2) format("woff2");font-display:swap;font-weight:400;font-style:normal}@font-face{font-family:Discordia;src:url(/_next/static/media/b83d8f81d0419287-s.p.woff2) format("woff2");font-display:swap;font-weight:700;font-style:normal}@font-face{font-family:Discordia;src:url(/_next/static/media/76321a0ed89ffabd-s.p.woff2) format("woff2");font-display:swap;font-weight:400;font-style:italic}@font-face{font-family:Discordia Fallback;src:local("Arial");ascent-override:95.94%;descent-override:43.91%;line-gap-override:0.00%;size-adjust:122.99%}.__className_622799{font-family:Discordia,Discordia Fallback,serif}.__variable_622799{--font-serif:"Discordia","Discordia Fallback",serif}*,:after,:before{box-sizing:border-box}*{margin:0}@media (prefers-reduced-motion:no-preference){html{interpolate-size:allow-keywords}}body{line-height:1.5}canvas,img,picture,svg,video{display:block;max-width:100%}button,input,select,textarea{font:inherit}h1,h2,h3,h4,h5,h6,p{overflow-wrap:break-word}p{text-wrap:pretty}h1,h2,h3,h4,h5,h6{text-wrap:balance}#__next,#root{isolation:isolate}.about{margin-bottom:64px}.about__header{font:var(--type-header-large);letter-spacing:var(--type-ls-header);margin-bottom:24px;margin-top:32px}.about__text p{margin:20px 0}@media (max-width:768px){.about__header{margin-bottom:16px;margin-top:20px}}.about__description{color:var(--color-gray-800);font:var(--type-text-medium);letter-spacing:-.005em;margin-bottom:64px}.about__selected-projects{margin-bottom:72px}.about__mini-map{margin-bottom:80px}@media (max-width:768px){.about{margin-bottom:48px}.about__description,.about__mini-map,.about__selected-projects{margin-bottom:54px}.about__header{font:var(--type-header-medium)}}.top-bar{padding-top:32px;margin-bottom:64px;position:relative;z-index:100}.top-bar__links{flex:1 0;gap:8px 12px;display:flex;flex-flow:row wrap;align-items:center}.top-bar__link{display:inline-flex;height:36px;padding:0 12px;border-radius:3px;align-items:center;color:var(--color-gray-800);font:var(--type-text-regular);font-weight:500;text-decoration:none}.top-bar__link--active{color:var(--color-gray-500);background-color:var(--color-gray-100)}.top-bar__link:hover:not(.top-bar__link--active){background-color:var(--color-gray-50);color:var(--color-accent)}.top-bar__link--external:after{display:inline-block;content:"";background-color:var(--color-gray-300);width:4px;height:4px;border-radius:4px;position:relative;top:-6px;margin-left:4px}.top-bar__link--external:hover:after{background-color:var(--color-accent);opacity:.8}.top-bar__layout{--logo-size:54px;--logo-margin:40px;display:flex;align-items:center;margin-left:calc(-1 * (var(--logo-size) + var(--logo-margin) + 12px))}.top-bar__logo-wrapper{margin-right:calc(var(--logo-margin))}.top-bar__logo{--color:var(--color-gray-800);border-radius:3px;width:var(--logo-size);height:var(--logo-size);display:block}.top-bar__logo:after{-webkit-mask:url(/_next/static/media/logo-mask.9b0d656a.png) no-repeat center/100%;mask:url(/_next/static/media/logo-mask.9b0d656a.png) no-repeat center/100%;background:var(--color);width:100%;height:100%;display:block;content:""}.top-bar__logo:hover{--color:var(--color-accent)}@media (min-width:768px){.top-bar__link--mobile-only{display:none}}@media (max-width:768px){.top-bar__layout{flex-wrap:wrap;--logo-size:32px;--logo-margin:22px;margin-left:0}.top-bar__links{order:1}.top-bar__logo-wrapper{margin-right:0;margin-left:12px;order:2;align-self:flex-start}.top-bar{margin-bottom:48px}}.footer{padding:0 0 80px;margin-top:32px}.footer__main{margin:0 auto 80px}.footer__divider{height:2px;background:linear-gradient(to right,transparent 5%,var(--color-gray-100),transparent 95%)}@media (max-width:768px){.footer__main{margin-bottom:64px}}.footer__links{font:var(--type-text-regular);font-weight:500;display:grid;grid-template-columns:repeat(2,1fr);grid-gap:12px 64px;gap:12px 64px}.footer__reach-out{color:var(--color-gray-600);font:var(--type-text-regular);margin-bottom:32px;padding-top:48px}.footer__link{color:var(--color-gray-800);text-decoration:none}.footer__link:hover{color:var(--color-accent)}.footer__cv{grid-area:1/1/span 2/span 1;place-self:flex-start flex-start;width:100%}@media (max-width:640px){.footer__cv{grid-column-end:span 2;padding-bottom:6px}}.footer__logo{width:32px;opacity:.15;margin:0 auto 24px}.footer__side-note{color:var(--color-gray-600);font:var(--type-text-small);margin:0 auto;text-align:center}.footer__side-note a{color:var(--color-accent-300);text-decoration:none}.footer__side-note p{margin:18px 0}.footer__side-note a:hover{color:var(--color-accent-500);text-decoration:underline}.footer__font--discordia{font-family:var(--font-serif);font-weight:700}.footer__font--dseg7{font-family:var(--font-segm7);font-size:.8em;font-weight:700}.footer__font--dseg14{font-family:var(--font-segm14);font-size:.8em;font-weight:700}.mini-map__header{font:var(--type-text-small);color:var(--color-gray-600);margin-bottom:6px}.mini-map{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));grid-gap:7px;gap:7px}.mini-map__item{aspect-ratio:1/1;min-width:80px;min-height:80px;max-width:96px;max-height:96px;background-size:cover;background-position:50%;background-repeat:no-repeat;cursor:pointer;background-color:var(--color-gray-200);border-radius:6px;--shadow:inset -1px -1px 0 1px rgba(0,0,0,0.07),inset 1px 1px 0px 1px rgba(128,128,128,0.2),inset 2px 2px 0px 1px rgba(255,255,255,0.2);box-shadow:var(--shadow),inset 0 0 0 2px transparent;position:relative;overflow:hidden}.mini-map__item:before{content:"";display:block;position:absolute;inset:0;background:radial-gradient(circle at top left,rgba(255,255,255,.3) 0,transparent 35%,transparent 70%,rgba(0,0,0,.05));border-radius:6px;transition:box-shadow .2s ease;box-shadow:inset 0 0 0 2px transparent}.mini-map__item:hover:before{box-shadow:inset 0 0 0 2px var(--color-accent)}.showcase__popover{--aspect-ratio:2;position:fixed;width:480px;height:calc(480px / var(--aspect-ratio));overflow:hidden;border-radius:8px;z-index:999;box-shadow:0 2px 30px rgba(0,0,0,.1),0 0 0 1px rgba(0,0,0,.075);background-color:var(--color-gray-100)}.showcase__popover--modal{width:100%;max-width:480px;height:calc(440px / var(--aspect-ratio));position:relative;border-radius:0}.showcase__popover--hidden{opacity:0;pointer-events:none}.showcase__static-backdrop{position:fixed;z-index:998;background-color:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);padding:32px 0;flex-flow:column nowrap;gap:40px}.showcase__placeholder,.showcase__static-backdrop{inset:0 0 0 0;display:flex;align-items:center;justify-content:center}.showcase__placeholder{position:absolute;overflow:hidden;background-color:var(--color-gray-100)}.showcase__placeholder>span{animation-duration:.7s}.showcase__media{position:absolute;inset:0 0 0 0;overflow:hidden;font-size:20px}.showcase__img,.showcase__video{object-fit:cover;object-position:top center}.showcase__video{width:100%;height:100%}.showcase__desc{position:absolute;bottom:0;left:0;right:0;height:40px;padding:5px 16px;background:var(--color-accent);font:var(--type-text-regular);color:white;font-weight:600;line-height:1.5;text-overflow:hidden;white-space:nowrap}.showcase__modal-button{background-color:var(--color-gray-50);border-radius:32px;max-width:230px;height:64px;border:none;display:flex;align-items:center;justify-content:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;font:var(--type-text-regular);-webkit-text-decoration:dashed underline var(--color-gray-400);text-decoration:dashed underline var(--color-gray-400);color:inherit}.showcase__modal-button:active,.showcase__modal-button:hover{color:var(--color-accent)}.showcase__description{position:absolute;bottom:22px;left:0;height:32px;width:100%;background:var(--color-accent-700);color:white;font:var(--type-text-medium);transform:rotate(-.5deg);display:flex;align-items:center;box-shadow:0 1px 6px -1px rgba(0,0,0,.15);font-family:var(--font-serif);font-style:italic}@media (max-width:640px){.showcase__description{bottom:12px}}.showcase__marquee{padding:0 32px;display:flex;align-items:center;box-sizing:border-box}.showcase__tag{border-radius:32px;border:1px solid white;display:flex;align-items:center;font-family:var(--font-sans);font-weight:600;font-size:12px;color:white;padding:0 4px;margin-right:4px;height:18px}.showcase__tag:last-child{margin-right:8px}.references{--marker-offset:12px;padding:0}.references a{color:inherit;-webkit-text-decoration-color:var(--color-gray-300);text-decoration-color:var(--color-gray-300)}.references a:active,.references a:hover{-webkit-text-decoration-color:var(--color-accent);text-decoration-color:var(--color-accent);text-decoration-thickness:3px}li.references__item{padding-left:var(--marker-offset);margin-left:calc(-1 * var(--marker-offset))}li.references__item+li.references__item{margin-top:32px}li.references__item::marker{font:var(--type-text-small);color:var(--color-gray-400);font-size:12px;margin-right:8px}.references__link{color:var(--color-gray-800);font-style:italic;display:block}.references__link:before{content:"«"}.references__link:after,.references__link:before{-webkit-text-decoration-color:var(--color-gray-300);text-decoration-color:var(--color-gray-300)}.references__link:after{content:"»"}.references__details{margin-top:4px;color:var(--color-gray-700);font-weight:400}.page-header__header{font:var(--type-header-medium);letter-spacing:var(--type-ls-header);margin-bottom:16px;margin-top:16px}.page-header__text{font:var(--type-text-medium);margin-bottom:70px;color:var(--color-gray-800)}@media (max-width:768px){li.references__item::marker{color:transparent}}.banner-cv__button{background:white;border-radius:6px;height:62px;padding:0 18px;display:flex;align-items:center;cursor:pointer;position:relative;overflow:hidden;-webkit-user-select:none;-moz-user-select:none;user-select:none;max-width:420px;color:inherit;text-decoration:inherit;box-shadow:0 0 0 2px var(--color-gray-200);z-index:100;-webkit-tap-highlight-color:transparent}.banner-cv__button:hover{box-shadow:0 0 0 2px var(--color-accent)}.banner-cv__label{font:var(--type-text-small);color:var(--color-gray-700);font-weight:500;margin-right:96px;margin-bottom:2px}.banner-cv__sub-label{font:var(--type-text-x-small);color:var(--color-gray-400);line-height:1;margin-bottom:6px}.banner-cv__page{width:116px;height:163px;position:absolute;top:0;right:0;box-shadow:1px 1px 16px 0 var(--color-gray-300),0 0 0 .5px var(--color-gray-100);transform:translateY(6px) rotate(3deg) scale(1.1);transition:transform .2s ease;will-change:transform;pointer-events:none;background-size:cover;background-position:top;z-index:50}.banner-cv__button:hover .banner-cv__label{color:var(--color-accent)}.banner-cv__button:hover .banner-cv__page{color:var(--color-accent);transform:translateY(11px);box-shadow:1px 1px 8px 0 var(--color-gray-200),0 0 0 .5px var(--color-gray-200)}.banner-cv__button:active .banner-cv__page{transform:translateY(5px)}@media (max-width:640px){.banner-cv__button{max-width:none;height:72px}.banner-cv__page{width:162px;height:229px}}.grid-layout{--inner-grid-width:700px;--spacer:1fr;--inner-grid-step:calc(var(--inner-grid-width) / 4);--outer-grid-step:var(--inner-grid-step);display:grid;grid-template-columns:[start] var(--spacer) [outer-grid] var(--outer-grid-step) [inner-grid] repeat(4,var(--inner-grid-step) [inner-grid]) var(--outer-grid-step) [outer-grid] var(--spacer) [end]}.grid-layout--with-padding{padding:0 calc(32px + max(env(safe-area-inset-right), env(safe-area-inset-left)))}@media (max-width:768px){.grid-layout--with-padding{padding:0 calc(20px + max(env(safe-area-inset-right), env(safe-area-inset-left)))}}@media (max-width:1152px){.grid-layout{--spacer:0fr;--outer-grid-step:calc((100% - var(--inner-grid-width)) / 2)}}@media (max-width:768px){.grid-layout{--spacer:0fr;--outer-grid-step:0fr;--inner-grid-step:calc(100% / 4)}}.container--ignore-topbar-margin{margin-top:-64px}@media (max-width:768px){.container--ignore-topbar-margin{margin-top:-48px}}.solid-link{display:inline;cursor:pointer;position:relative;white-space:nowrap;text-decoration:none;z-index:2;text-shadow:1px 1px 0 white,-1px 1px 0 white,0 1px 0 white;color:inherit;font-weight:500}.solid-link:before{display:inline-block;content:"";height:2px;background-color:var(--color-accent);position:absolute;top:1.1em;right:0;left:0;transition:height .1s ease;z-index:-2}.solid-link:hover:before{height:5px}.selected-projects__grid{display:flex;flex-flow:row nowrap;gap:40px 16px}.selected-projects__pic{background-color:var(--color-gray-50);height:214px;transition:border .2s ease;border:2px solid var(--color-gray-200);border-radius:6px;overflow:hidden;position:relative;cursor:pointer;display:block;margin-bottom:16px}.selected-projects__img{object-fit:cover;object-position:bottom center}.selected-projects__pic:hover{border-color:var(--color-accent)}.selected-projects__title{font:var(--type-text-regular)}.selected-projects__item{flex:1 1 50%;max-width:100%}@media (max-width:768px){.selected-projects__pic{height:200px}}@media (max-width:640px){.selected-projects__pic{height:220px}.selected-projects__grid{flex-wrap:wrap}.selected-projects__item{flex-basis:100%;flex-shrink:0}}@supports (aspect-ratio:16/9){.selected-projects__pic{aspect-ratio:16/9;height:auto}}.selected-projects__links{margin-top:16px}.project-link{background-color:var(--color-gray-50);padding:0 16px 1px;border-radius:40px;font-weight:600;height:38px;vertical-align:middle;margin-right:8px;box-shadow:inset 0 0 0 1px var(--color-gray-200);color:var(--color-gray-600);text-decoration:none;transition:box-shadow .2s ease;display:inline-flex;align-items:center;gap:8px}.project-link>svg{color:var(--color-gray-800);margin-top:1px}.project-link:hover,.project-link:hover>svg{color:var(--color-accent)}.project-link:hover{box-shadow:inset 0 0 0 2px var(--color-accent)}.project-link--primary{--primary-color:var(--color-accent-500);background-color:var(--primary-color);color:white;box-shadow:none}.project-link--primary:hover{color:white;box-shadow:inset 0 0 0 2px var(--primary-color),inset 0 0 0 4px white}.speaking{padding-top:48px;padding-right:32px}.speaking__header{display:flex;flex-flow:row nowrap;align-items:center;gap:24px;justify-content:center;padding-bottom:12px}.speaking__title{font:var(--type-text-medium);margin:0}.speaking__talk{display:flex;flex-flow:row nowrap;align-items:flex-start;gap:32px 54px;margin-bottom:128px}.speaking__slides{flex-shrink:0}.speaking__desc{margin-bottom:26px}.speaking__desc p{margin:18px 0}.speaking__desc code{font:var(--type-text-small);font-family:var(--font-mono);font-weight:500;background-color:var(--color-gray-100);letter-spacing:-.01em;padding:1px 4px;border-radius:4px}.speaking__head{flex:1 1 auto;font:var(--type-header-regular)}.speaking__confs{display:flex;flex-wrap:wrap;gap:8px}.speaking__conf{font:var(--type-text-small);font-weight:500;border:1px solid var(--color-gray-300);height:32px;border-radius:8px;display:flex;align-items:center;padding-left:12px;white-space:nowrap;gap:16px;overflow:hidden;box-shadow:0 1px 0 1px var(--color-gray-100);text-decoration:none;color:inherit}.speaking__conf-year{display:flex;height:100%;align-items:center;padding:0 12px;font:var(--type-text-x-small);border-left:1px solid var(--color-gray-300);letter-spacing:0;font-style:italic;font-weight:700;letter-spacing:-.05em}.speaking__conf[href]:hover{color:var(--color-accent-700)}.speaking__conf[href]:hover,.speaking__conf[href]:hover .speaking__conf-year{border-color:var(--color-accent-700)}.speaking__rest{display:grid;grid-template-columns:1fr 1fr;grid-gap:96px 80px;gap:96px 80px;margin-bottom:80px}.speaking__rest>.speaking__talk{margin-bottom:0}.speaking__title-with-icon{display:flex;flex-flow:column wrap;gap:28px}@media (max-width:768px){.speaking__title-with-icon{flex-flow:row nowrap;align-items:center;gap:24px}}.sp-icon{height:50px;width:50px;flex:0 0 auto;position:relative}.sp-icon__img{position:absolute;top:-2px;left:0}.sp-icon>svg{width:100%;transform:rotate(-3deg);color:var(--color-gray-50)}.speaking__nav-btn{background-color:var(--color-gray-50);padding:0 17px;border-radius:40px;height:38px;vertical-align:middle;box-shadow:inset 0 0 0 1px var(--color-gray-200);color:var(--color-gray-600);text-decoration:none;transition:box-shadow .2s ease;font:var(--type-text-small);font-weight:500;display:inline-flex;align-items:center;gap:8px}.speaking__nav-btn>svg{color:var(--color-gray-800);margin-top:1px}.speaking__nav-btn:hover,.speaking__nav-btn:hover>svg{color:var(--color-accent)}.speaking__nav-btn:hover{box-shadow:inset 0 0 0 2px var(--color-accent)}.speaking-talk-link{display:flex;flex-flow:row nowrap;align-items:center;border-radius:12px;gap:12px;background-color:var(--color-gray-50);text-decoration:none;color:inherit;padding:8px 16px;white-space:nowrap;transition:background-color .15s ease}.speaking-talk-link:hover{background-color:var(--color-gray-100)}.speaking-talk-link__icon{flex:0 0 auto;display:flex;align-items:center;justify-content:center;&>svg{width:20px;color:var(--color-gray-600)}.speaking-talk-link:hover & svg{color:var(--color-gray-900)}}.speaking-talk-link__text{flex:1 1 auto;font:var(--type-text-small);text-decoration:inherit;color:var(--color-gray-600);padding-top:1px;text-overflow:ellipsis;overflow:hidden;.speaking-talk-link:hover &{color:var(--color-gray-900)}}.speaking-talk-link__details{font:var(--type-text-x-small);color:var(--color-gray-400);text-overflow:ellipsis;overflow:hidden;padding-top:2px;margin-left:6px}.speaking__talk-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));grid-gap:8px;gap:8px;margin-top:12px;&.speaking__talk-links--single{grid-template-columns:1fr;justify-items:center}}@media (max-width:1024px){.speaking__talk-links{width:320px}}@media (max-width:640px){.speaking__talk-links{width:100%}}@media (max-width:1024px){.speaking{padding-top:16px;padding-right:0}.projector{width:320px}}@media (max-width:768px){.speaking__talk{flex-wrap:wrap;margin-bottom:80px}.speaking__rest{grid-template-columns:1fr;gap:72px}.speaking__desc{margin-bottom:20px}}@media (max-width:640px){.speaking__slides{flex-grow:1}.projector{width:100%;min-height:auto}}.segmented__text{font-family:var(--font-segm14);position:relative;color:inherit}.segmented__text:before{z-index:-1;position:absolute;inset:0 0 0 0;content:attr(data-cells);color:var(--cell-color)}.segmented__text:after{content:attr(data-text)}.projector{--slides-n:2;border-radius:12px;width:380px;min-height:240px;background-color:var(--color-gray-50);display:flex;flex-flow:column nowrap;align-items:center;justify-content:center;overflow:hidden}.projector:has(.projector__progress){justify-content:flex-start}.projector__slides{display:grid;grid-auto-flow:column;scroll-snap-type:x mandatory;scroll-snap-stop:always;padding:24px 0}.projector__slides::-webkit-scrollbar{display:none}.projector__slide-step{flex:1 0 100%;scroll-snap-align:start;padding:0 24px;width:100%}.projector__slide{aspect-ratio:16/9;width:100%;border:3px solid #ffffff;box-shadow:0 0 16px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.1);border-radius:12px;position:relative;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:scale .1s ease}.projector__slide:hover{scale:.99}.projector__slide-img{aspect-ratio:16/9;object-fit:cover;border-radius:12px}.projector__progress{--step-w:20px;--step-h:7px;height:calc(var(--step-h) + 1px);background:white;box-shadow:0 0 0 1px rgba(0,0,0,.05),inset 0 2px 0 rgba(0,0,0,.07);border-radius:6px;display:flex;gap:1px;padding:0 1px;width:calc(var(--total) * var(--step-w));position:relative}.projector__progress-control{border-radius:16px;padding:10px;margin-top:-12px;margin-bottom:14px;cursor:pointer;transition:background .15s ease}.projector__progress-control:hover{background:rgba(0,0,0,.03)}.projector__progress-mark{width:1px;height:4px;position:absolute;background:var(--color-gray-100);top:4px}.projector__progress-step{height:var(--step-h);width:var(--step-w);margin-top:1px;border-radius:16px;background-color:var(--color-accent-400);box-shadow:inset 0 1px 2px rgba(255,255,255,.4),0 0 0 .5px var(--color-accent-300);transition:transform .1s ease;transform:translateX(calc(100% * var(--current)))}@media (max-width:1024px){.projector{width:320px}}@media (max-width:640px){.projector{width:100%;min-height:auto}}.article{--type-article-header:600 normal 54px/56px var(--font-serif);--type-article-title:600 normal 19px/29px var(--font-sans);padding-bottom:96px;padding-top:40px}.article__header{padding-bottom:80px;font:var(--type-article-title);font-weight:400}.article__description{text-wrap:pretty;padding-right:40px}.article__info{color:var(--color-gray-400);margin-top:4px}.article__h1{font:var(--type-article-header);color:var(--color-gray-800);letter-spacing:var(--type-ls-header);max-width:480px;margin-bottom:24px}@media (max-width:768px){.article{--type-article-header:600 44px/46px var(--font-serif)}.article__header{padding-bottom:56px}.article__h1{margin-bottom:22px}.article__info{margin-top:4px}}.article__category{font:var(--type-text-x-small);color:var(--color-accent-400);text-transform:uppercase;letter-spacing:2px;margin-bottom:16px;display:inline-block;border-radius:6px}.article__cover{height:380px;overflow:hidden;position:relative;border-radius:4px;margin-bottom:48px;& img{object-fit:cover;object-position:top center}}@media (max-width:640px){.article__cover{height:200px;margin-bottom:32px}}.article__notion.notion{&{--notion-max-width:var(--inner-grid-width);--notion-font:var(--font-sans);padding:0;font:var(--type-text-post);color:var(--color-gray-800)}& ::selection{color:var(--color-gray-50);background-color:var(--color-accent)}& code{font-family:var(--font-mono)}& .notion-h{letter-spacing:var(--type-ls-header);margin-bottom:16px;padding:0}& .notion-h1{font:var(--type-header-large)}& .notion-h2{font:var(--type-header-medium);margin-top:80px}& .notion-h3,& .notion-h4{font:var(--type-header-regular)}& .notion-h1+.notion-h2{margin-top:.8em}& .notion-inline-code{background-color:var(--color-gray-100);letter-spacing:-.01em;padding:2px 4px;border-radius:4px;font-weight:700;color:hsl(346 76% 59%/1);& b{font-weight:800}}& .notion-link:has(.notion-inline-code){text-decoration:none;border-bottom:none;opacity:1}& .notion-link>.notion-inline-code{text-decoration:underline}& .notion-link>.notion-inline-code:hover{background:var(--color-gray-200)}& .notion-text{margin:16px 0;padding:0}& .notion-list-numbered>li::marker{font:var(--type-text-small)}& .notion-asset-wrapper{margin:16px 0;padding:0}& .notion-asset-wrapper-image{border-radius:3px;overflow:hidden}& .notion-asset-wrapper-full:has(iframe){border:1px solid var(--color-gray-200);border-radius:3px;overflow:hidden;max-width:calc(100vw - 32px)}& .notion-asset-wrapper:not(.notion-asset-wrapper-full):has(iframe){border:1px solid var(--color-gray-200);border-radius:4px}& .notion-asset-caption{font:var(--type-text-small)}& .notion-callout{border-radius:8px;padding:24px 16px;border-color:transparent;& .notion-page-icon{margin-top:6px}}& .notion-code{--sh-class:#f8f8f2;--sh-identifier:#50fa7b;--sh-sign:#ff79c6;--sh-string:#f1fa8c;--sh-keyword:#8be9fd;--sh-comment:#6272a4;--sh-jsxliterals:#bd93f9;--sh-property:#50fa7b;--sh-entity:#f8f8f2;background:rgba(33,31,32,1);padding:40px 32px;font-family:var(--font-mono);margin:16px 0}& .exec-code{margin:16px 0}& .exec-code__content{width:100%;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:24px}& .exec-code--full{width:calc(100dvw - 32px);align-self:center}& .exec-code__loading{min-height:240px;display:flex;align-items:center;font:var(--type-header-regular);color:var(--color-gray-500)}}.sketches__grid{--sketches-gap:8px;--sketches-block-padding:18px;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:var(--sketches-gap);margin-bottom:40px;justify-items:center}.sketches__block{max-width:380px;border-radius:18px;padding:var(--sketches-block-padding);background-color:var(--color-gray-100);font:var(--type-text-small);font-weight:400;color:var(--color-gray-800);margin-bottom:var(--sketches-gap)}@media (max-width:1024px){.sketches__grid{grid-template-columns:1fr}.sketches__left{order:2}}@media (max-width:640px){.sketches__block{max-width:100%}}.sketches__block:last-child{margin-bottom:0}.sketches__block--intro{font-family:var(--font-serif);font-style:italic}.sketches__block a{color:var(--color-accent-600);font-weight:600;text-decoration:none}.sketches__block a:hover{text-decoration:underline}.sketches__block p{margin:0}.sketches__block p+p{margin-top:12px}.sketches__info{padding-top:16px}.sketches__published{font:var(--type-text-x-small);font-weight:700;display:inline-flex;align-items:center;color:var(--color-gray-700);letter-spacing:.5px;background:white;padding:4px 12px;border-radius:12px}.sketches__published>svg{width:9px;transform:rotate(45deg);vertical-align:middle;margin-right:6px;padding-top:1px}.blog-posts__head{font:var(--type-text-medium);font-weight:600;margin:0 0 8px}.blog-posts__list{border-top:1px solid var(--color-gray-100)}.blog-posts__post{display:flex;flex-flow:row nowrap;align-items:flex-start;gap:0 28px;padding:16px 0;border-bottom:1px solid var(--color-gray-100);text-decoration:none;color:inherit}.blog-posts__post:hover>.blog-posts__title{text-decoration:underline}.blog-posts__title{flex:1 1}.blog-posts__date{min-width:100px;color:var(--color-gray-400)}.blog-posts__icon{rotate:-2deg;filter:drop-shadow(0 1px 4px rgba(0 0 0/.05));margin-top:2px;transition:all .2s ease}.blog-posts__post:hover .blog-posts__icon{rotate:2deg;scale:1.1;filter:drop-shadow(0 3px 6px rgba(0 0 0/.1))}@media (max-width:768px){.blog-posts__post{padding:10px 0}}._404__page-container{overflow:hidden;margin-top:-112px;margin-bottom:-32px}._404{padding:256px 0 320px;position:relative;height:calc(100vh - 176px);min-height:600px;--canvas-width:1600px;--dot-grid-step:64px}._404__title{font-size:80px;font-weight:900;margin-bottom:40px;text-align:center;text-shadow:0 6px 0 white,6px 0 0 white,-6px 0 0 white,0 -6px 0 white}@media (max-width:768px){._404__title{font-size:72px}}._404__subtitle{font:var(--type-text-medium);font-weight:500;text-align:center;max-width:400px;margin:0 auto;color:var(--color-gray-600);text-wrap:balance;text-shadow:0 1px 0 white,1px 0 0 white,-1px 0 0 white,0 -1px 0 white}._404__canvas-flex{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;justify-content:center}._404__message{position:relative;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}._404__canvas{background:url(/_next/static/media/polka-dot-pattern.1cfd81bd.svg) repeat 0 0/var(--dot-grid-step) var(--dot-grid-step);height:100%;flex-shrink:0;flex-basis:var(--canvas-width);position:relative;-webkit-mask-image:linear-gradient(90deg,black 75%,transparent),linear-gradient(270deg,black 75%,transparent),linear-gradient(180deg,black 85%,transparent),linear-gradient(0deg,black 85%,transparent);mask-image:linear-gradient(90deg,black 75%,transparent),linear-gradient(270deg,black 75%,transparent),linear-gradient(180deg,black 85%,transparent),linear-gradient(0deg,black 85%,transparent);-webkit-mask-composite:source-in,xor;mask-composite:intersect}.speaking-all{font:var(--type-text-small);color:var(--color-gray-900);padding-bottom:128px}.speaking-all__table{width:100%;border-collapse:collapse}.speaking-all__year{padding:14px 0;text-align:left;vertical-align:top;color:var(--color-gray-400);font-family:var(--font-mono);font-size:14px;font-weight:400}.speaking-all__talk-row:not(:last-of-type){border-bottom:1px solid var(--color-gray-150)}.speaking-all__title-cell{padding:14px 12px;vertical-align:top}.speaking-all__title-with-icon{margin-bottom:5px}.speaking-all__conference{color:var(--color-gray-500);margin-top:4px;font-weight:400}.speaking-all__date-cell{text-align:right;vertical-align:top;padding:14px 0;font-family:var(--font-mono);font-size:14px;color:var(--color-gray-400);white-space:nowrap;font-weight:400}.speaking-all__nav{display:flex;margin-bottom:20px}@media (max-width:768px){.speaking-all__nav{margin-bottom:12px}}.expand-inline{display:inline}.expand-inline span{display:inline-block;white-space:pre}.expand-inline__button{display:inline-flex;align-items:center;vertical-align:middle;color:var(--color-gray-400);border:none;border-radius:12px;padding:1px 10px 0;margin-left:2px;cursor:pointer;font-size:inherit;font:inherit;line-height:10px;font-weight:600;transition:box-shadow .15s ease;position:relative;top:-2px;-webkit-user-select:none;-moz-user-select:none;user-select:none;box-shadow:inset 0 0 0 1px var(--color-gray-200),inset 0 3px 1px 0 rgba(255,255,255,.8);background:linear-gradient(to bottom,var(--color-gray-100),var(--color-gray-200))}.expand-inline__button:active{transform:translateY(1px)}.expand-inline__button>svg{width:18px}.expand-inline__button:hover{color:var(--color-gray-600)}.expand-inline__button:active{transform:scale(.95);background:var(--color-gray-150);box-shadow:none}.expand-inline__button:focus-visible{box-shadow:0 0 0 2px red;border:inherit}.friends{margin-bottom:140px;padding:16px 0}.friends__header{font:var(--type-header-medium);letter-spacing:var(--type-ls-header);text-align:center;margin-bottom:6px}.friends__intro{font:var(--type-text-medium);color:var(--color-gray-500);text-align:center;max-width:600px;margin:0 auto 16px;text-wrap:balance}.friends__container{position:relative;padding:32px 16px}.friends__list{display:flex;flex-wrap:wrap;justify-content:center;gap:10px}.friends__item{background-color:var(--color-gray-100);border-radius:8px}.friends__item,.friends__item-inner{-webkit-user-select:none;-moz-user-select:none;user-select:none}.friends__item-inner{padding:0;position:relative;background-color:white;border:1px solid var(--color-gray-200);border-radius:8px;cursor:pointer;overflow:hidden;transition:border-color .2s ease,background-color .2s ease;box-shadow:0 1px 0 1px var(--color-gray-100);text-align:left;display:block;width:100%}.friends__item-content{display:flex;align-items:center;padding:6px;opacity:1}.friends__item--active .friends__item-content{opacity:0}.friends__avatar{flex-shrink:0;border-radius:4px;overflow:hidden}.friends__item-overlay{position:absolute;inset:0;pointer-events:none}.friends__info{margin-left:14px;margin-right:12px}.friends__website{font-family:var(--font-mono);font-size:13px;line-height:14px;margin-top:4px;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--color-gray-800)}.friends__item-inner:hover{background-color:var(--color-gray-100)}.friends__website--active{color:var(--color-blue-600)}.friends__name{font:var(--type-text-x-small);color:var(--color-gray-400)}.friends__overlay{position:absolute;inset:0;background-color:rgba(255,255,255,.7);z-index:10;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:flex-start;justify-content:center;padding-top:32px}.friends__modal{width:380px;background-color:white;box-shadow:0 4px 20px rgba(0,0,0,.1);border-radius:12px;z-index:20;margin:8px}.friends__modal>div{position:relative;padding:12px}.friends__close-button{position:absolute;top:10px;right:10px;width:28px;height:28px;display:flex;-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:50%;background-color:var(--color-gray-100);border:none;align-items:center;justify-content:center;cursor:pointer;color:inherit;transition:background-color .2s;padding:0;-webkit-tap-highlight-color:transparent}.friends__close-button:hover{background-color:var(--color-gray-200)}.friends__close-icon{width:16px;height:16px}.friends__modal-name{font:var(--type-text-regular);font-weight:500;margin-bottom:8px;padding:0 6px;display:flex;align-items:center;gap:10px}.friends__modal-avatar{flex-shrink:0;border-radius:2px;overflow:hidden;display:flex;align-items:center;justify-content:center}.friends__modal-bio{font:var(--type-text-small);color:var(--color-gray-600);margin-bottom:20px;padding:0 6px}.friends__website-button{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:5px;background-color:var(--color-gray-100);border-radius:8px;text-align:center;text-decoration:none;color:var(--color-gray-800);font-family:var(--font-mono);font-size:14px;text-transform:uppercase;transition:background-color .2s}.friends__button-icon{width:14px;height:14px}.friends__website-button:hover{background-color:var(--color-gray-200)}.friends__preview{background-color:var(--color-blue-100);padding:24px;border-radius:12px;box-shadow:0 4px 12px rgba(0,0,0,.08)}.friends__preview-website{font-size:14px;color:var(--color-blue-600);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:8px}.friends__preview-name{font-size:18px;font-weight:700;margin-bottom:8px}.friends__preview-bio{color:var(--color-gray-800);font:var(--type-text-small);line-height:1.5}@media (max-width:768px){.friends__intro{margin-bottom:32px;text-wrap:wrap}.friends{margin-bottom:48px}.friends__header{font:var(--type-header-medium);margin-bottom:8px}.friends__preview{padding:16px}}@media (max-width:480px){.friends__overlay{position:fixed;inset:0;align-items:center}.friends__item{width:100%}.friends__container{padding:16px 4px}}:root{--type-text-x-small:500 13px/22px var(--font-sans);--type-text-small:400 15px/24px var(--font-sans);--type-text-regular:400 17px/27px var(--font-sans);--type-text-medium:400 18px/28px var(--font-sans);--type-text-post:400 18px/29px var(--font-sans);--type-header-large:500 italic 42px/48px var(--font-serif);--type-header-medium:500 italic 39px/48px var(--font-serif);--type-header-regular:500 italic 28px/34px var(--font-serif);--type-ls-header:-0.03em;--color-gray-50:#f8f8fa;--color-gray-100:#f4f4f5;--color-gray-150:#ececee;--color-gray-200:#e4e4e7;--color-gray-300:#d4d4d8;--color-gray-400:#a1a1aa;--color-gray-500:#71717a;--color-gray-600:#52525b;--color-gray-700:#3f3f46;--color-gray-800:#262626;--color-gray-900:#18181b;--color-accent-200:#738efc;--color-accent-300:#5f7efc;--color-accent-400:#4b6efb;--color-accent-500:#2c57fb;--color-accent-600:#234efb;--color-accent-700:#0f3efa;--color-accent:#2c57fb;--color-accent-rgb:44,87,251;--main-container-width:768px}@media (max-width:768px){:root{--type-text-regular:400 17px/28px var(--font-sans);--type-text-post:400 18px/28px var(--font-sans);--type-header-large:500 italic 36px/39px var(--font-serif);--type-header-medium:500 italic 32px/38px var(--font-serif);--type-header-regular:500 italic 26px/32px var(--font-serif)}}h3{margin:0}body{font-family:var(--font-sans);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;font:var(--type-text-regular);color:var(--color-gray-900)}::selection{color:var(--color-gray-50);background-color:var(--color-accent)}