html{-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}body,button,h1,h2,h3,li,p,ul{margin:0;padding:0}code{font-size:1em;font-weight:400;font-style:normal}*,:after,:before{-webkit-box-sizing:border-box;box-sizing:border-box}img{border:0}article,footer,header,main,nav,section{display:block}button{background:0 0;border:0;-webkit-box-sizing:border-box;box-sizing:border-box;color:inherit;cursor:pointer;font:inherit;line-height:inherit;overflow:visible;vertical-align:inherit}a,button{-ms-touch-action:manipulation;touch-action:manipulation}:root{--black:#0c0d0d;--blue:#2d79b4;--blue-dark:#1069ad;--blue-light:#73d6ff;--aqua:#73ffe1;--background:#f9f9fb;--border:#efefef}html{font-size:62.5%}body{background:var(--background);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol;font-size:1.6rem}@media screen and (max-device-width:720px){html{-webkit-tap-highlight-color:rgba(0,0,0,.5)}body{-webkit-text-size-adjust:none}}h1,h2,h3{font-weight:600;line-height:1.5}h1{font-size:3.6rem;line-height:1.15}h2{font-size:2.4rem;margin-bottom:1.6rem}h3,p{font-size:1.8rem}p{line-height:1.5;margin-bottom:2.4rem;text-rendering:optimizeLegibility;max-width:64rem}a{color:var(--blue);text-decoration:none;-webkit-transition:color .2s ease;transition:color .2s ease}a:hover{color:var(--blue-dark)}.site-header{background:var(--black);width:100%}.site-title{margin-bottom:0}.site-title img{max-width:100%;height:auto;width:6rem}.logo-sm{display:none}.site-header .wrapper{width:100%;max-width:140rem;margin:0 auto;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;-webkit-box-align:center;-ms-flex-align:center;align-items:center;padding:1.2rem 2.4rem;overflow:hidden}.nav,.site-header .wrapper{display:-webkit-box;display:-ms-flexbox;display:flex}.nav{text-align:center}.nav li{display:-webkit-box;display:-ms-flexbox;display:flex}.nav li a{display:inline-block;color:#fff;margin-left:4rem;font-size:1.8rem;-ms-flex-item-align:center;align-self:center}.nav li a:hover{color:var(--blue-light)}.submit{width:36px}.submit svg{width:100%;height:auto}.submit svg circle{-webkit-transition:fill .2s ease;transition:fill .2s ease}.submit:hover svg circle{fill:var(--blue-light)}.submit span{display:none}.nav li a.ds-active{color:var(--aqua)}.pull{display:none;text-indent:-9999px}.post-header{width:100%;margin:0 auto 8rem;background:#fff;border-bottom:1px solid var(--border)}body,html{height:100%}body{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.footer-wrap{-ms-flex-negative:0;flex-shrink:0}.post-head-wrap{max-width:104rem;width:100%;padding:8rem 2.4rem 6rem;margin:0 auto;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;-ms-flex-line-pack:start;align-content:flex-start}.home-secondary-wrap{background:#fff;border:1px solid var(--border)}.home-secondary{display:grid;grid-gap:4rem;grid-template-columns:repeat(auto-fit,minmax(18rem,1fr));max-width:140rem;width:100%;padding:0 2.4rem;margin:0 auto}.secondary-tile{display:-webkit-box;display:-ms-flexbox;display:flex;padding:6rem 2.4rem;border-left:1px solid var(--border);border-right:1px solid var(--border);-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start}.secondary-tile:first-child,.secondary-tile:last-child{border-right:0;border-left:0}.secondary-tile-img{width:48px;height:48px;margin-right:2rem;margin-top:6px}.secondary-tile img{width:100%;height:auto}.secondary-tile h2{color:var(--black);margin-bottom:.4rem;-webkit-transition:color .2s ease;transition:color .2s ease}.secondary-tile p{font-size:1.4rem;color:var(--black)}.secondary-tile h2 span{display:inline-block;-webkit-transition:-webkit-transform .2s ease;transition:-webkit-transform .2s ease;transition:transform .2s ease;transition:transform .2s ease,-webkit-transform .2s ease}.secondary-tile:hover h2{color:var(--blue-light)}.secondary-tile:hover h2 span{-webkit-transform:translateX(3px);transform:translateX(3px)}.page-about-wrap{max-width:104rem;width:100%;padding:0 2.4rem 6rem;margin:0 auto;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;-ms-flex-line-pack:start;align-content:flex-start}.about-connect{width:30rem;padding-left:4rem}.about-connect ul{list-style-type:none}.about-connect li a{margin-bottom:1.6rem;padding-bottom:1.6rem;border-bottom:1px solid #e3e4e8;display:block}.about-connect svg{width:1.6rem;height:1.6rem;margin-right:4px;position:relative;top:2px}.about-connect path{fill:#787c80}.about-connect .twitter:hover path{fill:#1da1f2}.about-connect .github:hover path{fill:var(--black)}.about-connect .dribbble:hover path{fill:#ea4c89}.illustration{width:22rem;height:auto;margin-left:4rem}.post-content{display:grid;grid-gap:4rem;grid-template-columns:repeat(auto-fill,minmax(40rem,1fr));grid-column-gap:4rem;grid-auto-rows:1fr;max-width:140rem;width:100%;padding:0 2.4rem;margin:0 auto 9.6rem}.post-books .post-content{grid-template-columns:repeat(auto-fill,minmax(24rem,1fr))}.post-content.content-ds{margin-bottom:10rem}.post-content.content-articles,.post-content.content-ds{grid-gap:2.4rem;grid-template-columns:18rem repeat(auto-fill,minmax(28rem,1fr))}h1.post-title{margin-bottom:2rem}.block{border-radius:6px;background:#fff;-webkit-box-shadow:0 1px 1px 1px rgba(10,16,34,.08);box-shadow:0 1px 1px 1px rgba(10,16,34,.08);color:var(--black);cursor:pointer;position:relative;-webkit-transition:-webkit-transform .2s ease,-webkit-box-shadow .2s ease;transition:-webkit-transform .2s ease,-webkit-box-shadow .2s ease;transition:transform .2s ease,box-shadow .2s ease;transition:transform .2s ease,box-shadow .2s ease,-webkit-transform .2s ease,-webkit-box-shadow .2s ease}.block:hover{-webkit-box-shadow:0 16px 32px 0 rgba(10,16,34,.2),0 0 0 transparent;box-shadow:0 16px 32px 0 rgba(10,16,34,.2),0 0 0 transparent;-webkit-transform:translateY(-5px) translateZ(0);transform:translateY(-5px) translateZ(0)}.content-ds .title{background-image:-webkit-gradient(linear,left top,left bottom,from(#b973ff),to(#804bb5));background-image:linear-gradient(-180deg,#b973ff,#804bb5)}.content-articles .title{background-image:-webkit-gradient(linear,left top,left bottom,from(var(--blue-light)),to(#028bcc));background-image:linear-gradient(-180deg,var(--blue-light),#028bcc)}.block-talks,.content-articles .block-home .content,.post-articles .content,.post-talks .content{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;height:100%}.post-articles .clamp,.post-talks .clamp{-webkit-box-flex:1;-ms-flex:1;flex:1}.date{opacity:.8;font-size:1.3rem;padding-top:1.2rem;margin-top:2rem;border-top:1px solid #e4e4eb}.button{background:var(--aqua);display:inline-block;padding:.8rem 1.4rem;border-radius:6px;font-weight:600;opacity:1;cursor:pointer;-webkit-transition:background .2s ease;transition:background .2s ease}.title:hover .button{background:#53e9c9}.title h1{color:#fff;line-height:1.1;margin:2rem 0;font-size:2.4rem}.block.block-home h2{font-size:1.8rem;margin-bottom:0;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1}.block.block-home .content{padding:2rem 2.4rem}.block.title img{max-width:6.4rem}.block:focus,.block:hover{color:var(--black)}.block img{border-radius:6px 6px 0 0;width:100%;height:auto;-webkit-backface-visibility:hidden;backface-visibility:hidden}.block .content{padding:2.4rem 2.8rem 3.2rem}.block p{margin:0;font-size:1.4rem;line-height:1.65;opacity:.85}.block h2{font-size:2.2rem;font-weight:600;margin-bottom:1.6rem}.block h3{font-size:1.4rem;font-weight:400;font-family:monospace;text-transform:uppercase;margin:0 0 .6rem;opacity:.72;letter-spacing:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.img-wrap{border-radius:6px 6px 0 0;height:auto;display:block;border-bottom:1px solid #f1f1f1;line-height:0;-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-mask-image:-webkit-radial-gradient(#fff,#000);mask-image:-webkit-radial-gradient(#fff,#000)}.filter,.img-wrap{width:100%;text-align:center}.filter{max-width:140rem;padding:0 2.4rem;margin:-3.2rem auto 6rem}.filter li{display:inline-block;margin-right:4px}.filter a.active{background:#804bb5;color:#fff;-webkit-box-shadow:none;box-shadow:none}.filter li a{background:#fff;border-radius:4px;-webkit-box-shadow:0 2px 10px 0 rgba(0,0,0,.05);box-shadow:0 2px 10px 0 rgba(0,0,0,.05);color:var(--black);display:block;display:inline-block;font-size:1.3rem;padding:1rem;min-width:12rem;position:relative;text-align:center;text-decoration:none;margin-bottom:4px}.filter li:last-child{margin-right:0}.footer-wrap{display:block;background:var(--black);overflow:hidden}.footer-border{height:6px;background-image:-webkit-gradient(linear,left top,right top,from(#b973ff),color-stop(24%,var(--blue-light)),color-stop(50%,#61dac8),color-stop(77%,var(--blue-light)),to(#b973ff));background-image:linear-gradient(90deg,#b973ff 0,var(--blue-light) 24%,#61dac8 50%,var(--blue-light) 77%,#b973ff);display:block;background-size:100% auto}.footer{max-width:140rem;width:100%;padding:4rem 2.4rem;margin:0 auto;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;-ms-flex-line-pack:start;align-content:flex-start}.footer span{color:#919696}.footer span a{color:var(--aqua);padding-right:4px}.number{margin-left:4px;opacity:.85}@media only screen and (max-width:1199px){.post-content.content-articles,.post-content.content-ds{grid-template-columns:18rem repeat(auto-fit,minmax(21rem,1fr))}}@media only screen and (min-width:720px) and (max-width:959px){html{font-size:59%}.nav li a{margin-left:2.4rem}.nav li:last-child a{margin-left:4rem}.post-content.content-articles,.post-content.content-ds{grid-template-columns:repeat(auto-fill,minmax(32rem,1fr))}.post-content{display:grid;grid-gap:2.4rem;grid-template-columns:repeat(auto-fill,minmax(30rem,1fr))}.secondary-tile{display:block}.secondary-tile-img{margin-bottom:.8rem}}@media only screen and (max-width:719px){html{font-size:57%}.site-header{position:fixed;z-index:100}.post-content.content-articles,.post-content.content-ds{grid-template-columns:repeat(auto-fill,minmax(24rem,1fr));margin-bottom:4rem}.post-content{display:grid;grid-gap:2.4rem;grid-template-columns:repeat(auto-fill,minmax(30rem,1fr))}.site-title img{width:12rem;line-height:0}.logo-lg{display:none}.logo-sm{display:inline-block}.submit{width:100%}.submit span,.submit svg{display:inline-block}.submit svg{width:16px;height:16px;margin-left:12px}.site-header .wrapper{display:block;padding:0}.header-inner{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.site-title{float:left;padding-left:2.4rem}.responsive-nav{position:relative}.pull{display:block;float:right;margin:0;background:0 0;border:none;padding:3.2rem 2.4rem;-webkit-transition:all .24s ease;transition:all .24s ease;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;outline:0}.lines{width:28px;position:relative}.lines,.lines:after,.lines:before{display:block;height:3px;background:#fff;-webkit-transition:all .24s ease;transition:all .24s ease}.lines:after,.lines:before{width:24px;position:absolute;right:0;content:"";-webkit-transform:translateZ(0);transform:translateZ(0);-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-transform-origin:3rem center;transform-origin:3rem center}.lines:before{top:8px}.lines:after{top:-8px}.lines-button.close .lines{background:0 0}.lines-button.close .lines:after,.lines-button.close .lines:before{top:0;width:20px;-webkit-transform-origin:50% 50%;transform-origin:50% 50%}.lines-button.close .lines:before{-webkit-transform:rotate(45deg);transform:rotate(45deg)}.lines-button.close .lines:after{-webkit-transform:rotate(-45deg);transform:rotate(-45deg)}.navHidden{display:none}.nav{text-align:left;padding-top:2.4rem;clear:both;width:100%;height:100vh;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-transition:opacity 3s ease-in;transition:opacity 3s ease-in;opacity:1}.nav li{border-bottom:1px solid hsla(0,0%,100%,.07);padding:0}.nav li,.nav li a{display:block;margin:0}.nav li a{padding:2rem 2.4rem;font-size:2.4rem;color:#fff}.post-title{text-align:center}.post-home .post-title{font-size:2.4rem}.post-head-wrap{-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;padding:12rem 2.4rem 2.4rem;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.post-header{margin:0 auto 4rem}.illustration{-webkit-box-ordinal-group:0;-ms-flex-order:-1;order:-1;width:14rem;margin-bottom:2.4rem;margin-left:auto;margin-right:auto}.filter{margin:0 auto 1.2rem;white-space:nowrap;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:1rem;width:100%;-webkit-transform:translateZ(0);transform:translateZ(0)}.page-about-wrap{display:block}.about-connect,.about-credits{display:block;margin:0 auto;width:100%;max-width:64rem;padding-left:0}.about-credits{margin-bottom:4rem}.home-secondary{display:block;padding-bottom:2rem}.secondary-tile{display:-webkit-box;display:-ms-flexbox;display:flex;padding:2rem 0;border-left:0;border-right:0;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start}.secondary-tile:first-child{border-bottom:1px solid var(--border)}.secondary-tile:last-child{border-top:1px solid var(--border)}}@media only screen and (max-width:576px){.block,.post-content{display:block}.block{margin-bottom:2.4rem;width:100%}.footer,.footer span{display:block}.footer span{margin:0 auto;text-align:center}.footer span.coffee{margin-top:2.4rem}}.fade-enter-active[data-v-4017f15c]{-webkit-transition:opacity .5s;transition:opacity .5s}.fade-enter[data-v-4017f15c]{opacity:0}