﻿@font-face{font-family:"Metropolis";font-style:normal;font-weight:300;font-display:block;src:url(/static/fonts/Metropolis-light.woff2) format("woff2")}@font-face{font-family:"Metropolis";font-style:normal;font-weight:400;font-display:block;src:url(/static/fonts/Metropolis-regular.woff2) format("woff2")}@font-face{font-family:"Metropolis";font-style:normal;font-weight:600;font-display:block;src:url(/static/fonts/Metropolis-semibold.woff2) format("woff2")}@font-face{font-family:"Metropolis";font-style:normal;font-weight:800;font-display:block;src:url(/static/fonts/Metropolis-medium.woff2) format("woff2")}:root{--font-family: "Metropolis", -apple-system, BlinkMacSystemFont, avenir next, avenir, segoe ui, helvetica neue, helvetica, Cantarell, Ubuntu, roboto, noto, arial, sans-serif;--content-width: 68rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 2rem;--spacing-xl: 3rem;--color-dark: #1E2A31;--color-ocean: #007AB8;--color-indigo: #1D428A;--color-white: #FFFFFF;--color-light-gray: #F7F7F7;--color-light-blue: #F4F8FA;--color-background: #FFF;--color-background-highlight: var(--color-light-blue);--color-background-inverse: var(--color-dark);--color-shadow: #d5e3ec;--color-borders: var(--color-light-gray);--color-action: var(--color-ocean);--color-highlight: var(--color-indigo);--color-text: #565656;--color-text-link: var(--color-indigo);--color-text-link-hover: var(--color-indigo);--color-text-heading: #000;--color-text-inverse: #FFF;--color-text-light: #6a737d;--color-sh-highlighted-background: #ccf0f7;--color-sh-inline-code-color: #7a3398;--color-sh-property-color: #a13cea;--color-sh-value-color: #217e10;--color-sh-variable-color: #a8560d;--color-sh-function-color: #c62764;--color-sh-important-color: #f72a57;--color-sh-diff-inserted: hsla(120deg 77% 60% / 20%);--color-sh-diff-deleted: hsla(350deg 79% 71% / 20%);--color-alert-info: #eef5ff;--color-alert-info-border: #99c6f7;--color-alert-warning: #ffeab9;--color-alert-warning-border: #f9cca3}html.dark{--color-background: var(--color-dark);--color-background-highlight: #00364d;--color-background-inverse: #4380B1;--color-borders: #374C5C;--color-action: #16AAF5;--color-highlight: var(--color-ocean);--color-text: #FFF;--color-text-link: #5cc8ff;--color-text-link-hover: #97c8ff;--color-text-heading: #FFF;--color-text-inverse: #D8E8F1;--color-text-light: #adbec2;--color-sh-inline-code-color: #d794f4;--color-sh-highlighted-background: #ccf0f7;--color-sh-property-color: #d790ff;--color-sh-value-color: #53c73f;--color-sh-variable-color: #ee9e2e;--color-sh-function-color: #ff82b2;--color-sh-important-color: #f72a57;--color-sh-diff-inserted: hsla(120deg 77% 60% / 20%);--color-sh-diff-deleted: hsla(350deg 79% 71% / 20%);--color-alert-info: #2b49a4;--color-alert-info-border: #5a74c2;--color-alert-warning: #8c5c29;--color-alert-warning-border: #bf893c}.header,.section,.footer{margin:0 auto;padding:0 var(--spacing-md)}.section{max-width:var(--content-width)}@media screen and (min-width: 68rem){.header,.section,.footer{padding:0}}.block{--block-title-color: var(--color-action);background-color:var(--block-background-color, var(--color-background));padding:var(--spacing-lg) 0}.block__title{text-transform:uppercase;letter-spacing:1px;font-size:1rem;margin-bottom:var(--spacing-md)}.block__title.block__title--big{text-transform:none;letter-spacing:normal;font-size:3rem;margin-bottom:var(--spacing-md)}.block--action{--block-title-color: var(--color-action);--block-background-color: var(--color-background-highlight)}.block--inverse{--block-title-color: var(--color-text-inverse);--block-background-color: var(--color-background-inverse)}@media screen and (min-width: 750px){.block{padding:var(--spacing-xl) 0}}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background-color:var(--color-background);color:var(--color-text);font-family:var(--font-family);transition:color .125s ease-in-out,background-color .125s ease-in-out}a{color:var(--color-text-link);transition:color .1s ease-in-out}a:hover{color:var(--color-text-link-hover)}h1,h2,h3,h4,h5,h6{color:var(--color-text-heading);font-weight:300;margin:.75em 0 .1em}h1{font-size:3.125rem}h2{font-size:2.5rem}h3{font-size:2rem}h4{font-size:1.5625rem}h5{font-size:1.25rem}h6{font-size:1.125rem}.button{align-items:center;gap:var(--spacing-md);display:inline-flex;background-color:var(--color-highlight);border-radius:3px;color:var(--color-text-inverse);border:1px solid var(--color-white);padding:var(--spacing-md) var(--spacing-lg);text-decoration:none;transition:all .125s ease-in-out;will-change:transform}.button:hover{color:var(--color-highlight);background-color:var(--color-background);border-color:var(--color-highlight)}.button:active{transform:translateY(2px)}.dark .button{background-color:var(--color-white);color:var(--color-indigo);border-color:var(--color-indigo)}.dark .button:hover{color:var(--color-white);background-color:var(--color-indigo);border-color:var(--color-white)}code[class*=language-],.post__content :not(pre)>code,.content :not(pre)>code,pre[class*=language-]{--sh-inline-code-color: var(--color-sh-inline-code-color, var(--color-highlight));--sh-inline-code-background: var(--color-sh-inline-code-background, var(--color-background-highlight));--sh-block-background: var(--color-sh-block-background, var(--color-background-highlight));--sh-base-color: var(--color-sh-base-color, var(--color-text));--sh-selected-color: var(--color-sh-selected-color, var(--color-highlight));--sh-highlighted-background: var(--color-sh-highlighted-background);--sh-highlighted-accent: var(--color-sh-highlighted-accent, var(--color-action));--sh-comment-color: var(--color-sh-comment-color, var(--color-text-light));--sh-property-color: var(--color-sh-property-color);--sh-value-color: var(--color-sh-value-color);--sh-operator-color: var(--color-sh-operator-color, var(--color-text));--sh-variable-color: var(--color-sh-variable-color);--sh-function-color: var(--color-sh-function-color);--sh-important-color: var(--color-sh-important-color);--sh-keyword-color: var(--color-sh-keyword-color, var(--color-action));color:var(--sh-base-color);font-family:Menlo,Consolas,Monaco,Liberation Mono,Lucida Console,monospace;white-space:pre;word-spacing:normal;word-wrap:normal;line-height:1.5;border:0;tab-size:2;hyphens:none}pre[class*=language-]{background:var(--sh-block-background);padding:var(--spacing-md);margin:var(--spacing-lg) 0;overflow:auto;border-radius:5px}.post__content :not(pre)>code,.content :not(pre)>code{background:var(--sh-inline-code-background);border-radius:8px;border:1px solid var(--color-borders);color:var(--sh-inline-code-color);font-size:1rem;line-height:inherit;padding:.1rem .25rem}.token.comment,.token.doctype,.token.cdata{color:var(--sh-comment-color)}.token.selector{color:var(--sh-selector-color)}.token.punctuation{color:var(--sh-comment-color)}.token.operator{color:var(--sh-operator-color)}.token.atrule,.token.attr-value,.token.hex,.token.string,.token.boolean,.token.regex,.token.number{color:var(--sh-value-color)}.token.property,.token.entity,.token.url,.token.attr-name,.token.keyword{color:var(--sh-property-color)}.token.function,.token.constant{color:var(--sh-function-color)}.token.variable{color:var(--sh-variable-color)}.token.important,.token.deliminator{color:var(--sh-important-color)}.token.deleted,.token.inserted{display:inline-block;margin-right:5px}.token.deleted{background-color:var(--color-sh-diff-deleted)}.token.inserted{background-color:var(--color-sh-diff-inserted)}.token.prefix.unchanged,.token.prefix.inserted,.token.prefix.deleted{user-select:none}.token.inserted:not(.prefix),.token.deleted:not(.prefix){display:block;width:calc(100% + 32px);position:relative;margin-right:0;left:-16px}.about__header{text-align:center;margin:5rem 0}.about__header h1{font-size:2rem}.about__content{max-width:72ch;margin:var(--spacing-lg) auto}.about__authors{text-align:center}.about__author{margin-top:var(--spacing-lg)}.about__author img{height:8rem;width:8rem;border-radius:50%}.about__author__info h3{font-size:1.3rem;margin-bottom:var(--spacing-sm)}.about__author__info p{margin-top:0}.about__author__info__bio{color:var(--color-text-light)}@media screen and (min-width: 750px){.about__header h1{font-size:4rem}.about__authors{text-align:left;margin-bottom:var(--spacing-xl)}.about__author{display:flex;align-items:top;gap:var(--spacing-lg)}.about__author__info h3{margin-top:0}}.alert{--alert-background: var(--color-alert-info);--alert-border: var(--color-alert-info-border);background-color:var(--alert-background);border:1px solid var(--alert-border);border-radius:5px;margin:var(--spacing-md) 0;padding:var(--spacing-md)}.alert.alert--warning{--alert-background: var(--color-alert-warning);--alert-border: var(--color-alert-warning-border)}.alert>*:first-child{margin-top:0}.alert>*:last-child{margin-bottom:0}.box{background-color:var(--color-background);box-shadow:5px 5px 10px -3px var(--color-shadow);text-decoration:none;color:var(--color-text);transition:background-color .125s ease-in-out,transform .125s ease-in-out;padding:var(--spacing-lg);margin-top:var(--spacing-sm);will-change:transform}.box:hover{box-shadow:5px 5px 10px -3px var(--color-text-link-hover);transform:translateY(-0.3rem)}.call-to-action{margin:var(--spacing-xl) var(--spacing-xl) calc(var(--spacing-xl) + 10px);text-align:center}.call-to-action a{display:inline-block;background-color:var(--color-action);color:var(--color-text-inverse);border:3px solid var(--color-action);padding:var(--spacing-md) var(--spacing-lg);box-shadow:10px 10px 0 0 var(--color-background-highlight);text-decoration:none;transition:all .125s ease-in-out;will-change:transform}.call-to-action a:hover{color:var(--text-color);background-color:var(--color-background);border-color:var(--color-highlight);transform:translateY(-0.3rem)}.content .call-to-action a{color:var(--color-text-inverse)}.community{margin:var(--spacing-lg) auto;text-align:center}.community__title{font-size:2rem}.community__list{list-style:none;padding:0;margin:var(--spacing-lg) 0 0}.community__list a{text-decoration:none;color:var(--color-heading);transform:color .125s ease-in-out}.community__list a:hover{color:var(--color-text-link-hover)}.community__list h3{font-size:1.25rem;margin-bottom:var(--spacing-sm)}.community__list p{color:var(--color-text-light)}.content{padding:0 var(--spacing-md);max-width:65ch;font-size:1.1rem;line-height:1.65;margin-left:auto;margin-right:auto}.content.content--wide{max-width:75ch;margin-left:0;margin-right:0}.content blockquote{font-size:1.3rem;margin:var(--spacing-xl);color:var(--color-text-light);position:relative}.content blockquote:before{content:"“";color:var(--color-shadow);font-size:12rem;position:absolute;top:calc(var(--spacing-md)*-6);left:calc(var(--spacing-md)*-3);z-index:-1;opacity:.5}.content img{display:block;margin:var(--spacing-lg) auto calc(var(--spacing-lg) + 10px);max-width:100%;padding:var(--spacing-md);border:1px solid var(--color-borders);box-shadow:5px 5px 10px -3px var(--color-shadow)}.content img[width][height]{height:auto}.content .table-wrapper{margin:var(--spacing-lg) 0;overflow:auto}.content .table-wrapper table{margin:0}.content table{border:1px solid var(--color-borders);margin:var(--spacing-lg) 0;width:100%}.content table td,.content table th{padding:var(--spacing-sm)}.content table tr td,.content table tr th{border-right:1px solid var(--color-borders);border-bottom:1px solid var(--color-borders)}.content table tr td:last-child,.content table tr th:last-child{border-right:0}.content table tbody tr:last-child td,.content table tbody tr:last-child th{border-bottom:0}.content table thead{font-size:1.2rem;text-align:left}.dark .content blockquote:before{opacity:.1}@media screen and (min-width: 960px){.content{padding:0}}@media screen and (min-width: 1080px){.content .table-wrapper{margin-left:calc(var(--spacing-lg)*-2);width:calc(100% + var(--spacing-lg)*4)}}.events{margin:0;padding:0;list-style:none}.events__upcoming{margin-top:3rem}.event{margin:2rem 0 4rem}.event__title{margin-top:0;font-size:2rem}.event__sessions{margin-top:2rem}.event a{color:var(--color-text);text-decoration:none}.event a:hover{color:var(--color-text-link-hover)}.event img{border-radius:50%;height:2.5rem;width:2.5rem}.event__meta span+span{color:var(--color-text-light);margin-left:var(--spacing-md)}.event .sessions__meta{display:flex;align-items:center;gap:var(--spacing-md)}.event .sessions__meta span+span{color:var(--color-text-light);margin-left:var(--spacing-md)}.event__meta{display:block}.event .sessions h3{margin-bottom:var(--spacing-sm)}.event .sessions>h3:first-child{margin-top:.1rem}.event .sessions__recording{margin:var(--spacing-md) 0}.event .sessions__recording__link{color:var(--color-text-light);display:flex;align-items:center;gap:var(--spacing-sm)}.event .sessions__recording__link svg{width:1.5rem;height:1.5rem}.event .sessions__meta{color:var(--color-text-light)}.event .sessions__meta span+img,.event .sessions__meta span+span{margin-left:var(--spacing-md)}@media screen and (min-width: 800px){.event{display:flex;gap:1rem}.event__content{width:40%}.event__sessions{width:60%;margin-top:0}}.follow{margin:7rem var(--spacing-xl);text-align:center;position:relative}.follow h3{margin-bottom:1em}.follow:before{background:radial-gradient(circle, var(--color-action) 0%, var(--color-background) 50%);position:absolute;content:"";height:20rem;width:20rem;left:50%;top:65%;opacity:.25;transform:translateX(-50%) translateY(-50%);z-index:-1}.footer{padding:var(--spacing-md) 0;color:var(--color-text-light);text-align:center;width:100%;position:relative}.footer:before{background-image:linear-gradient(to right, #6fbe2e 19%, #00bbd6 43%, #0f61a9 57%, #5a39a0 81%);content:"";height:6px;position:absolute;top:-6px;left:0;width:100%}.footer__content{margin:0 auto}.footer__logo{position:relative}.footer__logo svg{margin:1rem 0;height:50px}.footer__links{border-top:1px solid var(--color-shadow)}.footer a,.footer a:visited{color:var(--color-text-light);transition:color .125s ease-in-out;text-decoration:none}.footer a:hover{color:var(--color-action)}.footer__social{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);margin:var(--spacing-md) 0 0}.footer__social svg{color:var(--color-text-link);width:22px}@media screen and (min-width: 750px){.footer{text-align:left}.footer__logo svg{height:50px}.footer__copy{max-width:35%}.footer__content{max-width:var(--content-width);width:100%}.footer__links{align-items:flex-start;justify-content:flex-start;display:flex;gap:var(--spacing-md);text-align:left}.footer__social{align-items:center;justify-content:flex-end;margin-left:auto;margin-top:1rem}.footer__social a:first-child{margin-left:var(--spacing-sm)}}.header{padding:var(--spacing-sm) var(--spacing-sm) var(--spacing-md) var(--spacing-sm);position:relative;width:100%}.header__content{margin:0 auto;max-width:var(--content-width)}.header:after{background-image:linear-gradient(to right, #6fbe2e 19%, #00bbd6 43%, #0f61a9 57%, #5a39a0 81%);content:"";height:6px;position:absolute;bottom:-6px;left:0;width:100%}.header__home{font-size:1.5rem;font-weight:300;margin:0}.header__home a{align-items:center;display:flex;flex-wrap:wrap;justify-content:center}.header__home svg{height:40px;margin:1.2rem 1.5rem 0 0}.header a{text-decoration:none;color:var(--color-text)}.header__nav ul{align-items:center;margin:0;padding:0;display:flex;flex-wrap:wrap;justify-content:center;list-style:none}.header__nav li{margin-top:var(--spacing-sm);margin-left:var(--spacing-md)}.header__nav li a{padding:0 var(--spacing-sm)}.header__nav li a:hover{color:var(--color-text-link-hover)}@media screen and (min-width: 850px){.header__content{display:flex;align-items:center;justify-content:space-between;text-align:left;max-width:var(--content-width);width:100%}.header__home{font-size:1.9rem}.header__home svg{height:40px;margin:1.25rem 1.5rem 0 0}.header__nav ul{margin:0;flex-wrap:nowrap;justify-content:flex-end}.header__nav li{margin-top:0}}@media screen and (min-width: 68rem){.header{padding:var(--spacing-sm) 0 var(--spacing-md)}.header__nav{position:relative;top:6px}}.hero{margin:var(--spacing-xl) var(--spacing-md)}.hero__illustration{text-align:center}.hero__illustration img{margin:0 0 calc(var(--spacing-lg)*-1);max-width:100%;position:relative;z-index:-1}.hero__content{background-color:var(--color-background);padding:var(--spacing-lg);box-shadow:5px 5px 15px -3px var(--color-shadow);z-index:10;line-height:1.65}.hero__content p:last-child{margin-bottom:0}.hero__content h2{margin-top:0;font-size:2rem}@media screen and (min-width: 750px){.hero{display:grid;margin:4rem 4rem 5rem 4rem;justify-content:center;grid-template-rows:12rem 10rem 1fr}.hero__illustration{grid-row:1/3;grid-column:1/3}.hero__illustration img{margin:0;max-width:100%;position:relative;left:-20px}.hero__content{grid-row:2/4;grid-column:2/4}}@media screen and (min-width: 1050px){.hero{grid-template-columns:25rem 10rem 25rem}.hero__illustration img{margin:0;max-width:120%;position:relative;left:-60px}}.list-article{margin-bottom:var(--spacing-lg)}.list-article h3{margin-bottom:var(--spacing-sm)}.list-article a{color:var(--color-heading);text-decoration:none}.list-article a:hover{color:var(--color-text-link-hover)}.list-article img{border-radius:50%;height:2.5rem;width:2.5rem}.list-article__meta{display:flex;align-items:center;gap:var(--spacing-md)}.list-article__meta span+span{color:var(--color-text-light);margin-left:var(--spacing-md)}.list-projects{display:grid;gap:var(--spacing-lg);grid-template-columns:1fr;margin-bottom:var(--spacing-lg)}.list-projects .list-project{width:100%}.list-projects .list-project h3{margin-top:0}.list-projects .list-project h3 a{color:var(--color-heading);text-decoration:none;transition:color .125s ease-in-out}.list-projects .list-project h3 a:hover{color:var(--color-text-light-hover)}.list-projects .list-project p{margin-bottom:0}.list-projects .list-project__links{margin-top:var(--spacing-md);display:flex;gap:var(--spacing-sm)}.list-projects .list-project__links a,.list-projects .list-project__links a:visited{padding:var(--spacing-xs);color:var(--color-text-light);transition:color .125s ease-in-out}.list-projects .list-project__links a:hover{color:var(--color-highlight)}@media screen and (min-width: 500px){.list-projects{grid-template-columns:repeat(2, 1fr)}}@media screen and (min-width: 750px){.list-projects{grid-template-columns:repeat(3, 1fr)}}.post__header{text-align:center;padding-bottom:var(--spacing-lg)}.post__header h2{font-size:2.5rem;margin-bottom:var(--spacing-md)}.post__header__meta{color:var(--color-text-light);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md)}.post__header__author{display:flex;align-items:center;gap:var(--spacing-sm)}.post__header__author img{border-radius:50%;height:2rem;width:2rem}.post__content{margin:var(--spacing-xl) auto 0}.post__footer{font-size:1.1rem;margin:0 auto var(--spacing-md);padding:var(--spacing-md);max-width:65ch}.post__authors{flex:1}.post__author__content{display:flex;align-items:center;gap:var(--spacing-md)}.post__author__content img{border-radius:50%;height:5rem;width:5rem}.post__author__info{flex:1 1 auto}.post__author__info h3{margin:0 0 var(--spacing-sm);font-size:1.1rem}.post__author__info p{margin-bottom:0;font-size:1rem}.post__author+.post__author{margin-top:var(--spacing-md)}.post__share{margin-top:var(--spacing-lg)}.post__share a{border:2px solid var(--color-borders);border-radius:10px;display:inline-block;padding:var(--spacing-sm) var(--spacing-md);text-decoration:none;color:var(--color-text);margin-bottom:var(--spacing-sm);transition:color .125s ease-in-out,border-color .125s ease-in-out}.post__share a:hover{border-color:var(--color-highlight);color:var(--color-highlight)}.post__share a+.post__share a{margin-left:var(--spacing-sm)}@media screen and (min-width: 650px){.post__header h2{font-size:3.5rem}.post__header__meta{flex-direction:row;gap:var(--spacing-xl)}.post__footer{align-items:flex-start;display:flex;justify-content:flex-start;padding:var(--spacing-lg) 0}.post__share{margin-top:0}}.project__header{margin-top:var(--spacing-lg);margin-bottom:var(--spacing-lg);text-align:center}.project__header__screenshot{aspect-ratio:auto 1320/1040;width:100%}.project__header__title{margin:var(--spacing-xl) 0 .5rem;font-size:3rem}.project__header__tagline{margin-top:0;color:var(--color-text-light);font-size:1.5rem}@media screen and (min-width: 1000px){.project__header{display:grid;grid-template-columns:minmax(0, 1fr) minmax(0, 660px);grid-template-rows:1fr;text-align:left}.project__header__block{display:flex;flex-direction:column;justify-content:center}.project__main{display:grid;grid-template-columns:300px minmax(0, 1fr);gap:calc(1.5*var(--spacing-xl))}}.projects__list{list-style:none;padding-left:0;margin-top:var(--spacing-lg)}.projects__item{margin-bottom:var(--spacing-lg)}.projects__item article{display:grid;grid-template-columns:1fr;grid-template-rows:minmax(0, 1fr) auto;gap:var(--spacing-sm)}.projects__item a{text-decoration:none;color:var(--color-text)}.projects__item__screenshot{max-width:100%}@media screen and (min-width: 750px){.projects__item article{grid-template-columns:minmax(0, 260px) 1fr;grid-template-rows:1fr;gap:var(--spacing-lg)}}.theme-button{color:var(--color-text);background:rgba(0,0,0,0);border:0;cursor:pointer;height:1.7rem;padding:0}.theme-button__dark{display:none}html.dark .theme-button__light{display:none}html.dark .theme-button__dark{display:block}
