:root{--gap:24px;--content-gap:10px;--nav-width:1024px;--main-width:720px;--header-height:60px;--footer-height:60px;--radius:8px;--theme:rgb(255, 255, 255);--entry:rgb(255, 255, 255);--primary:rgb(30, 30, 30);--secondary:rgb(108, 108, 108);--tertiary:rgb(214, 214, 214);--content:rgb(31, 31, 31);--hljs-bg:rgb(28, 29, 33);--code-bg:rgb(245, 245, 245);--border:rgb(238, 238, 238);--color-primary:#00c9b5;--color-secondary:#ff6e30;--font-gray:#8f8f8f}.dark{--theme:rgb(29, 30, 32);--entry:rgb(46, 46, 51);--primary:rgb(218, 218, 219);--secondary:rgb(155, 156, 157);--tertiary:rgb(65, 66, 68);--content:rgb(196, 196, 197);--hljs-bg:rgb(46, 46, 51);--code-bg:rgb(55, 56, 62);--border:rgb(51, 51, 51)}.dark.list{background:var(--theme)}*,::after,::before{box-sizing:border-box}html{-webkit-tap-highlight-color:transparent;overflow-y:scroll}a,button,body,h1,h2,h3,h4,h5,h6{color:var(--primary)}body{font-family:-apple-system,BlinkMacSystemFont,segoe ui,Roboto,Oxygen,Ubuntu,Cantarell,open sans,helvetica neue,sans-serif;font-size:18px;line-height:1.6;word-break:break-word;background:var(--theme)}article,aside,figcaption,figure,footer,header,hgroup,main,nav,section,table{display:block}h1,h2,h3,h4,h5,h6{line-height:1.2}h1,h2,h3,h4,h5,h6,p{margin-top:0;margin-bottom:0}ul{padding:0}a{text-decoration:none}body,figure,ul{margin:0}table{width:100%;border-collapse:collapse;border-spacing:0;overflow-x:auto;word-break:keep-all}button,input,textarea{padding:0;font:inherit;background:0 0;border:0}input,textarea{outline:0}button,input[type=button],input[type=submit]{cursor:pointer}input:-webkit-autofill,textarea:-webkit-autofill{box-shadow:0 0 0 50px var(--theme)inset}img{display:block;max-width:100%}::-webkit-scrollbar-track{background:0 0}.list:not(.dark)::-webkit-scrollbar-track{background:var(--code-bg)}::-webkit-scrollbar-thumb{background:var(--tertiary);border:5px solid var(--theme);border-radius:var(--radius)}.list:not(.dark)::-webkit-scrollbar-thumb{border:5px solid var(--code-bg)}::-webkit-scrollbar-thumb:hover{background:var(--secondary)}.not-found{position:absolute;left:0;right:0;display:flex;align-items:center;justify-content:center;height:80%;font-size:160px;font-weight:700}.archive-posts{width:100%;font-size:16px}.archive-year{margin-top:40px}.archive-year:not(:last-of-type){border-bottom:2px solid var(--border)}.archive-month{display:flex;align-items:flex-start;padding:10px 0}.archive-month-header{margin:25px 0;width:200px}.archive-month:not(:last-of-type){border-bottom:1px solid var(--border)}.archive-entry{position:relative;padding:5px;margin:10px 0}.archive-entry-title{margin:5px 0;font-weight:400}.archive-count,.archive-meta{color:var(--secondary);font-size:14px}.footer,.top-link{font-size:12px;color:var(--secondary)}.footer{max-width:calc(var(--main-width) + var(--gap) * 2);margin:0 auto;padding:calc((var(--footer-height) - var(--gap))/2)var(--gap);text-align:center;line-height:24px}.footer span{margin-inline-start:1px;margin-inline-end:1px}.footer span:last-child{display:block;font-size:10px;white-space:nowrap}.footer a{color:inherit;border-bottom:1px solid var(--secondary)}.footer a:hover{border-bottom:1px solid var(--primary)}.top-link{visibility:hidden;position:fixed;bottom:60px;right:30px;z-index:99;background:var(--tertiary);width:42px;height:42px;padding:12px;border-radius:64px;transition:visibility .5s,opacity .8s linear}.top-link,.top-link svg{filter:drop-shadow(0 0 0 var(--theme))}.footer a:hover,.top-link:hover{color:var(--primary)}.top-link:focus,#theme-toggle:focus{outline:0}header.header{border-bottom:1px solid var(--border);padding:0 1em}.nav{display:flex;flex-wrap:wrap;justify-content:space-between;max-width:calc(var(--nav-width) + var(--gap) * 2);margin:.5em auto}.nav>div{display:flex}.nav a{display:block}.logo,#menu{display:flex;margin:auto var(--gap)}.logo{flex-wrap:inherit;margin-left:0}.logo a{font-size:24px;font-weight:700;white-space:nowrap}.logo a img{display:inline;vertical-align:middle;pointer-events:none;transform:translate(0,-10%);border-radius:6px;margin-inline-end:8px}#theme-toggle svg{height:18px}button#theme-toggle{font-size:26px;margin:auto 4px}body.dark #moon{vertical-align:middle;display:none}body:not(.dark) #sun{display:none}#menu{list-style:none;word-break:keep-all;white-space:nowrap}#menu li+li{margin-inline-start:var(--gap)}#menu a{font-size:16px}.lang-switch li,.lang-switch ul,.logo-switches{display:inline-flex;margin:auto 4px}.menu-link{cursor:pointer;font-size:16px;position:relative;white-space:nowrap;color:var(--color-text)}.menu-link::before,.menu-link::after{position:absolute;width:100%;height:1px;background:var(--color-primary);top:100%;left:0;pointer-events:none}.menu-link::before{content:''}.menu-link{text-transform:lowercase}.menu-link::before{transform-origin:100% 50%;transform:scale3d(0,3,0);transition:transform .3s}.menu-link:hover::before{transform-origin:0% 50%;transform:scale3d(1,3,1)}.menu-link.active::before,.menu-link.active::after{transform-origin:0% 50%;transform:scale3d(1,3,1);background:var(--color-secondary)}body{display:flex;flex-direction:column;height:100vh;min-height:100vh;font-family:poppins,sans-serif}.main{position:relative;flex:1;max-width:calc(var(--main-width) + var(--gap) * 2);width:100%;margin:auto;padding:var(--gap);display:flex;flex-direction:column}.page-header{width:100%}.page-header h1{font-size:50px;position:relative}.pagination{display:flex}.pagination .button{pointer-events:auto;cursor:pointer;border:none;padding:.5rem 1rem;margin:0;font-family:inherit;font-size:inherit;position:relative;display:inline-block;color:#fff;background:0 0}.pagination .button::before,.pagination .button::after{position:absolute;top:0;left:0;width:100%;height:100%}.pagination .button span{display:block;color:#faf9f6;position:relative;z-index:1;transition:transform .4s cubic-bezier(.2,1,.8,1)}.pagination .button::before{content:'';background:var(--color-primary);-webkit-clip-path:polygon(0% 0%,100% 0,100% 50%,100% 100%,0% 100%);clip-path:polygon(0% 0%,100% 0,100% 50%,100% 100%,0% 100%);transition:clip-path .4s cubic-bezier(.2,1,.8,1),-webkit-clip-path .4s cubic-bezier(.2,1,.8,1)}.pagination .button:hover::before{background:var(--color-secondary);-webkit-clip-path:polygon(0% 0%,75% 0%,100% 50%,75% 100%,0% 100%);clip-path:polygon(0% 0%,75% 0%,100% 50%,75% 100%,0% 100%)}.pagination .button.prev::before{transform:rotate(180deg)}.pagination .button.prev:hover span{transform:translate3d(10px,0,0)}.pagination .button.next:hover span{transform:translate3d(-10px,0,0)}.pagination .next{margin-inline-start:auto}.social-icons{margin-top:.5em}.social-icons a:not(:last-of-type){margin-inline-end:12px}.social-icons a svg{height:26px;width:26px}code{direction:ltr}div.highlight,pre{position:relative}.copy-code{display:none;position:absolute;top:4px;right:4px;color:rgba(255,255,255,.8);background:rgba(78,78,78,.8);border-radius:var(--radius);padding:0 5px;font-size:14px;user-select:none}div.highlight:hover .copy-code,pre:hover .copy-code{display:block}.date{color:var(--secondary);font-size:.8em}.subtitle{font-size:1.5em}.first-entry{position:relative;display:flex;flex-direction:column;justify-content:center;min-height:320px;margin:var(--gap)0 calc(var(--gap) * 2)}.first-entry .entry-header{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3}.first-entry .entry-header h1{font-size:34px;line-height:1.3}.first-entry .entry-content{margin:14px 0;font-size:16px;-webkit-line-clamp:3}.first-entry .entry-footer{font-size:14px}.home-info .entry-content{-webkit-line-clamp:unset}.post-entry{position:relative;margin-bottom:var(--gap);padding:var(--gap)0;transition:transform,background-color .1s;border-bottom:1px solid var(--border)}.post-entry:active{transform:scale(.98)}.post-entry .subtitle:hover{text-decoration:underline}.tag-entry .entry-cover{display:none}.entry-header h2{font-size:16px}.entry-content{margin:8px 0;color:var(--secondary);font-size:16px;line-height:1.6;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:4}.entry-footer{color:var(--secondary);font-size:13px}.entry-cover,.entry-isdraft{font-size:14px;color:var(--secondary)}.entry-cover{margin-bottom:var(--gap);text-align:center}.entry-cover img{border-radius:var(--radius);pointer-events:none;width:100%;height:auto}.entry-cover a{color:var(--secondary);box-shadow:0 1px 0 var(--primary)}a .page-header,.post-header{margin:24px auto var(--content-gap)}.post-title{margin-bottom:20px;font-size:40px}.post-description{margin-top:10px;margin-bottom:5px;font-size:.85em}.post-meta,.breadcrumbs{color:var(--secondary);font-size:14px;display:flex;flex-wrap:wrap}.post-meta .i18n_list li{display:inline-flex;list-style:none;margin:auto 3px;box-shadow:0 1px 0 var(--secondary)}.breadcrumbs a{font-size:16px}.post-content{color:var(--content);font-size:16px;font-family:ui-sans-serif,-apple-system,BlinkMacSystemFont,segoe ui,Helvetica,apple color emoji,Arial,sans-serif,segoe ui emoji,segoe ui symbol}.post-content h3,.post-content h4,.post-content h5,.post-content h6{margin:24px 0 16px}.post-content h1{margin:40px auto 32px;font-size:40px}.post-content h2{margin:25px auto 10px;font-size:26px}.post-content h3{font-size:22px}.post-content h4{font-size:16px}.post-content h5{font-size:14px}.post-content h6{font-size:12px}.post-content del{text-decoration:none;background:linear-gradient(to right,var(--primary) 100%,transparent 0)0/1px 1px repeat-x}.post-content dl,.post-content ol,.post-content p,.post-content figure,.post-content ul{margin-bottom:var(--content-gap)}.post-content ol,.post-content ul{padding-inline-start:20px}.post-content li{margin-top:5px}.post-content li p{margin-bottom:0}.post-content dl{display:flex;flex-wrap:wrap;margin:0}.post-content dt{width:25%;font-weight:700}.post-content dd{width:75%;margin-inline-start:0;padding-inline-start:10px}.post-content dd~dd,.post-content dt~dt{margin-top:10px}.post-content table{margin-bottom:32px}.post-content table th,.post-content table:not(.highlighttable,.highlight table,.gist .highlight) td{min-width:80px;padding:12px 8px;line-height:1.5;border-bottom:1px solid var(--border)}.post-content table th{font-size:14px;text-align:start}.post-content table:not(.highlighttable) td code:only-child{margin:auto 0}.post-content .highlight table{border-radius:var(--radius)}.post-content .highlight:not(table),.post-content pre{margin:10px auto;background:var(--hljs-bg)!important;border-radius:var(--radius)}.post-content li>.highlight{margin-inline-end:0}.post-content ul pre{margin-inline-start:calc(var(--gap) * -2)}.post-content .highlight pre{margin:0}.post-content .highlighttable{table-layout:fixed}.post-content .highlighttable td:first-child{width:40px}.post-content .highlighttable td .linenodiv{padding-inline-end:0!important}.post-content .highlighttable td .highlight,.post-content .highlighttable td .linenodiv pre{margin-bottom:0}.post-content .highlighttable td .highlight pre code::-webkit-scrollbar{display:none}.post-content code{margin:auto 4px;padding:2px 6px;font-size:.95em;line-height:1.5;background:var(--code-bg);border-radius:4px;color:#eb5757;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;white-space:pre}.post-content pre code{display:block;margin:auto 0;padding:10px;color:#d5d5d6;background:#1f2937;border-radius:5px;overflow-x:auto;word-break:break-all;font-size:13px}.post-content blockquote{margin:20px 0;padding:0 14px;border-inline-start:3px solid #ccc}.post-content hr{margin:30px 0;height:1px;background:var(--tertiary);border-top:0;border-bottom:0}.post-content iframe{max-width:100%}.post-content img{border-radius:4px;margin:0 auto}.post-content figure.align-center{text-align:center}.toc{margin:0 2px 40px;border:1px solid var(--border);background:var(--code-bg);border-radius:var(--radius);padding:.4em}.dark .toc{background:var(--entry)}.toc details summary{cursor:zoom-in;margin-inline-start:20px}.toc details[open] summary{cursor:zoom-out}.toc .details{display:inline;font-weight:500}.toc .inner{margin:0 20px;padding:10px 20px}.toc li ul{margin-inline-start:var(--gap)}.toc summary:focus{outline:0}.post-footer{margin-bottom:40px}.post-tags{margin-top:1rem}.post-tags li{display:inline-block;margin-inline-end:3px;margin-bottom:5px}.paginav{color:var(--color-primary)}.post-tags a{display:block;color:var(--color-primary);text-decoration:underline}.post-tags a:hover,.paginav a:hover{color:var(--color-secondary);text-decoration:underline}.share-buttons{margin:14px 0;display:flex;justify-content:flex-start;align-items:center;overflow-x:auto}.share-buttons a{margin-top:10px}.share-buttons a:not(:last-of-type){margin-inline-end:12px}.share-buttons a svg{height:30px;width:30px;fill:currentColor;transition:transform .1s}.share-buttons svg:active{transform:scale(.98)}h1:hover .anchor,h2:hover .anchor,h3:hover .anchor,h4:hover .anchor,h5:hover .anchor,h6:hover .anchor{display:inline-flex;color:var(--secondary);margin-inline-start:8px;font-weight:500;user-select:none}.post-content :not(table) ::-webkit-scrollbar-thumb{border:2px solid var(--hljs-bg);background:#717175}.post-content :not(table) ::-webkit-scrollbar-thumb:hover{background:#a3a3a5}.gist table::-webkit-scrollbar-thumb{border:2px solid #fff;background:#adadad}.gist table::-webkit-scrollbar-thumb:hover{background:#707070}.post-content table::-webkit-scrollbar-thumb{border-width:2px}.paginav{margin:10px 0;display:flex;line-height:30px;border-radius:var(--radius)}.paginav a{padding-inline-start:14px;padding-inline-end:14px;border-radius:var(--radius)}.paginav .title{letter-spacing:1px;text-transform:uppercase;font-size:small;color:var(--secondary)}.paginav .prev,.paginav .next{width:50%}.paginav span:hover:not(.title){box-shadow:0 1px}.paginav .next{margin-inline-start:auto;text-align:right}[dir=rtl] .paginav .next{text-align:left}.column-list{display:flex;justify-content:space-between;gap:1em;margin:1em 0}.column{}@media all and (max-width:600px){.column{width:100%!important;padding:0}.column-list{flex-direction:column}}.callout{border-radius:3px;padding:1rem}.callout.block-color-gray_background{background:#f1f1ef}.dark .callout{background:rgba(241,241,239,.5);color:#fff}.icon{display:inline-block;max-width:1.2em;text-decoration:none;vertical-align:text-bottom;margin-right:.5em}img.icon{border-radius:3px}figure{margin:0 0 1.25em;page-break-inside:avoid}figcaption{opacity:.5;font-size:85%;margin-top:.5em;max-width:100%;width:100%;white-space:pre-wrap;word-break:break-word;caret-color:#37352f;font-size:14px;line-height:1.4;color:rgba(55,53,47,.65);padding-top:6px;padding-bottom:6px;padding-left:2px;margin-top:-5px}.dark figcaption{color:#fff}iframe{width:100%;min-height:500px;border:0}ul.bulleted-list{margin-bottom:0}.post-content table th,.post-content table:not(.highlighttable,.highlight table,.gist .highlight) td{padding:0!important;border-bottom:none;width:30px;min-width:30px}.hljs-ln-n{font-size:.9em;color:#6b7280}table.hljs-ln{margin:0}.post-content video{width:100%}.profile_container{display:flex;justify-content:center;padding:1em;margin-top:5em}.profile_inner{max-width:calc(var(--nav-width) + var(--gap) * 2)}.container{display:flex;justify-content:space-between}.container div{flex:1}.profile-text{font-size:1.1em}.profile-text .headline{font-size:1.3em;margin-bottom:1em}.profile-text .headline strong{font-size:1.5em}.profile-text .social-icons a svg{width:34px;height:34px}.profile-text a.link{font-weight:400}.profile-photo{display:flex;justify-content:center;align-items:flex-start;overflow:hidden}.profile-photo img{max-width:500px;object-fit:cover;mask-image:url(/assets/blob.svg);mask-size:cover;-webkit-mask-image:url(/assets/blob.svg);-webkit-mask-size:cover}@media screen and (max-width:510px){.profile-photo img{max-width:350px}}@media screen and (max-width:360px){.profile-photo img{max-width:250px}}h1{font-size:4em}.link,.post-content a{color:var(--color-primary);font-weight:500;text-decoration:underline}.link:hover,.post-content a:hover{color:var(--color-secondary);text-decoration:underline}.divider{width:80px;height:4px;border-radius:10px;background:var(--color-secondary);margin:3em 0 .5em}#searchbox input{padding:4px 10px;width:100%;color:var(--primary);font-weight:700;border:2px solid var(--tertiary);border-radius:var(--radius)}#searchbox input:focus{border-color:var(--secondary)}#searchResults li{list-style:none;border-radius:var(--radius);padding:10px;margin:10px 0;position:relative;font-weight:500}#searchResults{margin:10px 0;width:100%}#searchResults li:active{transition:transform .1s;transform:scale(.98)}#searchResults a{position:absolute;width:100%;height:100%;top:0;left:0;outline:none}#searchResults .focus{transform:scale(.98);border:2px solid var(--tertiary)}.hljs-comment,.hljs-quote{color:#9ca3af}.hljs-deletion,.hljs-name,.hljs-regexp,.hljs-selector-class,.hljs-selector-id,.hljs-tag,.hljs-template-variable,.hljs-variable{color:#eb3c54}.hljs-built_in,.hljs-builtin-name,.hljs-link,.hljs-literal,.hljs-meta,.hljs-number,.hljs-params,.hljs-type{color:#e7ce56}.hljs-attribute{color:#ee7c2b}.hljs-addition,.hljs-bullet,.hljs-string,.hljs-symbol{color:#86efac}.hljs-section,.hljs-title{color:#7dd3fc}.hljs-keyword,.hljs-selector-tag{color:#5eead4}.hljs{display:block;overflow-x:auto;background:#1c1d21;color:#c0c5ce;padding:.5em}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}@media screen and (max-width:768px){:root{--gap:14px}.profile img{transform:scale(.85)}.first-entry{min-height:260px}.archive-month{flex-direction:column}.archive-year{margin-top:20px}.footer{padding:calc((var(--footer-height) - var(--gap) - 10px)/2)var(--gap)}}@media screen and (min-width:768px){::-webkit-scrollbar{width:19px;height:11px}}@media screen and (max-width:900px){.list .top-link{transform:translateY(-5rem)}}@media(prefers-reduced-motion){.button:active,.share-buttons svg:active,.post-entry:active,.top-link,#searchResults .focus,#searchResults li:active{transform:none}}.about-me{margin-top:var(--gap)}.public-speaking{margin:2em 0}.public-speaking .subtitle{margin-bottom:.5em}.public-speaking ul{padding-left:1.5em}.public-speaking div{margin:3em 0;font-size:.9em;font-style:italic}.public-speaking span.note{font-size:.8em}.technology{color:var(--color-primary);font-weight:500}@media screen and (max-width:950px){.profile_inner .container{flex-direction:column;flex-flow:column-reverse}.profile_container{margin-top:0}}@media screen and (max-width:500px){.page-header h1,.post-title{font-size:30px}.subtitle{font-size:1.2em!important}.work-section .description,.testimonial-container blockquote,.about-me,.entry-content,.post-content,.profile-text{font-size:.9em!important}.work-section .technologies{font-size:.8em!important}.contact-container{font-size:1.1em!important}.references{height:30px!important}.references.smaller{height:20px!important}.references-container div img{margin:.5rem!important}.references-container{margin:1rem 0!important}.testimonial-container{margin-top:4.5em!important}.testimonial-container blockquote{margin:0}.testimonial-container blockquote:before{top:-70px!important;left:-3px!important}}@media screen and (max-width:460px){.nav>div{flex-direction:column}#menu{margin:.5em 0}}.work-section{margin:var(--gap)0}.work-section .technologies{font-size:.8em;color:var(--font-gray)}.work-section .subtitle{display:flex;align-items:center;margin-bottom:.3em}.work-section .subtitle a small{font-weight:400;font-size:.7rem;font-style:italic}.work-section .company-icon{width:40px;margin-right:.3em;border-radius:5px}.work-section .location{font-size:.8em;margin-bottom:.3em}.work-section .description{font-size:.9em}.references-container{margin:2em 0;background:#fff;padding:.5em 0}.references{filter:grayscale(1);opacity:.3;height:50px}.references.smaller{height:30px}.references-container h3{text-align:center;font-size:1em;color:#000;font-weight:400;margin-bottom:.5em}.testimonial-container{margin:2em 0}.references-container div{text-align:center}.references-container div img{display:inline-block;margin:1rem}.testimonial-container blockquote{font-size:1em;font-weight:400;font-style:italic;font-family:roboto serif,serif;position:relative;text-align:justify}.testimonial-container blockquote:before{content:'“';position:absolute;top:-45px;left:-45px;font-size:5em}.testimonial-container .author{font-size:.85em;text-align:center;font-style:italic;color:var(--font-gray)}.contact-container{text-align:center;font-size:1.5em;margin:1em 0 3em}.project-section{margin-top:1.5em}.project-section svg{width:28px;margin-right:.3em}.project-section .technologies{font-size:.8em;color:var(--font-gray)}.project-section .subtitle{display:flex;align-items:center;font-size:1.2em;margin-bottom:.3em}.project-section .subtitle a:hover{text-decoration:underline}.project-section .description{font-size:.9em}.project-section .date{font-size:.5em;margin-left:.5em;font-style:italic}.project-section .view-github{display:flex;align-items:center;font-size:.7em;width:fit-content}.project-section .view-github a{text-decoration:underline}.project-section .view-github:hover a{text-decoration:none;color:var(--color-secondary)}