:root{--text: #020a0d;--background: #f2fafd;--primary: #66b5d6;--secondary: #4789b3;--accent: #6db0cd}@media (prefers-color-scheme: dark){:root{--text: #f2fafd;--background: #0e161c;--primary: #66b5d6;--secondary: #4789b3;--accent: #6db0cd}}@media print{:root{--text: #000000;--background: #ffffff;--primary: #66b5d6;--secondary: #4789b3;--accent: #6db0cd}}*{scroll-behavior:smooth}body{color:var(--text);background:var(--background);padding:2em;font-family:Inter,sans-serif;max-width:80vw;margin:0 auto}.hidden{display:none}a{color:var(--primary);text-decoration:none}a:visited{color:var(--primary)}h2,h3,h4,h5{line-height:1.1}li::marker{content:"‣ "}.background{z-index:-1;position:fixed;top:0;left:0;width:100vw;height:100vh;margin:0}.to-the-top{position:fixed;top:auto;bottom:3rem;left:auto;right:3rem;font-size:2rem}@media (max-width: 800px){.to-the-top{bottom:1rem;right:1rem;font-size:1rem}}.small-caps{font-variant-caps:small-caps}.navbar{padding-bottom:.5rem;border-bottom:var(--accent) solid 2px}.navbar .links{display:flex;gap:5%;justify-content:space-around;text-align:center;align-items:center;font-weight:700;font-size:1.2rem;text-shadow:rgba(0,0,0,.75) 1px 1px 0}.section{margin-bottom:6rem}.section>.center{text-align:center}ul.center{text-align:center}ul.center li::marker{content:""}ul.center li:before{content:"‣ "}.section>h1{font-size:2.25rem}.introduction{margin-bottom:8rem}.introduction h1{text-align:left;font-size:3rem;line-height:.8}.introduction .icon{width:fit-content;max-width:90vw;margin:12rem auto 4rem}@media (max-width: 800px){.introduction .icon{margin-top:4rem}}.introduction .icon .sphere{border-radius:50%;background:color-mix(in hsl,var(--primary),#000000 50%);overflow:hidden;width:10rem;height:10rem;z-index:-1}.introduction .icon .sphere-lit{--move-amount: -5.5%;background:var(--primary);border-radius:50%;position:relative;left:var(--move-amount);top:var(--move-amount);width:100%;height:100%}.introduction .icon .text{position:relative;font-size:3.5rem;line-height:1.1;margin:0 0 0 2.5rem;color:#fff;text-shadow:#000000 4px 4px 0}@media print{.introduction .icon .text{text-shadow:none}}.introduction .icon .forename{margin-top:-48%}.introduction .icon .surname{margin-left:4rem}.introduction .links{font-size:1.5rem;font-weight:700;text-shadow:rgba(0,0,0,.75) 1px 1px 0}.project{margin:0 auto}.project .project-title{padding-bottom:1rem;border-bottom:var(--accent) solid 2px;margin:2rem 0 1rem;text-shadow:rgba(0,0,0,.75) 1px 1px 0}.project .project-title h2{color:var(--primary);font-size:2rem;line-height:.8;display:inline}.project .project-title h3{color:var(--secondary);font-size:1.1rem;line-height:.8;display:inline;margin-left:1rem}@media print{.project .project-title{text-shadow:none}}.project .project-description{padding:1rem}.project .project-description p{padding:0;margin:.3rem 0}.project .project-description h3{padding:0;margin:.75rem 0 .3rem}.project .project-description ul{margin:.3rem 0;padding-left:1rem}.project .project-image{width:fit-content;--border-color: var(--secondary);--border-width: 1px}.project .project-image a{display:block;--border-color: var(--primary);--border-width: 2px}.project .project-image img{border:var(--border-color) solid 2px;display:block;object-fit:contain;max-width:100%;box-shadow:#0003 .5em .5em;margin:0 auto}.project .project-split{display:flex;flex-flow:row nowrap;width:100%}.project .project-split{font-size:1rem;line-height:1.3rem;border-radius:2rem}.project .project-split>*{flex-basis:50%}@media (max-width: 800px){.project .project-split{flex-direction:column;gap:1rem}}.project .project-source{margin-top:.5rem;font-weight:700;font-size:1.2rem}.project .project-source a{margin-right:1.25rem}.project .project-icons{margin:1rem auto;width:fit-content;display:flex;flex-flow:row wrap;font-size:1.5rem;font-weight:700;line-height:3.5rem;gap:1rem}.project .project-icons img{max-height:4rem;width:3.5rem;object-fit:contain}.project .project-tags{font-size:.8rem;color:var(--accent)}.project-filter-bar{font-size:1.25rem}.project-filter-bar input{height:1.25rem;background:color-mix(in hsl,var(--primary),transparent 75%);border:1px solid var(--text);color:var(--text)}.skills-container{display:flex;flex-flow:row wrap;justify-content:space-around;line-height:2rem}.skills-container>*{flex-basis:15vw}@media (max-width: 800px){.skills-container>*{flex-basis:100%}}.skills-container ul{display:block;list-style:none;padding:0;font-size:1rem;font-weight:700}.icon-list>div{display:flex;font-size:1rem;line-height:2.5rem;align-items:center}.icon-list>div>img{object-fit:contain;height:2rem;margin-left:1rem}.icon-list>div>p{object-fit:contain;height:2rem;margin:2px;font-weight:700}.small{font-size:.8rem}.color-primary{color:var(--primary)}.color-secondary{color:var(--secondary)}.color-accent{color:var(--accent)}
