html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;font-size:100%;font:inherit;vertical-align:baseline}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}body{line-height:1}ol,ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:'';content:none}table{border-collapse:collapse;border-spacing:0}.highlight .hll{background-color:#ffc}.highlight .c{color:#999988;font-style:italic}.highlight .err{color:#a61717;background-color:#e3d2d2}.highlight .k{color:#000000;font-weight:bold}.highlight .o{color:#000000;font-weight:bold}.highlight .cm{color:#999988;font-style:italic}.highlight .cp{color:#999999;font-weight:bold;font-style:italic}.highlight .c1{color:#999988;font-style:italic}.highlight .cs{color:#999999;font-weight:bold;font-style:italic}.highlight .gd{color:#000000;background-color:#fdd}.highlight .ge{color:#000000;font-style:italic}.highlight .gr{color:#a00}.highlight .gh{color:#999}.highlight .gi{color:#000000;background-color:#dfd}.highlight .go{color:#888}.highlight .gp{color:#555}.highlight .gs{font-weight:bold}.highlight .gu{color:#aaa}.highlight .gt{color:#a00}.highlight .kc{color:#000000;font-weight:bold}.highlight .kd{color:#000000;font-weight:bold}.highlight .kn{color:#000000;font-weight:bold}.highlight .kp{color:#000000;font-weight:bold}.highlight .kr{color:#000000;font-weight:bold}.highlight .kt{color:#445588;font-weight:bold}.highlight .m{color:#099}.highlight .s{color:#d01040}.highlight .na{color:teal}.highlight .nb{color:#0086B3}.highlight .nc{color:#445588;font-weight:bold}.highlight .no{color:teal}.highlight .nd{color:#3c5d5d;font-weight:bold}.highlight .ni{color:purple}.highlight .ne{color:#990000;font-weight:bold}.highlight .nf{color:#990000;font-weight:bold}.highlight .nl{color:#990000;font-weight:bold}.highlight .nn{color:#555}.highlight .nt{color:navy}.highlight .nv{color:teal}.highlight .ow{color:#000000;font-weight:bold}.highlight .w{color:#bbb}.highlight .mf{color:#099}.highlight .mh{color:#099}.highlight .mi{color:#099}.highlight .mo{color:#099}.highlight .sb{color:#d01040}.highlight .sc{color:#d01040}.highlight .sd{color:#d01040}.highlight .s2{color:#d01040}.highlight .se{color:#d01040}.highlight .sh{color:#d01040}.highlight .si{color:#d01040}.highlight .sx{color:#d01040}.highlight .sr{color:#009926}.highlight .s1{color:#d01040}.highlight .ss{color:#990073}.highlight .bp{color:#999}.highlight .vc{color:teal}.highlight .vg{color:teal}.highlight .vi{color:teal}.highlight .il{color:#099}body,blockquote cite{color:#404040;font-family:'Roboto', sans-serif;font-size:16px;line-height:1.4}blockquote,.callout{color:#6b6b6b;font-size:24px;line-height:1.3}h1,h2,.logotype .name,.article-list-item-heading,h3{font-weight:700;line-height:1.2}h1 a,h2 a,.logotype .name a,.article-list-item-heading a,h3 a{text-decoration:none}h1{font-size:40px}h2,.logotype .name,.article-list-item-heading{font-size:32px}h3{font-size:24px}.small,.nerds{font-size:12px}body{background-color:#fff}h1,h2,h3{margin-bottom:1rem}p{margin-bottom:1rem}em{font-style:italic}strong{font-weight:700}a{color:#004080}a:hover{color:#006bd6}ul,ol{margin-bottom:1rem}ul li,ol li{margin-bottom:0.3rem}ul li:last-of-type,ol li:last-of-type{margin-bottom:0}ul{list-style:disc inside}ol{list-style:decimal inside}pre{background-color:#f1f1f1;color:#969696;font-family:'Inconsolata', monospace;margin:2rem 0;overflow-x:auto;padding:1rem}.highlight{margin-bottom:2rem}code{background-color:#f1f1f1;font-family:'Inconsolata', monospace}blockquote{border-left:0.5rem solid #2e96ff;margin:2rem;padding-left:1rem}blockquote cite{display:block;font-style:italic;margin-top:0.3rem;text-align:right}blockquote cite:before{content:'\2014'}hr{border:0;border-top:1px solid #dbdbdb;height:0;margin:2rem 0}*,*:before,*:after{box-sizing:border-box}body{background-color:#fff;display:flex;flex-direction:column;font-size:16px;min-height:100vh}img{max-width:100%}figure{margin-bottom:1rem}figure figcaption{color:#6b6b6b;font-style:italic}.container{flex:1;margin:0 2rem;width:calc(100% - (2rem * 2));max-width:760px}@media screen and (min-width: 824px){.container{margin-left:auto;margin-right:auto}}@font-face{font-family:'Stackicons';src:url(data:application/font-woff;charset=utf-8;base64,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) format("woff");font-style:normal;font-weight:normal}.icon-linkedin:after{content:'\e25f';font-family:'Stackicons'}.icon-instagram:after{content:'\e226';font-family:'Stackicons'}.icon-github:after{content:'\e186';font-family:'Stackicons'}.icon-codepen:after{content:'\e106';font-family:'Stackicons'}.icon-twitter:after{content:'\e036';font-family:'Stackicons'}.icon-mail:after{content:'\e04f';font-family:'Stackicons'}.icon-group .icon-text{clip:rect(0 0 0 0);overflow:hidden;position:absolute;height:1px;width:1px}.header-footer-container{margin:0 auto;max-width:1200px}.header{border-top:15px solid #004080;padding:2rem;position:relative}.header:before,.header:after{content:'';position:absolute;left:0;right:0}.header:before{border-top:10px solid #006bd6;top:-10px}.header:after{border-top:5px solid #2e96ff;top:-5px}.logotype{color:#404040;line-height:1;text-decoration:none}.logotype:hover{color:#404040}.logotype .logo{height:40px}.footer{background-color:#dbdbdb;margin-top:4rem;overflow:hidden;padding:2rem}.footer .header-footer-container{display:flex;flex-direction:column}@media screen and (min-width: 570px){.footer .header-footer-container{align-items:center;flex-direction:row;justify-content:space-between}}.social-links{list-style:none;margin-bottom:1rem;margin-left:-0.3rem}@media screen and (min-width: 570px){.social-links{margin-bottom:0}}.social-link{float:left;margin:0 0.3rem}.social-link .icon-group{font-size:32px;text-decoration:none}.colophon{text-align:right}.copyright{display:block}.nerds{font-style:italic}.content-section{display:flex;flex-direction:column;margin-bottom:2rem}@media screen and (min-width: 640px){.content-section{flex-direction:row}}.content-sidebar{flex:1 1;text-align:center}@media screen and (min-width: 640px){.content-sidebar{flex:1 0;text-align:right}}.content-thumbnail{margin:0 2rem 2rem}@media screen and (min-width: 640px){.content-thumbnail{margin-left:0}}.content{flex:1 1}.content *:last-child{margin-bottom:0}@media screen and (min-width: 640px){.content{flex:2 0}}.content.no-sidebar{max-width:100%;padding:0}@media screen and (min-width: 640px){.content.no-sidebar{padding-left:252px}}@media screen and (min-width: 820px){.content.no-sidebar{padding-left:calc(100% / 3)}}.article-list-item{margin-bottom:2rem}.article-list-item-heading{margin-bottom:0.3rem}.home-content{margin-top:4rem}@media screen and (min-width: 640px){.home-content{margin-top:10rem}}.home-content .article-list{margin-top:2rem}.codepen{margin-bottom:1rem}.speaker-deck{margin:2rem auto;max-width:100%}.pattern-section-heading{font-size:1em;background-color:#2e96ff;color:#fff;margin:2rem 0;padding:0.3rem;text-transform:uppercase}.swatch-sample.brand-color-1{background-color:#004080}.swatch-sample.brand-color-2{background-color:#006bd6}.swatch-sample.brand-color-3{background-color:#2e96ff}.swatch-sample.black{background-color:#404040}.swatch-sample.grey-1{background-color:#6b6b6b}.swatch-sample.grey-2{background-color:#969696}.swatch-sample.grey-3{background-color:#dbdbdb}.swatch-sample.grey-4{background-color:#f1f1f1}.swatch-sample.white{background-color:#fff}.swatch{display:inline-block;margin-right:0.3rem;width:115px}.swatch figcaption{font-style:normal}.swatch-sample{height:100px;width:100px}
