/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */@import"https://fonts.googleapis.com/css2?family=Rubik:wght@300;400;500&display=swap";html{line-height:1.15;-webkit-text-size-adjust:100%}body{margin:0}main{display:block}h1{font-size:2em;margin:.67em 0}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:rgba(0,0,0,0)}abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-0.25em}sup{top:-0.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}button,[type=button],[type=reset],[type=submit]{-webkit-appearance:button}button::-moz-focus-inner,[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}.l-xs-1,.l-sm-1,.l-md-1,.l-lg-1,.l-xs-2,.l-sm-2,.l-md-2,.l-lg-2,.l-xs-3,.l-sm-3,.l-md-3,.l-lg-3,.l-xs-4,.l-sm-4,.l-md-4,.l-lg-4,.l-xs-5,.l-sm-5,.l-md-5,.l-lg-5,.l-xs-6,.l-sm-6,.l-md-6,.l-lg-6,.l-xs-7,.l-sm-7,.l-md-7,.l-lg-7,.l-xs-8,.l-sm-8,.l-md-8,.l-lg-8,.l-xs-9,.l-sm-9,.l-md-9,.l-lg-9,.l-xs-10,.l-sm-10,.l-md-10,.l-lg-10,.l-xs-11,.l-sm-11,.l-md-11,.l-lg-11,.l-xs-12,.l-sm-12,.l-md-12,.l-lg-12{position:relative;min-height:1px;padding-left:20px;padding-right:20px}.l-xxs-1,.l-xxs-2,.l-xxs-3,.l-xxs-4,.l-xxs-5,.l-xxs-6,.l-xxs-7,.l-xxs-8,.l-xxs-9,.l-xxs-10,.l-xxs-11,.l-xxs-12{float:left}.l-xxs-1{width:8.3333333333%}.l-xxs-2{width:16.6666666667%}.l-xxs-3{width:25%}.l-xxs-4{width:33.3333333333%}.l-xxs-5{width:41.6666666667%}.l-xxs-6{width:50%}.l-xxs-7{width:58.3333333333%}.l-xxs-8{width:66.6666666667%}.l-xxs-9{width:75%}.l-xxs-10{width:83.3333333333%}.l-xxs-11{width:91.6666666667%}.l-xxs-12{width:100%}@media(min-width: 541px){.l-xs-1,.l-xs-2,.l-xs-3,.l-xs-4,.l-xs-5,.l-xs-6,.l-xs-7,.l-xs-8,.l-xs-9,.l-xs-10,.l-xs-11,.l-xs-12{float:left}.l-xs-1{width:8.3333333333%}.l-xs-2{width:16.6666666667%}.l-xs-3{width:25%}.l-xs-4{width:33.3333333333%}.l-xs-5{width:41.6666666667%}.l-xs-6{width:50%}.l-xs-7{width:58.3333333333%}.l-xs-8{width:66.6666666667%}.l-xs-9{width:75%}.l-xs-10{width:83.3333333333%}.l-xs-11{width:91.6666666667%}.l-xs-12{width:100%}}@media(min-width: 768px){.l-sm-1,.l-sm-2,.l-sm-3,.l-sm-4,.l-sm-5,.l-sm-6,.l-sm-7,.l-sm-8,.l-sm-9,.l-sm-10,.l-sm-11,.l-sm-12{float:left}.l-sm-1{width:8.3333333333%}.l-sm-2{width:16.6666666667%}.l-sm-3{width:25%}.l-sm-4{width:33.3333333333%}.l-sm-5{width:41.6666666667%}.l-sm-6{width:50%}.l-sm-7{width:58.3333333333%}.l-sm-8{width:66.6666666667%}.l-sm-9{width:75%}.l-sm-10{width:83.3333333333%}.l-sm-11{width:91.6666666667%}.l-sm-12{width:100%}}@media(min-width: 992px){.l-md-1,.l-md-2,.l-md-3,.l-md-4,.l-md-5,.l-md-6,.l-md-7,.l-md-8,.l-md-9,.l-md-10,.l-md-11,.l-md-12{float:left}.l-md-1{width:8.3333333333%}.l-md-2{width:16.6666666667%}.l-md-3{width:25%}.l-md-4{width:33.3333333333%}.l-md-5{width:41.6666666667%}.l-md-6{width:50%}.l-md-7{width:58.3333333333%}.l-md-8{width:66.6666666667%}.l-md-9{width:75%}.l-md-10{width:83.3333333333%}.l-md-11{width:91.6666666667%}.l-md-12{width:100%}}@media(min-width: 1200px){.l-lg-1,.l-lg-2,.l-lg-3,.l-lg-4,.l-lg-5,.l-lg-6,.l-lg-7,.l-lg-8,.l-lg-9,.l-lg-10,.l-lg-11,.l-lg-12{float:left}.l-lg-1{width:8.3333333333%}.l-lg-2{width:16.6666666667%}.l-lg-3{width:25%}.l-lg-4{width:33.3333333333%}.l-lg-5{width:41.6666666667%}.l-lg-6{width:50%}.l-lg-7{width:58.3333333333%}.l-lg-8{width:66.6666666667%}.l-lg-9{width:75%}.l-lg-10{width:83.3333333333%}.l-lg-11{width:91.6666666667%}.l-lg-12{width:100%}}.container{margin-right:auto;margin-left:auto;padding-left:20px;padding-right:20px}.container:before,.container:after{content:" ";display:table}.container:after{clear:both}@media(min-width: 541px){.container{width:calc(100% - 40px)}}@media(min-width: 768px){.container{width:calc(100% - 40px)}}@media(min-width: 992px){.container{width:900px}}@media(min-width: 1200px){.container{width:1200px}}.container--full{overflow:hidden}.container--full div[class^=l-]{padding-left:0;padding-right:0}.slide-up-enter-active,.slide-up-leave-active{transition:all .3s ease-in-out}.slide-up-enter-from{opacity:0;transform:translateY(30px)}.slide-up-leave-to{opacity:0;transform:translateY(-30px)}.v-enter-from,.v-leave-to{opacity:0}html{scroll-behavior:smooth}body{font-family:"Rubik",serif;font-size:16px;overflow-x:hidden;background-color:#f5f5f7}@media(min-width: 992px){main{margin-bottom:100vh}}.container{max-width:1050px}h1{font-size:3.6em;letter-spacing:-3px;font-weight:300;line-height:1.3em}@media(max-width: 991px){h1{font-size:2.2em}}h2{font-size:2.8em;font-weight:500;margin-bottom:0}@media(max-width: 991px){h2{font-size:1.8em}}h3{font-size:2em;font-weight:500;margin-bottom:.5em;margin-top:.2em}@media(max-width: 991px){h3{font-size:1.5em}}p{font-size:1.4em;font-weight:100;line-height:1.7em}@media(max-width: 991px){p{font-size:1.2em}}p a{display:inline-block;font-size:1em;background:#47ecd5;padding:0px 5px;color:#000;box-shadow:4px 6px rgba(0,0,0,.1254901961);text-decoration:none}@media(min-width: 992px){p a:hover{transform:translateY(4px);box-shadow:none}}a{font-size:1.4em;text-decoration:none}a:hover{text-decoration:underline}.blog-post{flex:1;display:flex;gap:6em;background:#fff;padding:2.8em 2.5em;box-shadow:0 0 15px rgba(0,0,0,.2);position:relative;z-index:1}.blog-post img{width:400px;border:4px solid}.blog-post--group{display:flex;flex-direction:column;gap:5em}.blog-post a{color:#47ecd5;text-decoration:none}.blog-post a:hover{text-decoration:underline}.chip{background:#627fef;color:#fff;display:inline-block;padding:.5em .7em}.chip-group{display:flex;flex-wrap:wrap;gap:1em}.chip-group--alt .chip{background:#47ecd5;color:#000}.code-link{display:flex;color:#000;background:#fff;cursor:pointer;transition:all .3s;height:250px;flex:1;align-items:center;justify-content:center;box-shadow:15px 18px rgba(0,0,0,.1254901961);transition:all .1s ease;border:3px solid;max-width:550px}@media(max-width: 991px){.code-link{width:95%;display:block}}@media(min-width: 992px){.code-link:hover{transform:translateY(10px);box-shadow:none}}.code-link img{width:60%}.code-link--wrap{display:flex;align-items:center;justify-content:space-between;gap:60px}@media(max-width: 991px){.code-link--wrap{margin-top:60px;flex-direction:column}}a.contact-link{display:inline-block;background:#47ecd5;padding:20px;margin:15px 0;text-decoration:none;color:#000;transition:all .1s ease;box-shadow:10px 12px hsla(0,0%,100%,.1882352941);font-size:2em}@media(max-width: 991px){a.contact-link{font-size:1.6em;padding:15px 20px}}@media(min-width: 992px){a.contact-link:hover{transform:translateY(10px);box-shadow:none}}.computer-monitor{display:flex;position:relative;align-items:center;flex-direction:column;justify-content:center}@media(max-width: 991px){.computer-monitor{width:95%}}.computer-monitor--screen{padding:8px;background:#202020}.computer-monitor--screen img{max-height:220px;width:100%}@media(max-width: 991px){.computer-monitor--screen img{max-width:300px}}.computer-monitor--stand{width:20px;height:20px;background:#202020}.computer-monitor--base{width:60px;height:10px;background:#202020}header{position:fixed;top:0;z-index:2;display:flex;align-items:center;justify-content:flex-end;width:100%;background:#f5f5f7;transition:.2s ease-in-out}header nav{display:flex;justify-content:space-between;align-items:center;gap:60px;padding:30px 50px}header nav a{color:#000;text-decoration:none;text-transform:uppercase;font-size:18px;font-weight:100}.bg-tint{background:#f5f5f7}.bg-dark{position:relative;background:#fff;color:#000}.highlight{font-weight:500;color:#627fef}.diag{position:relative}.diag::after{content:"";width:100%;height:70px;position:absolute;right:0;top:-35px;background:#fff;z-index:1}@media(max-width: 991px){.diag::after{height:50px}}.diag-1::after{transform:skewY(-1.2deg)}.diag-2::after{transform:skewY(1.2deg)}.text-accent{position:relative;display:inline-block}.text-accent:before{transition:all .8s;content:"";position:absolute;left:50%;bottom:-2px;width:0;height:10px;transform:skew(-12deg) translateX(-50%);background:rgba(110,138,249,.3137254902);z-index:0}.text-accent.in-view:before{width:98% !important}.text-accent--alt:before{background:rgba(71,236,213,.5019607843)}.code-icon--path{stroke-dashoffset:100;stroke-dasharray:90}.code-icon.in-view .code-icon--path{animation:animateSvg 3.4s linear forwards}@keyframes animateSvg{to{stroke-dashoffset:0}}.wave-hand,.wave-again{display:inline-block;animation:waveHand 1.5s forwards;cursor:pointer}.wave-hand{animation-delay:.7s}@keyframes waveHand{0%{transform:rotate(0deg)}25%{transform:rotate(15deg) scale(1.2)}50%{transform:rotate(-15deg) scale(1.2)}75%{transform:rotate(15deg) scale(1.2)}100%{transform:rotate(0deg) scale(1)}}@keyframes draw{to{stroke-dashoffset:0}}.cols-2{display:flex;align-items:center;gap:80px}@media(max-width: 991px){.cols-2{display:block}}@media(max-width: 991px){.hero h1{font-size:2em;letter-spacing:-2px;line-height:1.4em}}.headshot{width:135px;height:135px;border:double 10px rgba(0,0,0,0);border-radius:50%;background-image:linear-gradient(white, white),linear-gradient(to right, #47ecd5, #627fef);background-origin:border-box;background-clip:content-box,border-box}@media(max-width: 991px){.headshot{width:100px;height:100px}}.mobile-phone{display:flex;align-items:center;flex-direction:column;justify-content:center;max-width:125px}@media(max-width: 991px){.mobile-phone{margin:0}}.mobile-phone--screen{border-top-right-radius:20px;border-top-left-radius:20px;padding:8px 8px 0;background:#2b2b2b}.mobile-phone--screen img{width:100%;max-height:250px;border-radius:15px}.mobile-phone--bottom{display:flex;align-items:center;justify-content:center;padding-bottom:10px;width:100%;background:#2b2b2b;border-bottom-right-radius:20px;border-bottom-left-radius:20px}.mobile-phone--bottom--button{width:15px;height:15px;border-radius:50%;background:#868686}.portfolio-group{display:flex;justify-content:space-between;flex-direction:column}@media(max-width: 991px){.portfolio-group{margin-left:-5px}}.portfolio-item{margin-bottom:5em;border:3px solid;padding:2em 3em 1.3em;box-shadow:15px 18px rgba(0,0,0,.1254901961);color:inherit;text-decoration:none;font-size:inherit;transition:all .1s ease}@media(max-width: 991px){.portfolio-item{margin-bottom:2em;padding:2em 1em 2em;margin:20px 0;text-align:center;align-items:center;box-shadow:11px 17px rgba(0,0,0,.1254901961)}}@media(min-width: 992px){.portfolio-item:hover{text-decoration:none;transform:translateY(10px);box-shadow:none}.portfolio-item:hover .portfolio-item--button{background:#dfdfdf}}.portfolio-item:last-child{margin-bottom:3em}@media(max-width: 991px){.portfolio-item:last-child{margin-bottom:1em}}.portfolio-item--content{display:flex;position:relative;align-items:flex-start;justify-content:center;gap:3em}.portfolio-item--content>div:first-child{flex:6}.portfolio-item--content>div:first-child.wide{flex:10}.portfolio-item--content>div:last-child{flex:3;display:flex;justify-content:center;align-items:center}@media(max-width: 991px){.portfolio-item--content{display:flex;flex-direction:column-reverse;align-items:center;gap:1.5em}}.portfolio-item--description p{font-size:1.3em}.portfolio-item--description h3{margin-bottom:0}@media(max-width: 991px){.portfolio-item--description p{font-size:1.1em}}.portfolio-item--meta{display:flex;justify-content:space-between;padding-top:15px;border-top:2px solid;margin-top:30px}@media(max-width: 991px){.portfolio-item--meta{display:block;margin-top:15px;padding-top:0;border-top:none}}.portfolio-item--skills{display:flex;align-items:center}@media(max-width: 991px){.portfolio-item--skills{margin-top:0;justify-content:center}.portfolio-item--skills .chip-group{gap:.5em;justify-content:center}}.portfolio-item--button{display:inline-block;border-radius:30px;border:3px solid #000;padding:10px 40px;font-weight:500;transition:all .2s ease}@media(max-width: 991px){.portfolio-item--button{margin-top:25px;padding:15px 40px}}section{background-color:#fff}.section--hero{padding-top:70px;min-height:800px}@media(max-width: 991px){.section--hero{padding-top:30px;padding-bottom:30px;min-height:720px}}.section--recent-projects{padding-top:50px;padding-bottom:40px}@media(max-width: 991px){.section--recent-projects{padding-top:0px;padding-bottom:50px}}.section--about-me{padding-top:120px;padding-bottom:110px;text-align:center}.section--about-me p{font-size:1.7em;margin-top:2em;margin-bottom:2em}@media(max-width: 991px){.section--about-me{padding-top:50px;padding-bottom:50px;text-align:left}.section--about-me p{font-size:1.3em}}.section--code-links{padding:50px 0 170px;text-align:center}@media(max-width: 991px){.section--code-links{padding-top:20px;padding-bottom:110px}}.section--contact{display:flex;align-items:center;background:#202020;color:#fff;overflow:hidden;height:100vh;min-height:500px}@media(min-width: 992px){.section--contact{position:fixed;top:0;left:0;z-index:-1;width:100%;opacity:0;padding:0}.section--contact.visible{opacity:1}}@media(max-width: 991px){.section--contact p{font-size:1.5em}}.section--contact .code-icon{padding-top:100px;width:450px}@media(max-width: 991px){.section--contact .code-icon{width:50%;max-width:300px;padding-top:30px}}.section-intro{margin-bottom:5em}@media(max-width: 991px){.section-intro{margin-bottom:2em}}.section-intro p{font-size:1.8em}.skill{display:flex;flex-direction:column;margin-bottom:150px}.skill-intro{font-size:2em;font-weight:400}@media(max-width: 991px){.skill-intro{font-size:1.7em;margin:.5em 0 1em;font-size:1.3em;font-weight:500}}.skill-wrap{display:flex;align-items:center;justify-content:space-between;gap:30px}@media(max-width: 991px){.skill-wrap{display:block}}.skill-zoom{transform:scale(1.5)}.skill-icon{width:60px;height:60px;cursor:pointer;transition:.12s ease-in-out}@media(max-width: 991px){.skill-icon{width:50px;height:50px;flex:0 0 calc(25% - 15px)}}.skill-icon--group{display:flex;flex:1;justify-content:space-between;margin-right:20px}@media(max-width: 991px){.skill-icon--group{flex-wrap:wrap;justify-content:space-between;margin-right:0;row-gap:20px;text-align:center}}.skill-name{display:flex;position:relative;transition:1s ease;text-align:center;font-size:.7em;width:250px;flex-shrink:0}@media(max-width: 991px){.skill-name{width:100%;font-size:.6em}}.skill-name--wrap{width:250px;position:absolute;top:-42px;padding:10px 0;background:#47ecd5}@media(max-width: 991px){.skill-name--wrap{top:30px;width:calc(100% - 10px);padding:5px;font-size:.9em}}.skill-name p{position:relative;margin:0;font-weight:500;font-size:3em}[v-cloak]{display:none}/*# sourceMappingURL=style.css.map */
