article,aside,details,figcaption,figure,footer,header,hgroup,main,nav,section,summary{display:block}audio,canvas,video{display:inline-block}audio:not([controls]){display:none;height:0}[hidden],template{display:none}html{font-family:sans-serif;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}body{margin:0}a{background:0 0}a:focus{outline:thin dotted}a:active,a:hover{outline:0}h1{font-size:2em;margin:.67em 0}abbr[title]{border-bottom:1px dotted}b,strong{font-weight:700}dfn{font-style:italic}hr{-moz-box-sizing:content-box;box-sizing:content-box;height:0}mark{background:#ff0;color:#000}code,kbd,pre,samp{font-family:monospace,serif;font-size:1em}pre{white-space:pre-wrap}q{quotes:"\201C" "\201D" "\2018" "\2019"}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sup{top:-.5em}sub{bottom:-.25em}img{border:0}svg:not(:root){overflow:hidden}figure{margin:0}fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em}legend{border:0;padding:0}button,input,select,textarea{font-family:inherit;font-size:100%;margin:0}button,input{line-height:normal}button,select{text-transform:none}button,html input[type=button],input[type=reset],input[type=submit]{-webkit-appearance:button;cursor:pointer}button[disabled],html input[disabled]{cursor:default}input[type=checkbox],input[type=radio]{box-sizing:border-box;padding:0}input[type=search]{-webkit-appearance:textfield;-moz-box-sizing:content-box;-webkit-box-sizing:content-box;box-sizing:content-box}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0}textarea{overflow:auto;vertical-align:top}table{border-collapse:collapse;border-spacing:0}@font-face{font-family:extra-icons;src:url(../fonts/extra-icons.eot);src:url(../fonts/extra-icons.eot?#iefix) format("embedded-opentype"),url(../fonts/extra-icons.woff) format("woff"),url(../fonts/extra-icons.ttf) format("truetype"),url(../fonts/extra-icons.svg#extra-icons) format("svg");font-weight:400;font-style:normal}.iconx-spin:before,.iconx-twitter:before,.iconx-github:before,.iconx-mail:before,.iconx-hire:before{font-family:extra-icons;speak:none;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;line-height:1;text-decoration:none;opacity:.9;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.iconx-spin:before{content:'\e800';animation:spin 1.5s infinite linear;-webkit-animation:spin 1.5s infinite linear}.iconx-twitter:before{content:'\e801';font-size:1.2rem;line-height:.8}.iconx-github:before{content:'\e802'}.iconx-mail:before{content:'\e803'}.iconx-hire:before{content:'\e804'}@keyframes spin{from{transform:rotate(360deg)}to{transform:rotate(0deg)}}@-webkit-keyframes spin{from{transform:rotate(360deg)}to{transform:rotate(0deg)}}::selection{background:#26bced;color:#fafafa;text-shadow:none}::-moz-selection{background:#26bced;color:#fafafa;text-shadow:none}html{font-size:14px}body{font-family:fira sans,sans-serif;font-weight:300;margin:0;background:#fafafa;color:#333}strong,b{font-weight:500}a{text-decoration:none;color:inherit}header,h1,h2,h3,h4,h5,h6{font-family:raleway,sans-serif;font-weight:100;color:#26bced;text-rendering:optimizeLegibility;line-height:1;margin-top:0}h1{font-weight:300;font-size:5rem}h2{font-size:4rem}h3{font-size:3rem}h4,h5,h6{font-size:2rem}section{max-width:960px;margin:auto}a{color:#26bced;outline:none;transition:color ease .3s}a:hover,a:focus{color:#053342;transition:color .3s ease-in-out}p,ul,ol,dl{margin:1.6rem 0;font-size:1.28rem;line-height:1.6}ol ol,ul ul,ul ol,ol ul{margin:.4rem 0}li{list-style-position:inside}nav{margin:2rem auto}nav ul{margin:0;padding:0}nav li{display:inline-block}dl dt{float:left;width:180px;overflow:hidden;clear:left;text-align:right;text-overflow:ellipsis;white-space:nowrap;font-weight:700;margin-bottom:1rem}dl dd{margin-left:200px;margin-bottom:1rem}hr{display:block;height:1px;border:0;border-top:1px solid #ccc;margin:3.2rem 0;padding:0}blockquote{-moz-box-sizing:border-box;box-sizing:border-box;margin:1.6rem 0 1.6rem -2.2rem;padding:0 0 0 1.6rem;border-left:#ccc .4rem solid}blockquote p{margin:.8rem 0;font-style:italic}blockquote small{display:inline-block;margin:.8em 0 .8em 1.5em;font-size:.9em;color:#ccc}blockquote small:before{content:"— "}blockquote cite{font-weight:700}blockquote cite a{font-weight:400}mark{background-color:#ffc336}abbr{cursor:help}pre,code,tt,kbd{font-family:fira mono,sans-serif;padding:0 3px;white-space:pre-wrap;border:1px solid #ccc;background:#f4f4f4;border-radius:2px;font-size:1.2rem}pre{-moz-box-sizing:border-box;box-sizing:border-box;margin:1.6em 0;border:1px solid #333;background:#23241f;width:100%;padding:10px;white-space:pre;overflow:auto;border-radius:3px}pre code,tt{color:#f8f8f2;white-space:-moz-pre-wrap;white-space:pre-wrap;background:0 0;border:none;padding:0}kbd{display:inline-block;margin-bottom:.4em;padding:0;width:3rem;height:3rem;line-height:3rem;text-align:center;border:#ccc 1px solid;color:#666;text-shadow:#fff 0 1px 0;font-weight:700;background:#f4f4f4;border-radius:4px;text-transform:uppercase;box-shadow:0 1px 0 rgba(0,0,0,.2),0 1px 0 0 #fff inset}table{-moz-box-sizing:border-box;box-sizing:border-box;margin:1.6em 0;width:100%;max-width:100%;background-color:transparent}table th,table td{padding:8px;line-height:20px;text-align:left;vertical-align:top;border-top:1px solid #efefef}table th{color:#000}table caption+thead tr:first-child th,table caption+thead tr:first-child td,table colgroup+thead tr:first-child th,table colgroup+thead tr:first-child td,table thead:first-child tr:first-child th,table thead:first-child tr:first-child td{border-top:0}table tbody+tbody{border-top:2px solid #efefef}table table table{background-color:#fff}table tbody>tr:nth-child(odd)>td,table tbody>tr:nth-child(odd)>th{background-color:#f6f6f6}table.plain tbody>tr:nth-child(odd)>td,table.plain tbody>tr:nth-child(odd)>th{background:0 0}iframe,.fluid-width-video-wrapper{display:block;margin:1.6em 0}.fluid-width-video-wrapper iframe{margin:0}.highlighter-rouge{overflow-x:auto;-webkit-text-size-adjust:none;background:#241f1f;margin:2rem 0}.highlighter-rouge pre{padding:.5em;display:block;margin:0}.highlighter-rouge span,.highlighter-rouge .hljs-tag,.highlighter-rouge .css .hljs-rules,.highlighter-rouge .css .hljs-value,.highlighter-rouge .css .hljs-function .hljs-preprocessor,.highlighter-rouge .hljs-pragma{color:#f8f8f2}.highlighter-rouge .hljs-strongemphasis,.highlighter-rouge .hljs-strong,.highlighter-rouge .hljs-emphasis{color:#a8a8a2}.highlighter-rouge .hljs-bullet,.highlighter-rouge .hljs-blockquote,.highlighter-rouge .hljs-horizontal_rule,.highlighter-rouge .mi,.highlighter-rouge .hljs-regexp,.highlighter-rouge .kc,.highlighter-rouge .hljs-hexcolor{color:#ae81ff}.highlighter-rouge .hljs-tag .hljs-value,.highlighter-rouge .hljs-code,.highlighter-rouge .css .hljs-class,.highlighter-rouge .hljs-class .hljs-title:last-child{color:#a6e22e}.highlighter-rouge .hljs-link_url{font-size:80%}.highlighter-rouge .hljs-strong,.highlighter-rouge .hljs-strongemphasis{font-weight:700}.highlighter-rouge .hljs-emphasis,.highlighter-rouge .hljs-strongemphasis,.highlighter-rouge .hljs-class .hljs-title:last-child{font-style:italic}.highlighter-rouge .o,.highlighter-rouge .k,.highlighter-rouge .kd,.highlighter-rouge .kr,.highlighter-rouge .hljs-function,.highlighter-rouge .hljs-change,.highlighter-rouge .hljs-winutils,.highlighter-rouge .hljs-flow,.highlighter-rouge .nginx .hljs-title,.highlighter-rouge .tex .hljs-special,.highlighter-rouge .hljs-header,.highlighter-rouge .hljs-attribute,.highlighter-rouge .hljs-symbol,.highlighter-rouge .hljs-symbol .hljs-string,.highlighter-rouge .hljs-tag .hljs-title,.highlighter-rouge .hljs-value,.highlighter-rouge .alias .hljs-keyword:first-child,.highlighter-rouge .css .hljs-tag,.highlighter-rouge .css .unit,.highlighter-rouge .css .hljs-important{color:#f92672}.highlighter-rouge .nb{color:#66d9ef}.highlighter-rouge .hljs-variable,.highlighter-rouge .hljs-params,.highlighter-rouge .hljs-class .hljs-title{color:#f8f8f2}.highlighter-rouge .s1,.highlighter-rouge .css .hljs-id,.highlighter-rouge .hljs-subst,.highlighter-rouge .hljs-type,.highlighter-rouge .ruby .hljs-class .hljs-parent,.highlighter-rouge .django .hljs-template_tag,.highlighter-rouge .django .hljs-variable,.highlighter-rouge .smalltalk .hljs-class,.highlighter-rouge .django .hljs-filter .hljs-argument,.highlighter-rouge .smalltalk .hljs-localvars,.highlighter-rouge .smalltalk .hljs-array,.highlighter-rouge .hljs-attr_selector,.highlighter-rouge .hljs-pseudo,.highlighter-rouge .hljs-addition,.highlighter-rouge .hljs-stream,.highlighter-rouge .hljs-envvar,.highlighter-rouge .apache .hljs-tag,.highlighter-rouge .apache .hljs-cbracket,.highlighter-rouge .tex .hljs-command,.highlighter-rouge .hljs-prompt,.highlighter-rouge .hljs-link_label,.highlighter-rouge .hljs-link_url{color:#e6db74}.highlighter-rouge .c1,.highlighter-rouge .cm,.highlighter-rouge .hljs-javadoc,.highlighter-rouge .hljs-annotation,.highlighter-rouge .hljs-decorator,.highlighter-rouge .hljs-template_comment,.highlighter-rouge .hljs-pi,.highlighter-rouge .hljs-doctype,.highlighter-rouge .hljs-deletion,.highlighter-rouge .hljs-shebang,.highlighter-rouge .apache .hljs-sqbracket,.highlighter-rouge .tex .hljs-formula{color:#75715e}.highlighter-rouge .coffeescript .javascript,.highlighter-rouge .javascript .xml,.highlighter-rouge .tex .hljs-formula,.highlighter-rouge .xml .javascript,.highlighter-rouge .xml .vbscript,.highlighter-rouge .xml .css,.highlighter-rouge .xml .hljs-cdata,.highlighter-rouge .xml .php,.highlighter-rouge .php .xml{opacity:.5}body{margin-bottom:9rem}header[role=banner]{background:#26bced;padding:calc(13rem + 32px) 0 5rem;margin-top:-32px;height:5rem;text-align:center;color:#fff;margin-bottom:4rem}header[role=banner] a,header[role=banner] h1,header[role=banner] h2,header[role=banner] h3,header[role=banner] h4,header[role=banner] h5,header[role=banner] h6{color:#fff}header[role=banner] a:hover,header[role=banner] a:focus{color:#fff;opacity:.5}header[role=banner] h1{margin:0}header[role=banner] h3{font-size:2.7rem}.content[role=main]{max-width:900px;margin:1rem auto}.post{position:relative;width:80%;margin:3rem auto;padding-bottom:3rem;border-bottom:#ccc 1px solid;word-break:break-word;hyphens:auto}.post-title{margin:0}.post-title a{text-decoration:none}.post-excerpt p{margin:1.6rem 0 0;line-height:1.6rem}.post-meta{display:inline-block;margin:0 0 5px;font-size:2rem;color:#9eabb3}.post-meta a{color:#9eabb3;text-decoration:none}.post-meta a:hover{text-decoration:underline}.user-meta{position:relative;padding:.3rem 40px 0 100px;min-height:77px}.user-image{position:absolute;top:0;left:0}.user-name{display:block;font-weight:700}.user-bio{display:block;max-width:440px;font-size:1.4rem;line-height:1.5rem}.publish-meta{position:absolute;top:0;right:0;padding:4.3rem 0 4rem;text-align:right}.publish-heading{display:block;font-weight:700}.publish-date{display:block;font-size:1.4rem;line-height:1.5rem}.post-template .content{overflow:hidden}.post-template .post{margin-top:0;border-bottom:none;padding-bottom:0}.post-template .post:after{display:none}.post-template .post-header{padding:60px 0;text-align:center}.post-template .blog-title{display:inline-block;padding:2.5rem 0}.post-content img{display:block;max-width:100%;height:auto;margin:0 auto;padding:.6rem 0}.post-content .full-img{width:126%;max-width:none;margin:0 -13%}.post-footer{margin:2rem 0 0;padding:2rem 0 0;border-top:#ebf2f6 1px solid}.post-footer h4{font-size:1.8rem;margin:0}.archive-template .site-head{height:auto;padding-bottom:5rem}.archive-template .site-head a{color:#fff}.archive-template .blog-logo{display:block;margin-top:5rem}.tag-archive-header,.page-header{padding:20px 0;text-align:center;max-width:700px;margin:4rem auto;border-bottom:1px solid #ebf2f6;position:relative}.tag-archive-header:after,.page-header:after{display:block;content:"";width:7px;height:7px;border:#e7eef2 1px solid;position:absolute;bottom:-5px;left:50%;margin-left:-5px;background:#fff;-webkit-border-radius:100%;-moz-border-radius:100%;border-radius:100%;box-shadow:#fff 0 0 0 5px}.archive-template .blog-title{display:inline-block;padding:2.5rem 0}.gist table{margin:0;font-size:1rem}.gist .line-number{min-width:25px;font-size:1rem;font-family:fira mono,sans-serif}.gist .gist-file .gist-data .line-pre{font-family:fira mono,sans-serif!important}.pagination{position:relative;width:80%;max-width:700px;margin:1rem auto;font-size:.8rem;color:#9eabb3;text-align:center}.pagination a{color:#9eabb3}.older-posts,.newer-posts{position:absolute;display:inline-block;border:#ebf2f6 2px solid;padding:calc(1rem - 4px);text-decoration:none;border-radius:30px;transition:border ease .3s}.older-posts{right:0}.page-number{display:inline-block;padding:1rem}.newer-posts{left:0}.older-posts:hover,.newer-posts:hover{border-color:#9eabb3}.site-footer{position:relative;margin:8rem 0 0;padding:4rem 0;border-top:#ebf2f6 1px solid;font-size:.8rem;line-height:1.7rem;color:#bbc7cc;text-align:center;background:#f7fafb}.site-footer a{color:#bbc7cc;text-decoration:underline}.site-footer a:hover{color:#50585d}.poweredby .icon-ghost{font-weight:700;text-decoration:none}.poweredby .icon-ghost:hover{text-decoration:none}.poweredby .icon-ghost:before{font-size:1rem;margin-right:.2rem}.subscribe{width:28px;height:28px;position:absolute;top:-14px;left:50%;margin-left:-15px;border:#ebf2f6 1px solid;text-align:center;line-height:2.4rem;border-radius:50px;background:#fff;transition:box-shadow .5s}.subscribe:before{color:#d2dee3;font-size:10px;position:absolute;top:9px;left:9px;font-weight:700;transition:color .5s ease}.subscribe:hover{box-shadow:rgba(0,0,0,.05) 0 0 0 3px;transition:box-shadow .25s}.subscribe:hover:before{color:#50585d}.tooltip{opacity:0;display:inline-block;padding:4px 8px 5px;position:absolute;top:-23px;left:-21px;color:rgba(255,255,255,.9);font-size:1.1rem;line-height:1rem;text-align:center;background:#50585d;border-radius:20px;box-shadow:0 1px 4px rgba(0,0,0,.1);transition:opacity .3s ease,top .3s ease}.tooltip:after{content:"";border-width:5px 5px 0;border-style:solid;border-color:#50585d transparent;display:block;position:absolute;bottom:-4px;left:50%;margin-left:-5px;z-index:220;width:0}.subscribe:hover .tooltip{opacity:1;top:-33px}@media only screen and (max-width:900px){blockquote{margin-left:0}.site-head{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;height:auto;min-height:240px;padding:15% 0}.blog-title{font-size:4rem;letter-spacing:-1px}.blog-description{font-size:1.7rem;line-height:1.5rem}.post{font-size:.9rem;line-height:1.6rem}.post-template .post{padding-bottom:1rem}.post-template .post-header{padding:40px 0}h1{font-size:4.8rem;text-indent:-2px}h2{font-size:3.8rem}h3{font-size:3.3rem}h4{font-size:2.8rem}}@media only screen and (max-width:500px){.blog-logo img{max-height:80px}.inner,.pagination{width:auto;margin-left:16px;margin-right:16px}.post{width:auto;margin-left:16px;margin-right:16px;font-size:.8rem;line-height:1.6rem}.site-head{padding:10% 0}.blog-title{font-size:3rem}.blog-description{font-size:1.5rem}h1,h2{font-size:3rem;line-height:3.1rem;letter-spacing:-1px}h3{font-size:2.8rem}h4{font-size:2.3rem}.post-template .post{padding-bottom:0}.post-template .post-header{padding:30px 0}.post-content img{padding:0}.post-content .full-img{width:auto;width:calc(100% + 32px);margin:0 -16px;min-width:0;max-width:112%}.post-meta{font-size:.8rem}.post-footer{padding:4rem 0;text-align:center}.post-footer .author{margin:0 0 2rem;padding:0 0 1.6rem;border-bottom:#ebf2f6 1px dashed}.post-footer .share{position:static;width:auto}.post-footer .share a{margin:1.4rem .8rem 0}.older-posts,.newer-posts{position:static;margin:10px 0}.page-number{display:block}.site-footer{margin-top:6rem;font-size:1.1rem}}.buttonNav{max-width:600px;text-align:center;margin-bottom:4rem}.ripple,button{font-family:raleway,sans-serif;position:relative;transition:all .2s;transform:translateZ(0);display:inline-block;padding:calc(1rem - 1px);font-size:1.5rem;line-height:1.5rem;border:1px solid #26bced;border-radius:.5rem;text-align:center;margin:.5rem;min-width:7rem;max-width:20rem;background:0 0;appearance:none;-webkit-appearance:none;outline:none;box-sizing:content-box}.ripple i,.button i{margin-right:1rem}.ripple.ripple-focusin,.ripple.ripple-mouseover,.ripple.ripple-mouseup,.ripple.ripple-mousedown,button.ripple-focusin,button.ripple-mouseover,button.ripple-mouseup,button.ripple-mousedown{box-shadow:0 2px 5px 0 rgba(0,0,0,.26);color:#fff;outline:none;border-color:#0d7ca0}.ripple-canvas{position:absolute;top:0;left:0;z-index:-1;pointer-events:none;border-radius:.5rem}.ripple-field{position:relative;display:block;width:100%;height:6rem;margin:1rem 0;overflow:hidden}.ripple-field.textarea{height:12rem}.ripple-field .ripple-canvas{border-radius:0;top:2rem;z-index:0}.ripple-field input,.ripple-field textarea{appearance:none;-webkit-appearance:none;box-sizing:content-box;font:300 2rem/2rem "Fira Sans",sans-serif;height:calc(100% - 3rem);width:calc(100% - 2rem);border:0;background:#fafafa;resize:none;padding:0 1rem .6rem;outline:none;transition:all .15s ease-in-out;margin:2rem 0 0;line-height:3rem;box-shadow:0 .15rem 0 #fafafa;position:absolute;z-index:1}.ripple-field label{font:inherit;font-size:2rem;position:absolute;top:2rem;left:1rem;transition:all .15s ease-in-out;z-index:2}.ripple-field input:focus,.ripple-field textarea:focus{box-shadow:0 0 0 #fafafa}.ripple-field input:focus+label,.ripple-field textarea:focus+label,.ripple-field input:valid+label,.ripple-field textarea:valid+label,.ripple-field input:disabled+label,.ripple-field textarea:disabled+label{top:.25rem;font-size:1.1rem}.ripple-field input:disabled~.ripple-canvas,.ripple-field textarea:disabled~.ripple-canvas{opacity:.2}.ripple-field input:disabled,.ripple-field textarea:disabled,.ripple-field input:disabled+label,.ripple-field textarea:disabled+label{color:#ccc}.section-box{width:0;border:0 solid #ccc;border-radius:.5rem;visibility:hidden;overflow:hidden;height:0;position:relative;margin:-8rem auto 8rem;background:#fafafa;transition:border-width .3s ease-in-out .4s,margin .3s ease-in-out .4s,width .3s ease-in-out .4s,height .5s ease-in-out,visibility 0s ease-in-out 1s}.section-box.visible{width:900px;height:15rem;border-width:1px;visibility:visible;transition:border-width .3s ease-in-out,margin .3s ease-in-out,width .3s ease-in-out,height .5s ease-in-out .4s,visibility 0s ease-in-out 0s}.section-box h3{text-align:center}.section-box .inner{padding:1rem;position:absolute;top:0;right:0;bottom:0;left:0;height:calc(100% - 2rem)}.buttonset{text-align:right}.update-block{border:1px solid #fbc02d;background:#fff59d;padding:0 1.6rem;margin:0 auto}