*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media(min-width:640px){.container{max-width:640px}}@media(min-width:768px){.container{max-width:768px}}@media(min-width:1024px){.container{max-width:1024px}}@media(min-width:1280px){.container{max-width:1280px}}@media(min-width:1536px){.container{max-width:1536px}}.visible{visibility:visible}.fixed{position:fixed}.relative{position:relative}.left-4{left:1rem}.top-0{top:0}.z-\[500\]{z-index:500}.mx-auto{margin-left:auto;margin-right:auto}.inline-block{display:inline-block}.flex{display:flex}.grid{display:grid}.aspect-\[4\/3\]{aspect-ratio:4/3}.w-full{width:100%}.min-w-\[275px\]{min-width:275px}.min-w-full{min-width:100%}.max-w-\[40vw\]{max-width:40vw}.max-w-\[425px\]{max-width:425px}.max-w-\[95\%\]{max-width:95%}.max-w-\[var\(--max-page-width\)\]{max-width:var(--max-page-width)}.resize{resize:both}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.justify-stretch{justify-content:stretch}.gap-0{gap:0px}.gap-16{gap:4rem}.gap-2{gap:.5rem}.gap-24{gap:6rem}.gap-4{gap:1rem}.gap-8{gap:2rem}.overflow-x-auto{overflow-x:auto}.overflow-y-hidden{overflow-y:hidden}.border-2{border-width:2px}.border-y-2{border-top-width:2px;border-bottom-width:2px}.border-\[var\(--dark-grey\)\]{border-color:var(--dark-grey)}.border-\[var\(--grey\)\]{border-color:var(--grey)}.border-\[var\(--soft-teal\)\]{border-color:var(--soft-teal)}.object-cover{-o-object-fit:cover;object-fit:cover}.object-center{-o-object-position:center;object-position:center}.p-4{padding:1rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-4{padding-left:1rem;padding-right:1rem}.px-8{padding-left:2rem;padding-right:2rem}.px-\[var\(--page-padding\)\]{padding-left:var(--page-padding);padding-right:var(--page-padding)}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-5{padding-top:1.25rem;padding-bottom:1.25rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pb-12{padding-bottom:3rem}.pb-2{padding-bottom:.5rem}.text-2xl{font-size:1.5rem;line-height:2rem}.leading-none{line-height:1}.text-\[var\(--dark-grey\)\]{color:var(--dark-grey)}.text-\[var\(--grey\)\]{color:var(--grey)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}*{box-sizing:border-box;margin:0;padding:0;text-underline-offset:20%;text-decoration-color:var(--soft-teal);scroll-margin-top:96px}:root{--max-page-width: 1920px;--page-padding: 96px;--off-white: #f9f9f9;--off-black: #333;--grey: #c0c0c0;--dark-grey: #898989;--darker-grey: #4a4a4a;--soft-teal: #4bc7b9;--darker-teal: #2c5e6971;--background: #1e1f24;--bp-mobile: 768px;--bp-desktop: 1280px}html{scroll-behavior:smooth}html.no-smooth{scroll-behavior:auto!important}img{max-width:100%}body{font-family:Fira Code,monospace;font-optical-sizing:auto;font-size:16px;line-height:1.5;font-style:normal;padding:160px var(--page-padding) 0 var(--page-padding);background-color:var(--background);color:var(--off-white);display:flex;width:100%;flex-direction:column;align-items:center;gap:6rem}#root{display:flex;width:100%;flex-direction:column;align-items:center;gap:6rem}main{display:flex;width:100%;flex-direction:column;align-items:center;gap:6rem}html,body{overscroll-behavior:none}body.no-scroll{overflow:hidden}section{width:100%}a{text-decoration:none;color:var(--off-white)}ul{list-style:none}.hashtag{color:var(--soft-teal);padding:0 4px 0 0}h1{font-weight:800;font-size:48px;line-height:1}h2{font-weight:700;font-size:32px;line-height:1}h3{font-weight:500;font-size:24px;line-height:1}h4{font-weight:500}.btn{border:2px solid var(--soft-teal);padding:8px 16px;text-decoration-color:var(--soft-teal);transition:all .2s ease}.btn:hover{background-color:var(--darker-teal);text-decoration:underline;text-decoration-color:var(--soft-teal)}.navbar{position:fixed;top:0;left:0;width:100%;z-index:300;background-color:var(--background);transition:box-shadow .2s ease}.navbar.scrolled{box-shadow:0 2px 6px #0000004d}.navbar .container{padding:20px var(--page-padding);display:flex;align-items:center;justify-content:space-between}.brand-name{font-weight:600}.navbar ul{display:flex;gap:32px}.navbar ul .socials{display:none;gap:48px}.navbar ul .socials a{width:64px;aspect-ratio:1/1}.navbar ul .socials a img{width:100%}.menu-btn{color:var(--dark-grey);font-weight:500}.menu-btn[aria-current=page],.menu-btn[aria-current=true],.menu-btn:hover{color:var(--off-white)}.menu-toggle{display:none;border:2px solid var(--soft-teal);background:transparent;color:var(--off-white);padding:8px 12px;line-height:1;cursor:pointer}.permanent-socials{position:fixed;top:0;left:16px;z-index:500;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}.permanent-socials .line{background-color:var(--grey);width:2px;height:112px;border-radius:0 0 32px 32px;margin:0 0 8px}.permanent-socials .social{aspect-ratio:1/1;height:32px;padding:0}.social img{width:100%}.hero .container{grid-template-columns:1.25fr .75fr;display:grid;align-items:center;justify-content:stretch;gap:4rem}.hero .container .content{display:flex;flex-direction:column;justify-content:space-around;align-items:flex-start;gap:32px}.hero .container .graphic{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0px;width:100%;max-width:425px}.hero .container .content span{color:var(--grey)}.hero .container .graphic img{max-width:95%}.status{display:flex;align-items:center;border:2px solid var(--grey);color:var(--grey);padding:12px 16px;gap:8px;text-wrap:nowrap;min-width:100%}.status .highlight{color:var(--off-white)}.status .icon{aspect-ratio:1/1;width:16px;background-color:var(--soft-teal)}.quote{display:flex;flex-direction:column;align-items:flex-end;width:auto;font-size:24px}.quote span{position:relative;display:inline-block;padding:32px;border:2px solid var(--dark-grey)}.quote .author{padding:16px;color:var(--grey);border-top:none}.quote-open{position:absolute;top:-14.5px;left:12px}.quote-close{position:absolute;bottom:-14.5px;right:12px;transform:rotateX(180deg) rotateY(180deg)}.header{display:flex;align-items:center;justify-content:space-between;padding:0 0 48px}.header .title{display:flex;align-items:center;text-transform:lowercase;text-wrap:nowrap;gap:24px;width:100%}.header .title h2{display:flex;align-items:center;width:100%}.header .title h2:after{content:"";flex:1;height:2px;background-color:var(--soft-teal);min-width:48px;max-width:45%;margin:0 32px}.header .btn{border:none;width:auto;text-wrap:nowrap;align-items:center}.header .btn i{padding:0 0 0 8px}.header .btn:hover i{text-decoration:none}.header .btn:hover{background-color:transparent}.project-list{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));align-items:flex-start;gap:1rem}@media(min-width:768px){.project-list{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1024px){.project-list{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(min-width:1280px){.project-list{grid-template-columns:repeat(4,minmax(0,1fr))}}.project-list .entry{display:flex;flex-direction:column;border:2px solid var(--grey)}.project-list .entry .skills{padding:16px;display:flex;flex-wrap:wrap;gap:16px;line-height:1;color:var(--dark-grey);border-top:2px solid var(--grey);border-bottom:2px solid var(--grey)}.project-list .entry .info{display:flex;flex-direction:column;padding:16px;gap:16px}.project-list .entry .info span{color:var(--grey)}.project-list .entry .info .buttons{display:flex;gap:16px;width:100%}.project-list .entry img{width:100%;aspect-ratio:4/3;-o-object-fit:cover;object-fit:cover;-o-object-position:center;object-position:center;background-color:#4bc7b9}.skills .header .title h2:after{max-width:none}.skills .content{-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;scroll-snap-type:x proximity;display:flex;width:100%;align-items:flex-start;justify-content:flex-start;gap:1rem;overflow-x:auto;overflow-y:hidden;padding-bottom:.5rem}.skill-section{flex:0 0 250px;min-width:275px;border:2px solid var(--dark-grey);display:flex;flex-direction:column;scroll-snap-align:start}.skill-section .header{font-weight:500;border-bottom:2px solid var(--dark-grey);padding:8px}.skill-section ul{padding:8px;display:flex;flex-direction:column;color:var(--dark-grey);gap:8px}.contact .header .title h2:after{max-width:65%}.contact .content{display:flex;width:100%;flex-direction:column;justify-content:space-between;gap:2rem}@media(min-width:768px){.contact .content{flex-direction:row}}.contact .content .text{display:flex;flex-direction:column;justify-content:left;align-items:baseline;gap:32px;max-width:40vw;color:var(--dark-grey)}.contact .content .message-info{display:flex;flex-direction:column;border:2px solid var(--grey);gap:16px;padding:16px}.contact .content .message-info a{display:flex;gap:8px;color:var(--dark-grey);align-items:center}.contact .content .message-info a:hover{color:var(--off-white);text-decoration:underline}.footer{padding:0 0 32px;text-align:center;font-weight:200;color:var(--dark-grey)}@media(max-width:1080px){:root{--page-padding: 64px}.hero .container{display:flex;flex-direction:column;justify-content:stretch;align-items:center;gap:64px}.hero .container .graphic{border:2px solid var(--grey)}.hero .container .status{border:none;border-top:2px solid var(--grey)}.body{gap:64px}}@media(max-width:780px){:root{--page-padding: 48px}.permanent-socials{display:none}h1{font-size:36px}h2{font-size:28px}h3{font-size:18px}h4{font-size:16px}.header .btn{display:none}.header .title h2:after,.contact .header .title h2:after,.skills .header .title h2:after{max-width:none;margin-right:0}.menu-toggle{display:inline-flex;align-items:center;justify-content:center}.navbar .container{background-color:var(--background)}#primary-menu{position:fixed;top:var(--nav-h, 70px);left:0;right:0;bottom:0;background:var(--background);display:flex;flex-direction:column;gap:48px;padding:48px;font-size:32px;-webkit-overflow-scrolling:touch;overflow-y:auto;transform:translateY(-120%);transition:transform .2s ease;z-index:-1}.navbar.open #primary-menu{transform:translateY(0)}#primary-menu .socials{display:flex;position:absolute;bottom:24px;left:0;right:0;align-items:center;justify-content:center;gap:48px}}@media(max-width:480px){:root{--page-padding: 24px}.line,.status .not-highlighted{display:none}.contact .content{display:flex;flex-direction:column;width:100%;gap:32px}.contact .content .text{max-width:none}}.hover\:bg-\[var\(--darker-teal\)\]:hover{background-color:var(--darker-teal)}.hover\:text-\[var\(--off-white\)\]:hover{color:var(--off-white)}.hover\:underline:hover{text-decoration-line:underline}@media(min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:flex-row{flex-direction:row}}@media(min-width:1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-\[1\.25fr_0\.75fr\]{grid-template-columns:1.25fr .75fr}}@media(min-width:1280px){.xl\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}
