@charset "UTF-8";/*! normalize-scss | MIT/GPLv2 License | bit.ly/normalize-scss */.contact-page__input,.contact-page__textarea,.content-webmentions__form-input,.content-wrapper__inner a,a{-webkit-transition:-webkit-box-shadow 150ms ease-in-out}.content-wrapper__inner dt,b,optgroup,strong{font-weight:700}.highlight .ge,dfn{font-style:italic}.highlight table,table{border-spacing:0}.hidden,.offline .navigation__item-anchor{visibility:hidden}a:active,a:focus,a:hover{text-decoration:underline}html{font-family:sans-serif;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}article,aside,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section,summary{display:block}audio,canvas,progress,video{display:inline-block;vertical-align:baseline}audio:not([controls]){display:none;height:0}[hidden],template{display:none}a{background-color:transparent;color:#007db9;transition:-webkit-box-shadow 150ms ease-in-out;transition:box-shadow 150ms ease-in-out;transition:box-shadow 150ms ease-in-out,-webkit-box-shadow 150ms ease-in-out;text-decoration:none}a:active,a:hover{outline:0}abbr[title]{border-bottom:1px dotted}h1{font-size:2em;margin:.75em 0}mark{background:#ff0;color:#000}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}hr{-webkit-box-sizing:content-box;box-sizing:content-box;height:0}pre,textarea{overflow:auto}code,kbd,pre,samp{font-family:monospace,monospace;font-size:1em}button,input,optgroup,select,textarea{color:inherit;font:inherit;margin:0}.header__intro,.skip-links__anchor,p{line-height:1.375rem}button{overflow:visible}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}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0}input{line-height:normal}input[type=checkbox],input[type=radio]{-webkit-box-sizing:border-box;box-sizing:border-box;padding:0}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{height:auto}input[type=search]{-webkit-appearance:textfield;-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}fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em}legend{border:0;padding:0}table{border-collapse:collapse}td,th{padding:0}html{-webkit-box-sizing:border-box;box-sizing:border-box}*,::after,::before{-webkit-box-sizing:inherit;box-sizing:inherit}body{margin:0;overflow-x:hidden;font-family:Geneva,Tahoma,Verdana,sans-serif;background:#003c58;background:url(/images/app-shell/grid.png) top left,linear-gradient(165deg,#003c58 0,#004c70 30%,#004c70 30%,#002a3e 100%)}.content-wrapper__inner h1,.header__intro-title,.header__strapline,.header__title,.save-data .content-wrapper__inner h2,.save-data .content-wrapper__inner h3,.save-data .header__intro-title,.save-data .header__strapline,.save-data .header__title,.save-data .pagination,.save-data .post .post__title,.save-data .post-intro-article .post-intro-article__header,.save-data .post-intro-article__published,.save-data .post-intro-wrapper .post-intro-wrapper__header-link,.save-data .post-intro-wrapper .post-intro-wrapper__header-title,.save-data h1,.save-data h2,.save-data h3{font-family:Georgia,Times,Times New Roman,serif}@media (min-width:641px){body{background:url(/images/app-shell/iceburg.svg) 18% 3px no-repeat,url(/images/app-shell/lines.png) center 570px repeat-x,url(/images/app-shell/grid.png) top left,linear-gradient(to top,#002a3e 0,rgba(0,42,62,.99) 20%,rgba(0,42,62,.78) 34%,rgba(255,255,255,0) 100%),linear-gradient(165deg,#003c58 0,#004c70 30%,#004c70 30%,#002a3e 100%)}}.hidden{display:none}.save-data body{background:#004c70}.save-data .navigation__list--secondary li::after,.save-data .navigation__list--secondary li::before,.save-data .site-footer::after,.save-data .site-footer__copyright::after,.save-data .site-footer__copyright::before,.save-data .site-footer__design::after,.save-data .site-footer__design::before,.save-data .site-footer__licence::after,.save-data .site-footer__licence::before{background:0 0}.save-data .navigation__trigger{padding:23px 12px}.save-data .navigation__list--secondary{top:67px}.save-data .about .content-wrapper{background:#fff}.save-data .contact-page::after{background:0 0}p{font-size:1rem;margin:1.25rem 0}a:visited{color:#3c85a9}a:active,a:focus{color:#40a3e6}a:focus{outline:0;-webkit-box-shadow:0 0 5px 4px #d62839;box-shadow:0 0 5px 4px #d62839}figure{margin:0}.promo-wrapper{max-width:940px;margin:0 auto;padding:0 0 48px}.visually-hidden{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}.visually-hidden.focusable:active,.visually-hidden.focusable:focus{clip:auto;height:auto;margin:0;overflow:visible;position:static;width:auto}.header{color:#fff;position:relative;max-width:940px;margin:0 auto}.header__title{color:inherit;margin:0;text-transform:uppercase;font-size:42px;font-weight:400;line-height:inherit}@media (min-width:641px){.header{position:static}.header__title{text-align:center;font-size:80px;margin-bottom:10px}}@media (min-width:1025px){.header__title{text-align:left;line-height:1;margin-top:-10px;margin-left:-6px}}.header__title a{color:#fff;text-decoration:none}.header__title a:focus,.header__title a:hover{color:#007db9}.header__strapline{color:#fff;font-size:18px;width:191px;height:191px;border-radius:50%;background:rgba(74,0,116,.5);margin:22px auto 70px;text-align:left;line-height:1.25rem;padding:20px 40px;position:relative;clear:both;text-transform:uppercase}@media (min-width:641px){.header__strapline{margin:35px auto 100px}}@media (min-width:1025px){.header__strapline{width:312px;height:312px;font-size:31px;padding:20px 60px;margin:-222px 182px 40px 0;float:right;z-index:-20;line-height:2.25rem}.homepage .header__strapline{width:480px;height:480px;font-size:46px;margin:-167px 50px 40px 0;padding:20px 90px;line-height:2.875rem}}.homepage .header__strapline::after{-webkit-transform:rotate(53deg);-ms-transform:rotate(53deg);transform:rotate(53deg);margin-bottom:5px;border-width:40px 4px 0}@media (min-width:1025px){.homepage .header__strapline::after{-webkit-transform:rotate(60deg);-ms-transform:rotate(60deg);transform:rotate(60deg);margin-bottom:68px;border-width:65px 6px 0}.blog-post .header__strapline,.lab-post .header__strapline,.portfolio-post .header__strapline{margin-top:-20px}}.header__strapline::after{content:"";position:absolute;width:0;height:0;border-style:solid;border-width:35px 4px 0;border-color:rgba(74,0,116,.5) transparent transparent;bottom:0;left:0;-webkit-transform:rotate(55deg);-ms-transform:rotate(55deg);transform:rotate(55deg);margin-bottom:12px}.header__strapline span{position:relative;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%);display:block}.header__strapline span::after,.header__strapline span::before{color:#007db9}.header__strapline span::before{content:"{ ";margin-right:2px}.header__strapline span::after{content:" }";margin-left:2px}.content-wrapper::before,.content-wrapper__inner::after,.navigation__list--primary::after,.pagination .pagination__page-link::after{content:""}.header__intro{font-size:1rem;text-align:center;color:inherit;padding:38px 30px 0}@media (min-width:641px){.header__intro{width:65.9574468085%;float:left;margin-right:-100%;margin-left:17.0212765957%;clear:none;padding-bottom:22px}}@media (min-width:1025px){.header__strapline::after{margin-bottom:31px;border-width:50px 6px 0}.header__intro{width:40.4255319149%;float:left;margin-right:-100%;margin-left:0;clear:none;text-align:left;padding:0;min-height:220px}}.header__intro-title{text-transform:uppercase;margin:0 0 7px;font-size:inherit;display:block}.header__intro-copy{margin-top:0}.header__intro-retry-connection{display:block;margin:10px 0 0}.navigation{color:inherit}.navigation__trigger{color:#fff;font-size:18px;position:absolute;top:0;right:30px;padding:26px 12px;cursor:pointer;border:solid #003c58;border-width:0 1px;background:#002436;text-transform:uppercase}.navigation__list{margin:0;padding:8px 30px 12px;list-style:none}@media (min-width:641px){.navigation__trigger{display:none}.navigation__list{padding-top:30px}}@media (min-width:1025px){.navigation__list{padding:60px 0 30px}}.navigation__list--primary{background:#002436}.navigation__list--primary::after{display:table;clear:both}@media (min-width:641px){.navigation__list--primary{background:0 0}}.navigation__list--secondary{background:#001017;padding:40px 30px;position:absolute;top:72px;left:0;right:0;display:none;z-index:10}@media (min-width:641px){.navigation__list--secondary{position:static;background:0 0;padding:0;text-align:center;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center}@supports (display:grid){.navigation__list--secondary{display:grid;grid-template-columns:repeat(7,76px)}}.navigation__list--secondary li::after,.navigation__list--secondary li::before{content:"";position:absolute;display:block;background:url(/images/app-shell/cloud-r.svg) no-repeat;-webkit-filter:blur(2.2px);filter:blur(2.2px)}.ie9 .navigation__list--secondary li::after,.ie9 .navigation__list--secondary li::before{display:none}}@media (min-width:1025px){.navigation__list--secondary{text-align:right;margin-right:-6px}}.navigation__list--secondary li:nth-of-type(1)::after,.navigation__list--secondary li:nth-of-type(1)::before{width:86px;height:33px;background-size:86px 33px;z-index:-10}.navigation__list--secondary li:nth-of-type(1)::before{top:5%;left:20%;opacity:.3}.navigation__list--secondary li:nth-of-type(1)::after{top:8%;left:45%;opacity:.4}.navigation__list--secondary li:nth-of-type(2)::after,.navigation__list--secondary li:nth-of-type(2)::before{width:216px;height:18px;background-size:216px 18px;z-index:-10}.navigation__list--secondary li:nth-of-type(2)::before{top:8%;right:12%;opacity:.15}.navigation__list--secondary li:nth-of-type(2)::after{top:17%;left:30%;opacity:.11}.navigation__list--secondary li:nth-of-type(3)::after,.navigation__list--secondary li:nth-of-type(3)::before{width:109px;height:43px;background-size:109px 43px;z-index:-10}.navigation__list--secondary li:nth-of-type(3)::before{top:32%;right:9%;opacity:.11}.navigation__list--secondary li:nth-of-type(3)::after{top:32%;left:7%;opacity:.12}.navigation__list--secondary li:nth-of-type(4)::after,.navigation__list--secondary li:nth-of-type(4)::before{width:59px;height:23px;background-size:59px 23px;z-index:-10}.navigation__list--secondary li:nth-of-type(4)::before{top:11%;right:56%;opacity:.25}.navigation__list--secondary li:nth-of-type(4)::after{top:13%;left:4%;opacity:.35}.navigation__list--secondary li:nth-of-type(5)::after,.navigation__list--secondary li:nth-of-type(5)::before{width:141px;height:56px;background-size:141px 56px;z-index:-10}.navigation__list--secondary li:nth-of-type(5)::before{top:38%;left:67%;opacity:.15}.navigation__list--secondary li:nth-of-type(5)::after{top:44%;left:26%;opacity:.1}.navigation__item{color:inherit;font-family:Arial,"Helvetica Neue",Helvetica,sans-serif}.navigation__item-anchor{color:#fff;font-size:14px;display:block;padding:12px 0;border-bottom:1px dotted #003c58}.navigation__item-anchor--active,.navigation__item-anchor:hover{color:#40a3e6}.navigation__item--primary:hover .navigation__trigger{color:#007db9;background:#001017}.navigation__item--primary:hover .navigation__trigger::before{background:#40a3e6;-webkit-box-shadow:0 8px 0 0 #40a3e6,0 16px 0 0 #40a3e6;box-shadow:0 8px 0 0 #40a3e6,0 16px 0 0 #40a3e6}.navigation__item--secondary:first-of-type{border-top:1px dotted #003c58}.navigation__item--secondary a{padding-left:10px}@media (max-width:640px){.navigation__item--primary:hover>ul,.navigation__item--secondary a{display:block}.navigation__item--secondary a:hover{background:rgba(255,255,255,.15);color:#fff;text-decoration:none}}@media (min-width:641px){.navigation__item--secondary{margin:0 5px}.navigation__item--secondary:first-of-type{border:0}.navigation__item--secondary a{background:#fff;color:#007db9;text-align:center;display:block;width:66px;height:66px;border-radius:50%;border:0;padding:0;position:relative}.navigation__item--secondary a:focus,.navigation__item--secondary a:hover{color:#fff;background:#007db9;text-decoration:none;-webkit-transition:background-color .2s;transition:background-color .2s}.navigation__item--secondary a:focus::after,.navigation__item--secondary a:hover::after{border-color:#007db9 transparent transparent;-webkit-transition:border-color .2s;transition:border-color .2s}.navigation__item--secondary a:focus{text-decoration:underline}.navigation__item--secondary a::after{content:"";position:absolute;width:0;height:0;border-style:solid;border-width:20px 4px 0;border-color:#fff transparent transparent;bottom:0;left:0;-webkit-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg);margin-bottom:-5px}.navigation__item--secondary span{display:block;position:relative;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}}.navigation__item--active a{text-decoration:underline}@media (min-width:641px){.navigation__item--active a{color:#fff;background:#007db9;text-decoration:none;-webkit-transition:background-color .2s;transition:background-color .2s}.navigation__item--active a::after{border-color:#007db9 transparent transparent;-webkit-transition:border-color .2s;transition:border-color .2s}.navigation__item--active a:focus,.navigation__item--active a:hover{color:#fff;background:#001017;-webkit-transition:background-color .2s;transition:background-color .2s}.navigation__item--active a:focus::after,.navigation__item--active a:hover::after{border-color:#001017 transparent transparent;-webkit-transition:border-color .2s;transition:border-color .2s}}@media (min-width:1025px){.navigation__item--title{width:40.4255319149%;float:left;margin-right:-100%;margin-left:0;clear:none}.navigation__item--nav-wrapper{width:57.4468085106%;float:right;margin-left:0;margin-right:0;clear:none}}.skip-links{padding:0;margin:0;position:absolute;width:100%}.skip-links__anchor{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;font-size:1rem}.skip-links__anchor.focusable:active,.skip-links__anchor.focusable:focus{clip:auto;height:auto;margin:0;overflow:visible;position:static;width:auto}.skip-links__anchor:focus{background:rgba(74,0,116,.9);color:#fff;width:100%;height:auto;clip:auto;margin:0;display:block;top:0;left:0;z-index:90;padding:10px 12px;position:fixed;text-align:center;-webkit-box-shadow:none;box-shadow:none}.content-wrapper__inner::after,.post-intro-wrapper::after,.post-intro-wrapper__inner::after{display:table;clear:both}.content-wrapper{clear:both;color:#39454b;background:rgba(255,255,255,.93);position:relative;min-height:700px;margin-bottom:23px}.content-wrapper__inner{max-width:940px;margin:0 auto;padding:0 0 48px}.content-wrapper__inner h1{font-size:1.778rem;line-height:2.5rem;margin:1.25rem 0}.content-wrapper__inner h2,.content-wrapper__inner h3{margin:0;font-family:Georgia,Times,Times New Roman,serif}.content-wrapper__inner h2{font-size:1.333rem;line-height:2.5rem}.content-wrapper__inner h3{line-height:1.375rem;font-size:1.125rem}.content-wrapper__inner .highlighter-rouge,.content-wrapper__inner dd,.content-wrapper__inner dt,.content-wrapper__inner li,.content-wrapper__inner p,.content-wrapper__inner table{font-size:1rem;line-height:1.375rem}.content-wrapper__inner p{margin:0 0 1.25rem}.content-wrapper__inner p>code{background:#eee;border:1px solid #ccc;padding:2px 4px;color:#d14}.content-wrapper__inner a{transition:-webkit-box-shadow 150ms ease-in-out;transition:box-shadow 150ms ease-in-out;transition:box-shadow 150ms ease-in-out,-webkit-box-shadow 150ms ease-in-out;color:#007db9}.content-wrapper__inner a:visited{color:#3c85a9}.content-wrapper__inner a:hover{text-decoration:underline}.content-wrapper__inner a:active,.content-wrapper__inner a:focus{color:#40a3e6;text-decoration:underline}.content-wrapper__inner a:focus{outline:0;-webkit-box-shadow:0 0 5px 4px #d62839;box-shadow:0 0 5px 4px #d62839;text-decoration:underline}.content-wrapper__inner dl,.content-wrapper__inner ol,.content-wrapper__inner ul{margin:1.25rem 0}.content-wrapper__inner li>p{margin:0}.content-wrapper__inner li>.highlighter-rouge,.content-wrapper__inner li>ol,.content-wrapper__inner li>ul{margin:.625rem 0}.content-wrapper__inner li>code{background:#eee;border:1px solid #ccc;padding:2px 4px;color:#d14}.content-wrapper__inner blockquote{color:#757575;border-left:4px solid #d1d1d1;margin:0}.content-wrapper__inner blockquote>p{margin-left:.625rem}.content-wrapper__inner table{margin:1.25rem 0;border:1px solid #d1d1d1;background:#fff}.content-wrapper__inner td,.content-wrapper__inner th{border:solid #d1d1d1;border-width:0 1px 1px 0;padding:.625rem 1.25rem}.content-wrapper__inner hr{margin:1.25rem 0}.content-wrapper__inner iframe{border:1px solid #d1d1d1;margin:0 0 1.25rem}.content-wrapper__inner .highlighter-rouge{margin:1.25rem 0}.content-wrapper__inner .footnotes,.figure__caption{font-size:.75rem;line-height:1.25rem}.content-wrapper__inner .footnotes li,.content-wrapper__inner .footnotes p{font-size:inherit}@media (max-width:640px){.content-wrapper__inner table{width:100%;margin:0}.content-wrapper__inner .table-wrapper{margin:1.25rem 0;overflow-x:auto}}.content-wrapper::before{background:rgba(255,255,255,.96);height:20%;display:block;position:absolute;top:0;left:0;right:0;-webkit-transform:skew(0,-12deg);-ms-transform:skew(0,-12deg);transform:skew(0,-12deg);background-clip:content-box;z-index:-10;-webkit-transform-origin:top left;-ms-transform-origin:top left;transform-origin:top left}@media (min-width:641px) and (max-width:1024px){.content-wrapper::before{height:22%;-webkit-transform:skew(0,-8deg);-ms-transform:skew(0,-8deg);transform:skew(0,-8deg)}.blog-post .content-wrapper,.homepage .content-wrapper,.lab-post .content-wrapper{margin-bottom:142px}}@media (min-width:1025px){.content-wrapper::before{height:30%;-webkit-transform:skew(0,-5deg);-ms-transform:skew(0,-5deg);transform:skew(0,-5deg)}.blog-post .content-wrapper,.homepage .content-wrapper,.lab-post .content-wrapper{margin-bottom:160px}}@media (min-width:641px){.about .content-wrapper{background:url(/images/app-shell/narwhals-bg.jpg) bottom center no-repeat #fff;background-size:850px auto;padding-bottom:220px}.contact .content-wrapper{margin-bottom:110px}}@media (min-width:1025px){.about .content-wrapper{background-size:1500px auto}.contact .content-wrapper{margin-bottom:240px}}.pagination .pagination__page-link,.post-intro-wrapper--dark .post-intro-article .post-intro-article__published-day,.post-intro-wrapper--light .post-intro-article .post-intro-article__published-day{background:#eaeaea}.pagination{font-family:Georgia,Times,Times New Roman,serif;list-style:none;padding:0;margin:0 auto}@media (min-width:1025px){.pagination{margin:0}}.pagination__item{display:inline-block}.pagination .pagination__page-link{display:block;margin:0 12px 12px 0;border-radius:50%;width:36px;height:36px;color:#007db9;position:relative;text-align:center;padding:7px 0 0}@media (min-width:641px) and (max-width:1024px){.pagination .pagination__page-link{width:33px;height:33px;margin:0 10px 10px 0;padding:5px 0 0}}@media (min-width:1025px){.pagination .pagination__page-link{width:43px;height:43px;margin:0 16px 16px 0;padding:10px 0 0}}.pagination .pagination__page-link:focus,.pagination .pagination__page-link:hover{background:#007db9;-webkit-transition:background-color .2s;transition:background-color .2s;color:#fff;text-decoration:none}.pagination .pagination__page-link:focus::after,.pagination .pagination__page-link:hover::after{border-color:#007db9 transparent transparent;-webkit-transition:border-color .2s;transition:border-color .2s}.pagination .pagination__page-link::after,.post-intro-wrapper--dark .post-intro-article .post-intro-article__published-day::after,.post-intro-wrapper--light .post-intro-article .post-intro-article__published-day::after{border-color:#eaeaea transparent transparent}.pagination .pagination__page-link::after{position:absolute;width:0;height:0;border-style:solid;border-width:13px 2px 0;bottom:0;left:0;-webkit-transform:rotate(46deg);-ms-transform:rotate(46deg);transform:rotate(46deg);margin-bottom:-4px}@media (min-width:641px) and (max-width:1024px){.pagination .pagination__page-link::after{-webkit-transform:rotate(55deg);-ms-transform:rotate(55deg);transform:rotate(55deg);border-width:18px 3px 0;margin-bottom:-9px;bottom:4px}@supports (display:grid){.post-intro-wrapper__inner{grid-template-columns:repeat(2,1fr)}}}@media (min-width:1025px){.pagination .pagination__page-link::after{-webkit-transform:rotate(48deg);-ms-transform:rotate(48deg);transform:rotate(48deg);border-width:16px 3px 0;margin-bottom:-4px}}.pagination__item--next .pagination__page-link,.pagination__item--previous .pagination__page-link{background:0 0}.pagination__item--next .pagination__page-link:focus,.pagination__item--next .pagination__page-link:hover,.pagination__item--previous .pagination__page-link:focus,.pagination__item--previous .pagination__page-link:hover{background:0 0;color:#007db9;text-decoration:underline}.pagination__item--next .pagination__page-link::after,.pagination__item--previous .pagination__page-link::after{content:normal}.post-intro-article__published-day::after,.post-intro-wrapper::after,.post-intro-wrapper__header::after,.post-intro-wrapper__inner::after,.site-footer::after,.site-footer::before,.site-footer__copyright::before{content:""}.pagination__item--active .pagination__page-link{color:#001017}.pagination__item--active .pagination__page-link:focus,.pagination__item--active .pagination__page-link:hover{color:#fff;background:#001017;-webkit-transition:background-color .2s;transition:background-color .2s}.pagination__item--active .pagination__page-link:focus::after,.pagination__item--active .pagination__page-link:hover::after{border-color:#001017 transparent transparent;-webkit-transition:border-color .2s;transition:border-color .2s}.figure{margin:0 0 1.25rem}.figure__image{max-width:100%;border:1px solid #d1d1d1;width:auto;height:auto;background:#fff}a .figure__image{-webkit-transition:-webkit-filter 350ms ease-in-out;transition:-webkit-filter 350ms ease-in-out;transition:filter 350ms ease-in-out;transition:filter 350ms ease-in-out,-webkit-filter 350ms ease-in-out}a .figure__image:hover{-webkit-filter:grayscale(75%);filter:grayscale(75%)}.post a .figure__image:hover{-webkit-filter:none;filter:none}.post-intro-wrapper{padding:24px 30px 0;clear:both;position:relative}@media (min-width:1025px){.post-intro-wrapper{padding:24px 0 0}}.post-intro-wrapper__inner{padding:0 0 48px;font-size:0}@supports (display:grid){.post-intro-wrapper__inner{display:grid;grid-column-gap:30px}.post-intro-wrapper nav{grid-column:1/-1}}.post-intro-wrapper__header{border-bottom:1px dotted #b6bcbf;padding:24px 0;margin-bottom:32px;line-height:1.5;grid-column:1/-1;grid-row:1}.post-intro-wrapper__header::after{display:table;clear:both}.post-intro-wrapper .post-intro-wrapper__header-link,.post-intro-wrapper .post-intro-wrapper__header-title{display:block}.post-intro-wrapper .post-intro-wrapper__header-title{font-size:1.333rem;line-height:2.5rem;color:inherit;font-weight:400;margin:0}.post-intro-wrapper .post-intro-wrapper__header-link{font-size:1rem;line-height:1.375rem;font-family:Georgia,Times,Times New Roman,serif}@media (min-width:641px){.blog-post .content-wrapper,.lab-post .content-wrapper,.portfolio-post .content-wrapper{min-height:810px}.post-intro-wrapper .post-intro-wrapper__header-title{float:left}.post-intro-wrapper .post-intro-wrapper__header-link{font-size:1.333rem;line-height:2.5rem;float:right;text-align:right}}.post-intro-wrapper--light{color:#fff}.post-intro-wrapper--dark{color:#39454b}.post-intro-article{margin:.625rem 0 0;display:inline-block;font-size:0;vertical-align:top;width:100%;padding-bottom:24px}@media (min-width:641px) and (max-width:1024px){.post-intro-article{width:48%;margin:0 4% 0 0;padding-bottom:30px}.post-intro-article:nth-of-type(2n){margin-right:0}.post-intro-article:nth-of-type(2n-1){margin-left:0}@supports (display:grid){.post-intro-article{width:auto;margin-right:0}}}@media (min-width:1025px){.post-intro-article{width:31%;margin:0 3.5% 0 0;padding-bottom:32px}.post-intro-article:nth-of-type(3n){margin-right:0}.post-intro-article:nth-of-type(3n-2){margin-left:0}@supports (display:grid){.post-intro-wrapper__inner{grid-template-columns:repeat(3,1fr)}.post-intro-article{width:auto;margin-right:0}}}.post-intro-article .post-intro-article__time-wrapper{margin:.625rem 0}.post-intro-article .post-intro-article__header{font-size:1.333rem;font-family:Georgia,Times,Times New Roman,serif;font-weight:400;margin:.625rem 0;padding:0;color:#007db9;line-height:1.5625rem}.post-intro-article__published{font-size:1rem;line-height:1.375rem;font-family:Georgia,Times,Times New Roman,serif;text-transform:uppercase;padding:0;margin:.625rem 0;color:inherit;display:inline-block}.post-intro-article__published-day{font-size:26px;border-radius:50%;padding:3px 0 0 4px;position:relative;color:#39454b;width:40px;height:40px;display:inline-block}.post-intro-article__published-day::after{position:absolute;width:0;height:0;border-style:solid;border-width:13px 3px 0;bottom:0;left:0;-webkit-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg);margin-bottom:-4px}.post-intro-article__header-link{color:inherit}.post-intro-article__body{font-size:1rem;padding:0 0 2.5rem;line-height:1.6875rem}@supports (display:grid){.post-intro-article__body{padding-bottom:0}}.post-intro-article__body p{font-size:inherit;color:inherit;line-height:inherit;margin-top:0}.post-intro-wrapper--dark .post-intro-article{color:#39454b}.post-intro-wrapper--light .post-intro-article{color:#fff}.highlight,.highlight .hll,.highlight pre{background-color:#272822}.highlight{margin:1.25rem 0;overflow-x:auto}.highlight code,.highlight pre{color:#75715e;margin:0;padding:0}.highlight code table{margin:0;width:100%;background:#272822}.highlight .gutter{width:16px;text-align:right}pre.highlight{margin:0;padding:5px 10px}.highlight .c{color:#75715e}.highlight .err{color:#960050;background-color:#1e0010}.highlight .k{color:#66d9ef}.highlight .l{color:#ae81ff}.highlight .n{color:#f8f8f2}.highlight .o{color:#f92672}.highlight .p{color:#f8f8f2}.highlight .c1,.highlight .cm,.highlight .cp,.highlight .cs{color:#75715e}.highlight .gs{font-weight:700}.highlight .kc,.highlight .kd{color:#66d9ef}.highlight .kn{color:#f92672}.highlight .kp,.highlight .kr,.highlight .kt{color:#66d9ef}.highlight .ld{color:#e6db74}.highlight .m{color:#ae81ff}.highlight .s{color:#e6db74}.highlight .na{color:#a6e22e}.highlight .nb{color:#f8f8f2}.highlight .nc{color:#a6e22e}.highlight .no{color:#66d9ef}.highlight .nd{color:#a6e22e}.highlight .ni{color:#f8f8f2}.highlight .ne,.highlight .nf{color:#a6e22e}.highlight .nl,.highlight .nn{color:#f8f8f2}.highlight .nx{color:#a6e22e}.highlight .py{color:#f8f8f2}.highlight .nt{color:#f92672}.highlight .nv{color:#f8f8f2}.highlight .ow{color:#f92672}.highlight .w{color:#f8f8f2}.highlight .mf,.highlight .mh,.highlight .mi,.highlight .mo{color:#ae81ff}.highlight .s2,.highlight .sb,.highlight .sc,.highlight .sd{color:#e6db74}.highlight .se{color:#ae81ff}.highlight .s1,.highlight .sh,.highlight .si,.highlight .sr,.highlight .ss,.highlight .sx{color:#e6db74}.highlight .bp,.highlight .vc,.highlight .vg,.highlight .vi{color:#f8f8f2}.highlight .il{color:#ae81ff}.highlight .gu{color:#75715e}.highlight .gd{color:#f92672}.highlight .gi{color:#a6e22e}.site-footer{max-width:940px;margin:0 auto;padding:0 30px 250px;text-align:center;color:#949494;clear:both;position:relative}@media (min-width:641px){.site-footer{padding:0 30px 153px}}.site-footer p{font-size:12px;color:#fff}.site-footer::before{width:100%;height:1px;border-top:1px dotted #4c6875;display:block;margin-bottom:45px}.site-footer::after{width:211px;height:215px;background:url(/images/app-shell/whale.svg) no-repeat;display:block;opacity:.5;position:absolute;bottom:50px;left:50%;margin-left:-105.5px}.site-footer__copyright::after,.site-footer__copyright::before,.site-footer__design::before{background:url(/images/app-shell/bubble.svg) no-repeat;position:absolute}@media (min-width:641px){.site-footer::after{right:30px;bottom:36px;margin-left:0;left:auto}}@media (min-width:1025px){.site-footer{padding:140px 0 223px}.site-footer__wrapper{width:57.4468085106%;float:left;margin-right:-100%;margin-left:0;clear:none;text-align:left}}.site-footer__copyright,.site-footer__licence,.site-footer__rss,.site-footer__timings{margin:2px 0}.site-footer__copyright::before{display:block;width:10px;height:10px;-webkit-filter:blur(1px);filter:blur(1px);opacity:.5;bottom:120px;left:50%;margin-left:85px;background-size:10px 10px}.ie9 .site-footer__copyright::before{display:none}@media (min-width:641px){.site-footer__copyright::before{right:40px;bottom:108px;left:auto}}.site-footer__copyright::after,.site-footer__design::before{display:block;left:50%;content:"";width:10px;height:10px}.site-footer__copyright::after{-webkit-filter:blur(1px);filter:blur(1px);opacity:.4;bottom:137px;margin-left:95px;background-size:8px 8px}.ie9 .site-footer__copyright::after{display:none}.site-footer__design{margin:30px 0}@media (min-width:641px){.site-footer__copyright::after{right:27px;bottom:123px;left:auto}.site-footer__design{margin:20px 0}}@media (min-width:1025px){.site-footer__design{width:23.4042553191%;float:right;clear:none;text-align:right;margin:2px 0}}.site-footer__design::before{-webkit-filter:blur(1px);filter:blur(1px);opacity:.3;bottom:147px;margin-left:83px;background-size:6px 6px}.ie9 .site-footer__design::before{display:none}@media (min-width:641px){.site-footer__design::before{right:32px;bottom:140px;left:auto}}.site-footer__design::after{content:"";display:block;width:10px;height:10px;background:url(/images/app-shell/bubble.svg) no-repeat;position:absolute;-webkit-filter:blur(1px);filter:blur(1px);opacity:.2;bottom:164px;left:50%;margin-left:88px;background-size:6px 6px}.ie9 .site-footer__design::after{display:none}.content-webmentions{max-width:940px;margin:0 auto;padding:0 0 48px}.content-webmentions__inner{padding:24px 30px 0}@media (min-width:1025px){.content-webmentions__inner{padding:24px 0 0}}.content-webmentions__list{list-style:none;padding:0}.content-webmentions__list-item{display:inline-block;margin:0 5px 7px}.content-webmentions__list-item .reply{display:inline}.content-webmentions__list-item .reply__avatar{display:inline-block;line-height:1}.content-webmentions__list-item .reply__author,.content-webmentions__list-item .reply__date{display:none}.content-webmentions__list-item .u-photo{border-radius:10px;width:48px;height:48px}.content-webmentions--replies .content-webmentions__list-item{display:block;margin-bottom:24px}.content-webmentions--replies .content-webmentions__list-item .reply__bar p{line-height:1.5;margin:0}.content-webmentions--replies .content-webmentions__list-item .reply__avatar{float:left;margin-right:10px}.content-webmentions--replies .content-webmentions__list-item .reply__author,.content-webmentions--replies .content-webmentions__list-item .reply__date{display:block}.content-webmentions--replies .content-webmentions__list-item .comment__content{clear:both}.content-webmentions__loader{display:block;margin:0 auto;width:60px;height:60px}.content-webmentions__form{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-ms-flex-line-pack:start;align-content:flex-start}.content-webmentions__form-label{margin-bottom:10px;display:block;-webkit-box-flex:0;-ms-flex:0 0 100%;flex:0 0 100%}.content-webmentions__form-input{transition:-webkit-box-shadow 150ms ease-in-out;transition:box-shadow 150ms ease-in-out;transition:box-shadow 150ms ease-in-out,-webkit-box-shadow 150ms ease-in-out;border:1px solid #d1d1d1;padding:20px 18px;display:block;color:#767676;margin:0 0 4px;-webkit-box-flex:0;-ms-flex:0 0 100%;flex:0 0 100%}.content-webmentions__form-input:focus{outline:0;-webkit-box-shadow:0 0 5px 4px #d62839;box-shadow:0 0 5px 4px #d62839}@media (min-width:641px){.site-footer__design::after{right:22px;bottom:150px;left:auto}.content-webmentions__form-input{-webkit-box-flex:8;-ms-flex:8 1 auto;flex:8 1 auto;margin:0 4px 0 0}}.content-webmentions__form-button{background:#007db9;color:#fff;text-align:left;border:0;-webkit-transition:background-color .2s;transition:background-color .2s;padding:18px;-webkit-box-flex:0;-ms-flex:0 0 100%;flex:0 0 100%}@media (min-width:641px){.content-webmentions__form-button{-webkit-box-flex:2;-ms-flex:2 1 auto;flex:2 1 auto}}.content-webmentions__form-button:focus,.content-webmentions__form-button:hover{background:#005b86;text-decoration:underline}.content-webmentions__form-message{padding:20px 18px;border:1px solid #b6bcbf;-webkit-box-flex:0;-ms-flex:0 0 100%;flex:0 0 100%}.video-embed{position:relative;padding-bottom:56.25%;height:0;margin-bottom:1em;border:1px solid #39454b}.video-embed iframe{position:absolute;top:0;left:0;width:100%;height:100%}.video-image-link{display:block;position:relative}.video-image-link::before{content:"▶";display:inline-block;position:absolute;background-color:#ccc;color:var(--link-color);border-radius:50%;width:7vmax;height:7vmax;top:calc(50% - 3.5vmax);left:calc(50% - 3.5vmax);font-size:4vmax;text-align:center;text-indent:1vmax;opacity:.5;padding-top:1vmax}.contact-page,.post{padding:24px 30px 0}.video-image-link:focus::before,.video-image-link:hover::before{opacity:.75}@media (min-width:1025px){.post{padding:24px 0 0}}.post__header{margin:1.25rem 0}.post__meta{font-size:.75rem;line-height:1.25rem}.post__meta-time{margin-right:10px}.post .post__title{font-size:1.778rem;line-height:2.5rem;font-family:Georgia,Times,Times New Roman,serif;color:inherit;margin:1.25rem 0 0}.post .post__meta-tag-list{font-size:inherit;list-style:none;padding:0;display:inline;margin-right:6px}.post .post__meta-tag{font-size:inherit;display:inline-block;margin-right:3px}.frontend-fuel-post .header__strapline,.portfolio-post .header__strapline{display:none}@media (max-width:640px){.post__content{max-width:100%;width:100%;overflow:hidden}}.portfolio-post .header{margin-bottom:150px}@media (min-width:641px) and (max-width:1024px){.portfolio-post .header{margin-bottom:105px}}@media (min-width:1025px){.portfolio-post .header{margin-bottom:95px}}.portfolio-post .post-portfolio-column .figure__image{max-width:100%;margin:0 auto 1.25rem;display:block;width:100%;border:0;-webkit-box-shadow:0 0 10px 1px rgba(209,209,209,.4);box-shadow:0 0 10px 1px rgba(209,209,209,.4)}.portfolio-post .post-portfolio-column--1{margin-bottom:1.25rem}@media (min-width:1025px){.portfolio-post .post-portfolio-column--1{width:21.7391304348%;float:right;margin-left:0;margin-right:0;clear:none}.portfolio-post .post-portfolio-column--2{width:73.9130434783%;float:left;margin-right:-100%;margin-left:0;clear:none}}.portfolio-post .post::after{content:"";display:table;clear:both}.portfolio-post .post__header{margin-top:0;margin-bottom:.3125rem}.portfolio-post .post__title{font-size:1.333rem;line-height:2.5rem;line-height:1.35;margin-top:0}.portfolio-post .post li,.portfolio-post .post p,.public-speaking .public-speaking_inner .public-speaking_meta{line-height:1.25rem;font-size:.75rem}.portfolio-post .post p{margin:.625rem 0}.portfolio-post .post ol,.portfolio-post .post ul{margin:.625rem 0;padding-left:0;list-style:none}.frontend-fuel-post .header{margin-bottom:150px}@media (min-width:641px) and (max-width:1024px){.frontend-fuel-post .header{margin-bottom:105px}}@media (min-width:1025px){.frontend-fuel-post .header{margin-bottom:95px}}.frontend-fuel-post .post__content a{display:block;margin-top:4px}.frontend-fuel-post .post__content h2{margin-top:26px}.tag-page .header{margin-bottom:150px}@media (min-width:641px) and (max-width:1024px){.tag-page .header{margin-bottom:105px}}.tag-page .header__strapline{display:none}@media (min-width:1025px){.tag-page .header{margin-bottom:95px}.contact-page{padding:24px 0 0}}.contact-page__label{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}.contact-page__label.focusable:active,.contact-page__label.focusable:focus,.ie9 .contact-page__label{clip:auto;height:auto;margin:0;overflow:visible;position:static;width:auto}.ie9 .contact-page__label{padding:0}.contact-page__input,.contact-page__textarea{transition:-webkit-box-shadow 150ms ease-in-out;transition:box-shadow 150ms ease-in-out;transition:box-shadow 150ms ease-in-out,-webkit-box-shadow 150ms ease-in-out;border:1px solid #d1d1d1;padding:20px 18px;display:block;margin-bottom:1px;width:100%;color:#767676}.contact-page__input:focus,.contact-page__textarea:focus{outline:0;-webkit-box-shadow:0 0 5px 4px #d62839;box-shadow:0 0 5px 4px #d62839}.ie9 .contact-page__input,.ie9 .contact-page__textarea{margin-bottom:1.25rem}.contact-page__input--submit{background:#007db9;color:#fff;text-align:left;border:0;-webkit-transition:background-color .2s;transition:background-color .2s}.contact-page__input--submit:focus,.contact-page__input--submit:hover{background:#005b86;text-decoration:underline}.contact-page__textarea{height:200px}@media (min-width:641px){.contact-page__column-1{width:47.8260869565%;clear:right;float:left;margin-left:0;margin-right:4.347826087%}}.contact-page form p{margin:24px 0 12px}.contact-page::after{content:"";display:block}.four-oh-four .content-wrapper,.four-oh-four .post-intro-wrapper,.offline .content-wrapper,.offline .navigation__trigger,.offline .post-intro-wrapper{display:none}@media (min-width:641px){.contact-page::after{width:47.8260869565%;clear:right;float:right;margin-right:0;background:url(/images/app-shell/fox-bg.png) top center no-repeat;background-size:100% auto;min-height:580px}.four-oh-four .header{min-height:1650px}}.public-speaking .public-speaking_inner .public-speaking_header{margin:1.25rem 0 0}.public-speaking_inner{padding:24px 30px 0}@media (min-width:1025px){.public-speaking_inner{padding:24px 0 0}}@media (min-width:641px){.offline .header{min-height:1650px}}.offline .navigation__list--secondary{height:0}.content-wrapper .content-wrapper__inner h1{line-height:2.2rem}.content-wrapper .content-wrapper__inner h2{line-height:1.75rem;margin-bottom:.5rem}.content-wrapper .content-wrapper__inner h3{line-height:1.6rem;margin-bottom:.375rem}@media (max-width:640px){.navigation .navigation__list--primary,.navigation .navigation__trigger{min-height:76px}.navigation .navigation__list{padding:10px 30px}}#postBottom{line-height:0}.site-footer__wrapper .site-footer__social{margin:2px 0}.public-speaking_inner .public-speaking_header{margin:1.25rem 0}.public-speaking_inner .public-speaking_meta{font-size:.75rem;line-height:1.25rem}