@import'https://fonts.googleapis.com/css2?family=Roboto+Mono:ital,wght@0,100..700;1,100..700&family=Space+Grotesk:wght@300..700&display=swap" rel="stylesheet';body{margin:0;background-color:var(--color-bg);color:var(--color-main);font-family:Space Grotesk,sans-serif;line-height:1.5}html{--header-height: 40px;--spacing-xlow: .2rem;--spacing-low: .5rem;--spacing-common: 1rem;--spacing-large: 2.5rem;--spacing-xlarge: 3.5rem;--transition-time: .2s;--transition-time-button: calc(var(--transition-time))}html.dark{--color-main: white;--color-secondary: rgb(197,197,197);--color-bg: #021B1A;--color-draw: #88F7E6;--color-draw-light: white;--color-draw-shadow: var(--color-main);--color-item-bg: #032221;--color-header: var(--color-item-bg);--color-darkmode-button-shadow: rgb(170,170,170)}html:not(.dark){--color-main: rgb(38,52,46);--color-secondary: rgb(31,31,31);--color-bg: rgb(230,251,245);--color-draw: rgb(10, 120, 90);--color-draw-light: white;--color-draw-shadow: var(--color-draw);--color-item-bg: rgb(248,252,251);--color-header: var(--color-item-bg);--color-darkmode-button-shadow: rgb(120,200,160)}*{margin:0;padding:0}#root{display:flex;flex-direction:column}body,.content *,#header a{transition:background-color var(--transition-time) ease-in-out,color var(--transition-time) ease-in-out,border-color var(--transition-time) ease-in-out}.no-transition *{transition:none!important}.section-container{display:flex;flex-direction:column;align-items:center;max-width:800px;margin-inline:var(--spacing-large);flex:1;padding-top:var(--spacing-large);pointer-events:none;opacity:0;animation:appear;animation-timeline:--content-scroller;animation-range:50px 300px}#header.scrolled+.content .section-container{pointer-events:initial;opacity:1}footer{border-top:solid 1px var(--color-secondary);margin-inline:var(--spacing-common);padding-block:var(--spacing-low)}.section-title{width:fit-content;align-self:center;font-weight:400;font-size:2.7rem;cursor:default}.section-title span{color:var(--color-draw)}.section-title:before{position:absolute;right:calc(100% + var(--spacing-large));top:35%;height:40%;width:var(--spacing-xlarge);border-radius:8px;background-color:var(--color-main);pointer-events:none;transition:background-color var(--transition-time)}.scroll-dummy{position:absolute;height:120px}.animated-underline{position:relative}.animated-underline:after{content:"";position:absolute;bottom:2px;height:2px;background-color:var(--color-draw);width:0;right:0;left:auto;transition:width var(--transition-time) ease}.animated-underline:hover:after,.hero-cta:hover .animated-underline:after{width:100%;left:0;right:auto}h3{font-weight:400}section{padding-bottom:var(--spacing-xlarge);display:flex;justify-content:center}.hidden{opacity:0}.shown{animation:appear-from-below .15s linear}@keyframes appear-from-below{0%{opacity:0;transform:translateY(40px)}to{opacity:1}}p span{font-weight:700}strong{font-style:normal;color:var(--color-draw)}h2{font-size:1.5rem}g,path{transition:inherit}.content-wrapper{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:auto}.content{width:100%;overflow:auto;scroll-behavior:smooth;scrollbar-width:thin;scroll-timeline-name:--content-scroller;position:relative}.no-linebreak{white-space:nowrap}@media screen and (max-width: 1024px){.content-wrapper{flex-direction:column-reverse}}@media screen and (max-width: 768px){.section-container{margin-inline:var(--spacing-common)}.section-title{font-size:2.2rem}.section-title:before{right:calc(100% + 2 * var(--spacing-common))}footer{padding-block:calc(var(--spacing-low) + 2px)}h2{font-size:1.4rem}}#header{height:var(--header-height);width:100%;align-self:center;position:sticky;top:0;font-family:Roboto Mono,monospace;color:var(--color-main);background-color:var(--color-bg);transition:box-shadow calc(var(--transition-time) / 2),color var(--transition-time) ease-in-out,background-color var(--transition-time) ease-in-out,border-color var(--transition-time) ease-in-out;z-index:10;opacity:0;animation:appear .5s .6s forwards}@keyframes appear{0%{opacity:0}to{opacity:1}}#header.scrolled{box-shadow:0 0 2px}#header nav{height:100%;display:flex;flex-direction:row;justify-content:center;gap:var(--spacing-common);padding-inline:var(--spacing-common);position:relative}#header nav .nav-center{display:flex;gap:calc(var(--spacing-common) + var(--spacing-low))}#header-title{position:absolute;left:var(--spacing-common)}#header-contact,#header-contact:visited{font-weight:700;font-size:1.05rem;color:var(--color-draw);transition:color var(--transition-time) ease-in-out}#header nav .header-buttons{position:absolute;right:var(--spacing-common);align-self:center;display:flex;gap:var(--spacing-low)}#header nav a{display:block;padding-block:calc(var(--header-height) / 2 - 1em * .75 + 1px);text-decoration:none}#header nav a:hover:not(.resume-link):not(#dark-toggle):not(#language-toggle){transform:translateY(-3px);transition:transform var(--transition-time-button)}#header nav a:hover,#header nav a:hover i{font-weight:700}#header nav a.resume-link{padding-inline:var(--spacing-common);gap:var(--spacing-low)}#header nav a.resume-link i{display:inline;align-self:center}#header nav a i{display:none}#dark-toggle,#language-toggle{width:calc(var(--header-height) - 8px);cursor:pointer}#dark-toggle{color:var(--color-darkmode-button-shadow);background-color:var(--color-draw-shadow);border:solid 1px var(--color-draw-shadow);box-shadow:0 0 var(--color-darkmode-button-shadow)}#dark-toggle:before{color:var(--color-bg);transition:color var(--transition-time) ease-in-out}#language-toggle{border:solid 1px var(--color-main)}a.resume-link,#language-toggle{background-color:var(--color-item-bg);border:solid 1px var(--color-main)}#header nav #dark-toggle,#header nav a.resume-link,#header nav #language-toggle{align-self:center;display:flex;justify-content:center;align-items:center;height:calc(var(--header-height) - 14px);padding-block:0;padding-inline:var(--spacing-low);border-radius:4px}.resume-link:not(:active),#language-toggle:not(:active){box-shadow:-2px 3px}#dark-toggle:not(:active){box-shadow:-2px 3px}#dark-toggle:active,.resume-link:active,#language-toggle:active{transform:translate(-2px,3px)}a,a:visited{color:var(--color-main)}@media screen and (max-width: 1024px){#header{flex-shrink:0;position:sticky;top:auto;bottom:0;border-top:solid 1px var(--color-main)}#header.scrolled{box-shadow:none}#header nav{justify-content:center}#header nav #header-title{position:initial}#header nav .nav-center{opacity:1;gap:var(--spacing-common)}#header nav .header-buttons{position:initial;gap:var(--spacing-common)}#header nav a{display:flex;padding-block:0;justify-content:center;align-items:center}#header nav a:hover:not(.resume-link):not(#dark-toggle):not(#language-toggle){transform:none}#header nav a span{display:none}#header nav a i{display:inherit;font-size:1.5rem}#header nav a:hover,#header nav a:hover i{font-weight:400}#header nav #dark-toggle,#header nav a.resume-link,#header nav #language-toggle{padding:0;width:auto;border:none;box-shadow:none;font-size:1.5rem}#header nav a.resume-link,#header nav #language-toggle{background-color:transparent}#dark-toggle:active,.resume-link:active,#language-toggle:active{transform:none}#header nav #dark-toggle{padding:2px;border-radius:50%}}@media screen and (max-width: 370px){#header nav a i{font-size:1.2rem}}.hero-container{padding-top:calc(50vh - 220px);display:flex;flex-direction:column;justify-content:center}.hero{width:800px;height:400px;margin-inline:auto;display:flex;flex-direction:column;flex-wrap:wrap-reverse;justify-content:center;align-items:flex-end;gap:var(--spacing-common)}.hero>*{max-width:500px;order:2}@keyframes appear-from-left{0%{opacity:0;transform:translate(-10px)}to{opacity:1}}@keyframes appear-and-scale{0%{opacity:0;transform:scale(.97)}to{opacity:1}}@keyframes appear-from-above{0%{opacity:0;transform:translateY(-10px)}to{opacity:1}}@keyframes appear-from-right{0%{opacity:0;transform:translate(10px)}to{opacity:1}}.hero-img-container{position:relative;min-width:256px;max-width:256px;order:9;opacity:0;animation:appear-and-scale .3s .2s ease-in-out forwards}.hero-img{display:block;width:100%;transition:rotate var(--transition-time);backface-visibility:hidden}.villain-img{position:absolute;top:0;left:0;width:100%;transition:rotate var(--transition-time);backface-visibility:hidden;rotate:y -180deg}.hero-img-container,.hero-img,.villain-img{border-radius:4%}.hero-img-container:hover .hero-img{rotate:y 180deg}.hero-img-container:hover .villain-img{rotate:y 0deg}.hero-heading{display:flex;flex-direction:column;gap:var(--spacing-common)}.hero-title{font-size:3.3rem;line-height:1.2;opacity:0;animation:appear-from-left .3s .2s ease-in-out forwards}.wave-hand{display:inline-block;transform-origin:65% 75%;cursor:default;animation:wave .9s ease-in-out infinite paused}.hero-title:hover .wave-hand{animation-play-state:running}@keyframes wave{50%{rotate:30deg}}.hero-info{margin-top:calc(0px - var(--spacing-low));gap:var(--spacing-common);display:flex;align-items:center;color:var(--color-secondary);opacity:0;animation:appear-from-left .3s .3s ease-in-out forwards}.hero-subtext{font-size:1.1rem;color:var(--color-main);opacity:0;animation:appear-from-left .3s .4s ease-in-out forwards}.hero-detail:after{bottom:0;height:1.5px;background-color:var(--color-draw)}.hero-ctas{margin-top:var(--spacing-common);display:flex;gap:var(--spacing-common);flex-wrap:wrap;opacity:0;animation:appear-from-left .3s .5s ease-in-out forwards}.hero-cta{display:flex;align-items:center;height:2em;font-size:1.2rem;border-radius:4px;padding-block:var(--spacing-low);padding-inline:var(--spacing-common);text-decoration:none}.hero-cta .animated-underline:after{height:1.5px}.hero-cta.primary .animated-underline:after{background-color:var(--color-bg)}.hero-cta.secondary .animated-underline:after{background-color:var(--color-draw-shadow)}.hero-cta.primary{color:var(--color-bg);background-color:var(--color-draw-shadow);font-weight:700;border:solid 1px var(--color-draw-shadow)}.hero-cta.secondary{color:var(--color-draw-shadow);background-color:var(--color-bg);font-weight:600;border:solid 1px}@media screen and (max-width: 1024px){.hero-container{padding-top:0;padding-bottom:0;min-height:calc(100vh - var(--header-height))}.hero{flex-direction:column;padding:var(--spacing-common);gap:var(--spacing-common);width:auto;max-width:400px;align-items:flex-end;justify-content:flex-end;height:auto}.hero-img-container{min-width:200px;width:100%;max-width:400px;order:1}.hero-title{order:0;animation-delay:.1s}.hero-img-container,.hero-title,.hero-info,.hero-subtext,.hero-ctas{animation-name:appear-from-left}.hero-img-container{animation-delay:.3s}.hero-ctas{width:100%}.hero-cta{flex-grow:1;justify-content:center;font-size:1.1rem}}@media screen and (max-width: 768px){.hero-cta .animated-underline:after{display:none}.hero-title{font-size:2.8rem}}@media screen and (max-width: 480px){.hero-title{font-size:2.5rem}.hero-ctas{gap:var(--spacing-low);flex-direction:column}.hero-cta{padding-block:0}}.about{display:flex;flex-direction:column;gap:var(--spacing-large)}.about-container{display:flex;flex-direction:row-reverse;gap:var(--spacing-xlarge)}.about-img-container{aspect-ratio:1 / 1;flex:2;max-width:400px;max-height:400px;margin:auto;position:relative}.about-portrait{display:block;max-width:100%;max-height:100%;margin:auto;align-self:center;border-radius:50%}.about-portrait-description{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;justify-content:center;align-items:center;font-size:1.5rem;color:transparent;transition:all var(--transition-time);border-radius:50%}.about-portrait-description:hover{background-color:#1f1f1fb3;color:var(--color-main)}.about-details{flex:3;height:100%}.about-details h2{font-style:italic;font-weight:400;position:relative;color:var(--color-main);transition:color var(--transition-time)}.about-details h2 span{opacity:0}.about-details h2:hover span{animation:blink 1s var(--transition-time) step-start infinite}.about-details h2:hover{color:var(--color-draw)}.about-details p{color:var(--color-secondary)}.about-details p a{text-decoration:none;font-weight:400}.about-details p a:hover{text-decoration:underline}.about-details p em,.about-details p a{color:var(--color-main)}@keyframes blink{50%{opacity:1}}.about-details h2+p{margin-top:var(--spacing-common)}@media screen and (max-width: 800px){.about-container{flex-direction:column;gap:var(--spacing-common)}.about-img-container{max-width:100%;max-height:100%}}.project{display:flex;flex-direction:column;gap:var(--spacing-common);padding:var(--spacing-common);border:solid 1px var(--color-secondary);outline:solid 0px var(--color-draw);transition:box-shadow var(--transition-time),outline .1s,border-color .1s ease-in-out,background-color var(--transition-time) ease-in-out}.project:hover{box-shadow:-8px 8px var(--color-draw);outline-width:1px;border-color:var(--color-draw);background-color:var(--color-item-bg)}.project:hover .project-overlay{opacity:1}.project:hover .project-title{color:var(--color-draw)}.project-img-container{max-width:700px;display:flex;align-items:center;position:relative}.project-img{display:block;width:100%;border:1px solid var(--color-main)}.project-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;justify-content:center;align-items:center;opacity:0;background-color:#0009;transition:opacity var(--transition-time)}.project-link{font-size:1.5rem;padding:1rem;color:#fff;border:solid 1px white;border-radius:4px;transition:background-color var(--transition-time-button);text-decoration:none}.project-link:visited{color:#fff}.project-link:hover{background-color:#fff3}.project-description{color:var(--color-secondary)}.project-icons{flex:1;margin-top:var(--spacing-common);display:flex;flex-direction:row;align-items:flex-end;gap:var(--spacing-common);flex-wrap:wrap}@media screen and (max-width: 800px){.project,.project.reversed{flex-direction:column}.project-text{width:auto}}.project-icon{display:flex;width:3em;height:3em;justify-content:center;align-items:center;border:solid 1px var(--color-secondary);transition:var(--transition-time-button) ease-in-out;transition-property:background-color,border-color}.project-icon i{color:var(--color-main);font-size:2rem}.project-icon i,.project-icon svg{transition:color var(--transition-time-button) ease-in-out}.project-icon svg{color:var(--color-main);width:2em;height:2em}.project-icon:hover{background-color:var(--color-draw);border-color:var(--color-draw)}.project-icon:hover i,.project-icon:hover svg{color:var(--color-bg)}.projects-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-common);margin-top:var(--spacing-large)}.contact{padding-top:var(--spacing-large);border-top:solid 1px var(--color-secondary);gap:var(--spacing-common);max-width:400px}.contact .animated-underline:after{height:3px}.contact-title{font-weight:400;font-size:2.7rem;cursor:default}.contact-title span{color:var(--color-draw)}.contact-mail{-webkit-user-select:all;user-select:all}.contact-list{display:flex;justify-content:center;gap:var(--spacing-common);padding:0;flex-wrap:wrap}.contact-item{list-style:none;color:var(--color-main)}.contact-item img{width:30px}.contact-container{text-align:center}.contact-divider{content:"";width:var(--spacing-xlarge);margin:auto;height:1px;background-color:var(--color-secondary)}@media screen and (max-width: 768px){.contact-title{font-size:2.2rem}}.contact-icon i{font-size:1.5rem}.contact-icon svg{max-width:1.5em;max-height:1.5em}.contact-icon{display:flex;width:3em;height:3em;justify-content:center;align-items:center;border:solid 1px var(--color-main);border-radius:4px;background-color:var(--color-bg);transition:all var(--transition-time-button) ease-in-out}.contact-icon span{color:var(--color-main);height:1.5em;transition:var(--transition-time-button) ease-in-out;transition-property:background-color,border-color,transform}.contact-icon:hover{background-color:var(--color-draw);border-color:var(--color-draw);transform:scale(1.1)}.contact-icon:hover span{color:var(--color-bg)}.skill-icon{flex-grow:1;display:flex;width:auto;padding:var(--spacing-common);position:relative;justify-content:flex-start;align-items:flex-start;gap:1em;border:solid 1px var(--color-main);color:var(--color-main)}.skill-icon:hover{border-color:var(--color-draw-shadow);background-color:var(--color-draw-shadow)}.skill-text{pointer-events:none;display:flex;justify-content:center;gap:1em}.skill-text i{font-size:1.5em}.skill-icon:hover .skill-text{color:var(--color-bg)}.skill-popup{pointer-events:none;position:absolute;top:calc(100% + var(--spacing-low));left:-1px;width:max-content;max-width:300px;height:fit-content;padding:var(--spacing-low);border:solid 1px;border-radius:3px;background-color:var(--color-item-bg);color:var(--color-main);line-height:normal;z-index:2;opacity:0%;transition:opacity var(--transition-time) ease-in-out}.skill-icon:hover .skill-popup,.skill-icon:active .skill-popup{opacity:100%}.skill-popup span{font-size:.9rem}.skill-popup.top{bottom:calc(100% + var(--spacing-low));top:auto}.skill-popup.left{right:-1px;left:auto}@media screen and (max-width: 600px){.skill-popup{max-width:250px}}.skills-list{width:100%;display:flex;flex-wrap:wrap;gap:var(--spacing-common);margin-top:var(--spacing-large)}.skills-list:after{content:"";flex-grow:20}.skills-section{overflow:hidden}.experience{padding:var(--spacing-large);border:solid 1px var(--color-main);display:flex;flex-direction:column;gap:calc(2 * var(--spacing-common));outline:solid 0px var(--color-draw);transition:box-shadow var(--transition-time),outline .1s,border-color .1s ease-in-out,background-color var(--transition-time) ease-in-out}.experience:hover{box-shadow:-10px 10px var(--color-draw);outline-width:1px;border-color:var(--color-draw);background-color:var(--color-item-bg)}.experience-header{display:flex;flex-direction:row;justify-content:space-between}.experience-title{font-size:1.1rem;font-weight:700;position:relative}.experience-title:after{content:"";position:absolute;bottom:0;height:2px;background-color:var(--color-draw);width:0;right:0;left:auto;transition:width var(--transition-time)}.experience:hover .experience-title:after{left:0;right:auto;width:100%}@media screen and (max-width: 800px){.experience-header{flex-direction:column;align-items:flex-start}}@media screen and (max-width: 617px){.experience:hover .experience-title:after{width:0}}@media screen and (max-width: 480px){.experience{padding:var(--spacing-common);border-width:2px}.experience:hover{box-shadow:-8px 8px var(--color-draw);outline:none}}.experiences-vertical-container{margin-top:var(--spacing-large);display:flex;flex-direction:row;gap:calc(var(--spacing-large));width:100%}.experiences-container{display:flex;flex-direction:column;flex-grow:1;gap:var(--spacing-common)}.experiences-visual-timeline{position:relative;border-right:solid 2px var(--color-main);height:100%;display:none}.experiences-current-time{position:absolute;width:1em;aspect-ratio:1 / 1;top:0;left:1px;transform:translate(-50%,-100%);border-radius:50%;border:solid 2px var(--color-main);display:flex;justify-content:center;align-items:center}@media screen and (max-width: 480px){.experiences-vertical-container{gap:calc(var(--spacing-common))}}
