:root{--color-bg-dark: hsl(40, 7%, 8%);--color-bg: hsl(40, 7%, 10%);--color-bg-light: hsl(0, 0%, 13%);--color-bg-highlight: hsl(0, 0%, 19%);--color-text: hsl(0, 0%, 95%);--color-text-muted: hsl(0, 0%, 70%);--color-primary: hsl(210, 100%, 68%);--shadow-elevation-1: 0 2px 4px rgba(0, 0, 0, .6);--shadow-elevation-2: 0 4px 6px rgba(0, 0, 0, .7);--ff: system-ui, Avenir, Helvetica, Arial, sans-serif;--h1: bold 1.125rem/1.4em var(-ff);--h2: bold 1rem/1.4em var(-ff);--p: 1.125rem/1.4em var(-ff);--p2: .875/1.4em var(-ff);--navbar-height: 64px}[data-theme=light]{--color-bg-dark: hsl(40, 7%, 87%);--color-bg: hsl(40, 7%, 90%);--color-bg-light: hsl(0, 0%, 96%);--color-bg-highlight: hsl(0, 0%, 81%);--color-text: hsl(0, 0%, 5%);--color-text-muted: hsl(0, 0%, 30%);--color-primary: hsl(210, 100%, 68%);--shadow-elevation-1: 0 2px 4px rgba(0, 0, 0, .1);--shadow-elevation-2: 0 4px 6px rgba(0, 0, 0, .15)}:root{font-family:var(--ff);line-height:1.5;font-weight:400;color-scheme:light dark;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{min-width:320px;min-height:100vh;background-color:var(--color-bg-dark);color:var(--color-text)}a{color:var(--color-text);text-decoration:none;transition:color .2s;cursor:pointer}a:hover{color:var(--color-primary)}a:active{filter:brightness(1.2)}button{cursor:pointer}ul{list-style-position:inside;text-indent:-1.5em;padding-left:1.5em}@media (prefers-reduced-motion: reduce){a{transition:none!important}}#root{max-width:1280px;margin:48px auto 96px;padding:0 36px;text-align:center}html{scroll-behavior:smooth}body{margin:0;padding:0;display:block;justify-content:center}section{scroll-margin-top:var(--navbar-height);padding-top:3rem}section h1{padding-bottom:1.5rem}main#content{min-height:60vh;display:flex;flex-direction:column;align-items:center;gap:2rem}.blog-list,.blog-post{text-align:left;width:100%;max-width:800px;margin:0 auto}.blog-list article{margin-bottom:2rem;background-color:var(--color-bg-light);padding:1.5rem;border-radius:12px;box-shadow:var(--shadow-elevation-1);transition:transform .2s ease}.blog-list article:hover{transform:translateY(-2px)}.blog-list article h2{margin-bottom:.5rem}.blog-list article p{color:var(--color-text-muted)}.blog-post h1{margin-bottom:.5rem}.blog-post small{color:var(--color-text-muted);display:block;margin-bottom:1.5rem}.navbar{display:flex;justify-content:space-between;align-items:center;background-color:var(--color-bg-light);position:fixed;top:0;left:0;right:0;height:var(--navbar-height);z-index:100}.navbar a{padding:1rem 1.5rem;font-size:1.2rem;font-weight:500}.navbar-right{display:flex;height:100%}.navbar-right a.active{background-color:var(--color-bg-highlight)}.navbar-right-theme-toggle{display:flex;justify-content:center;min-width:5rem}.navbar-right-theme-toggle button{width:100%}.navbar-toggle{display:none;flex-direction:column;justify-content:center;cursor:pointer;padding:.5rem 1.5rem;z-index:110}.navbar-toggle span{height:3px;width:30px;background:var(--color-text);margin:4px 0;border-radius:2px;transition:.3s}.navbar-toggle.active span:nth-child(1){transform:rotate(45deg) translate(8px,7px)}.navbar-toggle.active span:nth-child(2){opacity:0}.navbar-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(8px,-8px)}@media (max-width: 768px){.navbar-right{position:absolute;top:var(--navbar-height);right:0;flex-direction:column;background-color:var(--color-bg-light);width:200px;max-height:0;height:auto;overflow:hidden;transition:max-height .3s ease}.navbar-right.active{max-height:500px}.navbar-right-theme-toggle{min-height:3.75rem}.navbar-toggle{display:flex}}@media (max-width: 400px){.navbar-right{width:100%}}@media (prefers-reduced-motion: reduce){.navbar-right,.navbar-toggle span{transition:none!important}}.theme-toggle{background:none;border:none;display:flex;align-items:center;justify-content:center;color:var(--color-text)}.theme-toggle svg{font-size:2rem;transition:color .2s}.theme-toggle:hover{color:var(--color-primary)}.theme-toggle:active{filter:brightness(1.2)}@media (prefers-reduced-motion: reduce){.theme-toggle svg{transition:none!important}}.about-details{display:flex;justify-content:center;margin-top:1rem}.about img{border-radius:50%;box-shadow:var(--shadow-elevation-1)}.about p{max-width:1000px;text-align:left;color:var(--color-text-muted)}.about a{font-weight:600}.about-links{margin-top:2rem}@media (max-width: 768px){.about img{max-width:224px}}.contact{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem 1.5rem}.contact a{display:flex;align-items:center;gap:.5rem;font-size:1.3rem}.contact a svg{font-size:1.5rem;padding-top:.25rem}@media (max-width: 768px){.contact{flex-direction:column;align-items:center}}.footer{background-color:var(--color-bg-light);position:fixed;width:100%;min-height:var(--navbar-height);z-index:100;bottom:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:0 1.5rem}.footer-links{display:flex;gap:1.5rem;padding-top:.25rem;font-size:1.5rem}@media (max-width: 650px){.footer{flex-direction:column-reverse;justify-content:space-around;padding:.3rem 1rem}.footer p{font-size:.75rem}.footer-links{font-size:1.1rem}}.projects h3{margin:3rem 0 1.5rem}.projects h3:first-of-type{margin-top:0}.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}@media (max-width: 1120px){.projects-grid{grid-template-columns:repeat(2,360px);max-width:calc(720px + 1.5rem)}}@media (max-width: 800px){.projects-grid{grid-template-columns:1fr;max-width:100%;padding:0 1rem}}.project-card{position:relative;display:block;width:100%;border-radius:1rem;overflow:hidden;transition:transform .2s;box-shadow:var(--shadow-elevation-1)}.project-card:hover{transform:translateY(-2px)}.project-card:hover .project-card-overlay{background:#000000b3}.project-card-image{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}.project-card-overlay{position:absolute;bottom:0;left:0;right:0;padding:.75rem 1rem;background:#0009;color:#fff;transition:background .2s}.project-card-overlay h3{margin:0}.project-card-title{font-size:1rem;margin:0}@media (prefers-reduced-motion: reduce){.project-card,.project-card-overlay{transition:none!important}}.project-modal-backdrop{position:fixed;inset:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:999;opacity:0;animation:fadeIn .2s forwards}.project-modal{background:var(--color-bg-light);border-radius:1rem;padding:1.5rem 2rem 2rem;max-width:1400px;width:90%;position:relative;max-height:80vh;overflow-y:auto;transform:translateY(-20px);animation:slideIn .2s forwards;display:flex;flex-direction:column;align-items:center}.project-modal-header{display:flex;flex-shrink:0;align-items:center;justify-content:space-between;margin-bottom:1rem;position:relative;width:100%}.project-modal-header h2{font-size:2rem;margin-left:auto;padding-left:30px;font-size:clamp(.5rem,2vw + 1rem,2rem)}.project-modal-header-close{margin-left:auto;display:flex;flex-direction:column;background:none;border:none}.project-modal-header-close span{height:3px;width:30px;background:var(--color-text);margin:4px 0;border-radius:2px}.project-modal-header-close span:nth-child(1){transform:rotate(45deg) translate(8px,7px)}.project-modal-header-close span:nth-child(2){opacity:0}.project-modal-header-close span:nth-child(3){transform:rotate(-45deg) translate(8px,-8px)}.project-modal-header-close:hover span{background:#5badff}.project-modal-header-close:active span{filter:brightness(1.2)}.project-modal-media{flex-shrink:0;position:relative;width:100%;max-width:900px;margin:0 auto 1rem;aspect-ratio:16/9}.project-modal-media .video-wrapper,.project-modal-media .image-wrapper{width:100%;height:100%;overflow:hidden;background:#000}.project-modal-media iframe{width:100%;height:100%;border:none}.project-modal-media .image-wrapper img{width:100%;height:100%;background-color:var(--color-bg-light);object-fit:contain}.project-modal-description{flex:1 1 auto;overflow-y:auto;margin-top:.5rem;padding-right:.5rem;max-width:900px;min-height:100px;width:100%;text-align:left;word-wrap:break-word;overflow-wrap:break-word;white-space:normal;color:var(--color-text-muted)}.project-modal-description a{font-weight:500}.project-modal-description p{margin-bottom:.5rem}.project-modal-description strong,.project-modal-description h1,.project-modal-description h2,.project-modal-description h3,.project-modal-description h4,.project-modal-description h5,.project-modal-description h6{color:var(--color-text)}.project-modal-description h1,.project-modal-description h2,.project-modal-description h3,.project-modal-description h4,.project-modal-description h5,.project-modal-description h6{margin:.5rem 0}@media (max-height: 1000px){.project-modal-media{max-width:500px}}@media (max-height: 700px){.project-modal-media{max-width:300px}}@keyframes fadeIn{to{opacity:1}}@keyframes slideIn{to{transform:translateY(0)}}.experience{display:flex;flex-direction:column;align-items:center}.experience-list{display:flex;flex-direction:column;gap:2rem;text-align:left}.experience-list-entry-header{display:flex;flex-direction:row;justify-content:space-between;align-items:center}.experience-list-entry p,.experience-list-entry-description{margin-top:.5rem;color:var(--color-text-muted)}.experience-resume-button{margin-top:3rem;padding:1rem 2.5rem;background-color:transparent;border:2px solid var(--color-text);border-radius:2rem;cursor:pointer;transition:background-color .2s}.experience-resume-button:hover{background-color:var(--color-text)}.experience-resume-button:hover a{color:var(--color-bg-dark)}.experience-resume-button:active{opacity:.8}.experience-resume-button a{font-size:1.15rem;font-weight:600}@media (max-width: 768px){.experience-list-entry-header{flex-direction:column;text-align:center}}.skills{margin-top:2rem}.skills-groups{display:grid;grid-template-columns:repeat(2,1fr);gap:3rem;max-width:900px}.skills-group{background:var(--color-bg-light);border-radius:.75rem;padding:1.5rem;box-shadow:var(--shadow-elevation-1)}.skills-group h3{font-size:1.3rem;margin-bottom:1rem}.skills-group ul{text-align:left}@media (max-width: 768px){.skills-groups{grid-template-columns:1fr}}a small{color:var(--color-text)}pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}/*!
  Theme: GitHub Dark
  Description: Dark theme as seen on github.com
  Author: github.com
  Maintainer: @Hirse
  Updated: 2021-05-15

  Outdated base version: https://github.com/primer/github-syntax-dark
  Current colors taken from GitHub's CSS
*/.hljs{color:#c9d1d9;background:#0d1117}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#ff7b72}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#d2a8ff}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-variable,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id{color:#79c0ff}.hljs-regexp,.hljs-string,.hljs-meta .hljs-string{color:#a5d6ff}.hljs-built_in,.hljs-symbol{color:#ffa657}.hljs-comment,.hljs-code,.hljs-formula{color:#8b949e}.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo{color:#7ee787}.hljs-subst{color:#c9d1d9}.hljs-section{color:#1f6feb;font-weight:700}.hljs-bullet{color:#f2cc60}.hljs-emphasis{color:#c9d1d9;font-style:italic}.hljs-strong{color:#c9d1d9;font-weight:700}.hljs-addition{color:#aff5b4;background-color:#033a16}.hljs-deletion{color:#ffdcd7;background-color:#67060c}.blog-post{display:flex;flex-direction:column}.blog-post .date{margin-top:-1.5rem}.blog-post .content{flex:1 1 auto;overflow-y:auto;max-width:900px;width:100%;text-align:left;word-wrap:break-word;overflow-wrap:break-word;white-space:normal;color:var(--color-text-muted)}.blog-post .content a{font-weight:500;text-decoration:underline}.blog-post .content p{margin-bottom:1rem}.blog-post .content strong,.blog-post .content h1,.blog-post .content h2,.blog-post .content h3,.blog-post .content h4,.blog-post .content h5,.blog-post .content h6{color:var(--color-text)}.blog-post .content h1,.blog-post .content h2,.blog-post .content h3,.blog-post .content h4,.blog-post .content h5,.blog-post .content h6{margin:1.25rem 0 .75rem;line-height:1.2}.blog-post .content img{display:block;margin:1rem auto;max-width:100%;height:auto}.blog-post .content :not(pre)>code{font-family:Fira Code,monospace;font-size:.9rem;background-color:#303030;color:#f2f2f2;padding:.15em .4em;border-radius:4px;white-space:normal}.blog-post .content pre{margin-bottom:1rem;max-width:90vw;overflow:auto;tab-size:2;word-break:normal;-webkit-hyphens:none;hyphens:none}.blog-post .content pre code{overflow-x:auto;white-space:pre;display:block;min-width:100px;max-width:100%;border-radius:8px;background-color:#303030;color:#f2f2f2;font-size:.95rem}@media (max-width: 768px){.blog-post .content h1{font-size:1.5rem}.blog-post .content small{font-size:.85rem}.blog-post .content .content{font-size:.9rem;line-height:1.6}.blog-post .content pre code{font-size:.8rem;border-radius:6px}.blog-post .content img{border-radius:6px;box-shadow:none}}
