:root{--font-color:#fff;--hover-color:#ccc;--highlight-color:#26E7B9;--highlight-color-rgb:38,231,185;--bg-color:#222;--bg-light:#444;--bg-lighter:#666;--content-max-width:60rem;--whiteFadeOffset:25%;--whiteFadeBg:rgba(0,0,0,0);--whiteFadeColor:rgba(255,255,255,.75)}@property --whiteFadeOffset{syntax:"<percentage>";initial-value:25%;inherits:false}@property --whiteFadeBg{syntax:"<color>";initial-value:rgba(0,0,0,0);inherits:false}@property --whiteFadeColor{syntax:"<color>";initial-value:rgba(255,255,255,.75);inherits:false}*{scrollbar-width:auto;scrollbar-color:var(--bg-lighter) var(--bg-light)}::-webkit-scrollbar{height:0;width:.5rem}::-webkit-scrollbar-track{background:var(--bg-color)}::-webkit-scrollbar-thumb{background-color:var(--bg-light);border-radius:0;border:1px solid var(--bg-color)}*{box-sizing:border-box;padding:0;margin:0}body,html{height:100svh}body{font-family:ui-monospace,Cascadia Code,Source Code Pro,Menlo,Consolas,DejaVu Sans Mono,monospace;font-weight:300;color:var(--font-color);background:#000;background:url(/img/ep_naturalblack.png) repeat;display:grid;grid-template-columns:[full-start] 1.5rem [padded-start] auto [content-start] calc(min(var(--content-max-width) + 3rem,100%) - 3rem) [content-end] auto [padded-end] 1.5rem [full-end];grid-template-rows:auto 1fr auto;&>*{grid-column:full}@media (prefers-reduced-motion:no-preference){&:before{content:"";background:url(/img/ep_naturalblack.png) repeat;height:300%;left:-50%;opacity:1;position:fixed;top:-110%;width:300%;animation:grain 8s steps(10) infinite;z-index:-1;pointer-events:none}}}img{max-width:100%;height:auto;vertical-align:middle;font-style:italic;background-repeat:no-repeat;background-size:cover;shape-margin:1rem}a{color:inherit}h3{color:var(--highlight-color);font-size:2.5rem}h4{font-weight:400}main{overflow:auto;display:grid;grid-template-columns:subgrid;grid-auto-rows:max-content;&>*{grid-column:content}}button,input,select,textarea{color-scheme:dark;font:inherit;color:var(--font-color);background:var(--bg-color);border:2px ridge var(--bg-light);padding:.5rem .75rem;font-size:1rem;border-radius:2px;text-shadow:1px 1px 0 rgba(0,0,0,.5);&:active,&:focus,&:hover{border-color:var(--bg-lighter);outline:none}}input:-webkit-autofill,input:-webkit-autofill:focus{-webkit-transition:2s ease;transition:2s ease}label.checkbox{font:inherit;text-align:center;color:var(--font-color);padding:.5rem .75rem;font-size:1rem;&>input[type=checkbox]{margin-left:.5rem}}input,select,textarea{box-shadow:inset .25rem .25rem .75rem rgba(0,0,0,.5)}button{border-style:groove;box-shadow:inset -.25rem -.25rem 1rem rgba(0,0,0,.5),inset .1rem .1rem .75rem rgba(255,255,255,.25);&:hover{cursor:pointer}&.active,&:hover{color:var(--highlight-color);border-color:rgba(var(--highlight-color-rgb),.5);box-shadow:inset -.25rem -.25rem 1rem rgba(0,0,0,.25),inset .1rem .1rem .75rem rgba(255,255,255,.15)}&:active,&:focus{border-style:ridge}&.active{color:var(--highlight-color);box-shadow:inset .25rem .25rem .5rem rgba(0,0,0,.25),inset -.1rem -.1rem .25rem rgba(255,255,255,.15)}&:disabled,&[disabled]{color:var(--font-color);border-color:var(--bg-light);box-shadow:inset -.25rem -.25rem 1rem rgba(0,0,0,.25),inset .1rem .1rem .75rem rgba(255,255,255,.15);border-style:ridge;cursor:default}}.text-right{text-align:right}.pull-left{float:left}.pull-right{float:right}.img{min-height:100px;container-type:inline-size;container-name:img-container;display:flex;position:relative;justify-content:center;align-items:flex-start;width:100%;border-radius:3px;overflow:clip;box-shadow:10px 10px 10px -5px rgba(0,0,0,.5);&.has-dialog{cursor:pointer}&>span{display:inline-block;flex:1 0;height:100%;background-color:lightgray;background-size:cover;background-repeat:no-repeat;background-position:50%;position:relative}&.contain>span{background-size:contain}.content{position:absolute;bottom:0;left:0;right:0;& h3{text-shadow:2px 2px 0 rgba(0,0,0,.5);margin:0 1rem}& p{margin:.5rem 1rem 1rem;text-shadow:2px 2px 2px rgba(0,0,0,.5),0 0 10px rgba(255,255,255,1)}}&.white-content-box{.content{pointer-events:none;background:rgba(255,255,255,.75);color:var(--bg-color)}}&.white-fade{&:before{content:"";pointer-events:none;position:absolute;inset:0;background:linear-gradient(var(--whiteFadeBg) var(--whiteFadeOffset),var(--whiteFadeColor));transition:--whiteFadeOffset 1s,--whiteFadeBg 1s,--whiteFadeColor 1s;z-index:1}.content{pointer-events:none;z-index:1;& h3{transition:color 1s;color:var(--highlight-color)}& p{transition:color 1s,height 1s;color:var(--bg-color)}}}}.header-menu{display:flex;justify-content:flex-end;align-items:center;gap:.625rem;align-self:stretch;font-size:1.6875rem;line-height:.5;padding:1rem 0;grid-column:padded;& a{text-decoration:none;text-transform:uppercase;font-weight:400;&:hover{color:var(--hover-color)}&.active{color:var(--highlight-color)}}.fa-house{font-size:1.125rem}.fa-linkedin{font-size:1.3125rem}.fa-github{font-size:1.25rem}}h1.intro{font-size:3rem;text-align:center;display:block;.label,.name{display:inline-block;margin:0 auto;color:var(--highlight-color)}.name{font-size:5rem}}.about{display:grid;grid-template-columns:repeat(9,1fr);grid-template-rows:repeat(7,1fr);grid-gap:1.5rem 2rem;gap:1.5rem 2rem;margin:1.5rem auto;text-align:justify;font-size:1.1rem;.me{grid-row:1/6;grid-column:1/5}.history{grid-column:5/10;grid-row:1/3}.specialize{grid-row:3/6;grid-column:5/10}.interests{grid-row:6/8;grid-column:1/7}.desk{grid-row:6/8;grid-column:7/10}&:after{content:"";clear:both}}.skills{margin-top:2rem;&+.skills{margin-top:1rem}.icons{display:flex;padding:.5rem 0 1.5rem;align-items:flex-end;align-content:flex-start;gap:.5rem;align-self:stretch;flex-wrap:wrap;.skill{display:flex;width:3rem;height:3rem;margin-top:1rem;transition:all .3s ease;transition-delay:.1s;@media (prefers-reduced-motion:no-preference){&:hover{width:4rem;height:4rem;margin-top:0;transition-delay:0s}}& img{max-width:100%;max-height:100%}}}&:nth-child(2n){text-align:right;.icons{justify-content:flex-end}}}.search-bar{display:flex;justify-content:center;align-items:center;gap:1rem;& svg:hover{cursor:pointer}& input{flex:1 0}}.filters{display:flex;align-items:center;justify-content:space-between;gap:1rem;align-self:stretch;transition:height .2s ease;overflow-x:scroll;overflow-y:hidden;-ms-overflow-style:none;scrollbar-width:none;&::-webkit-scrollbar{display:none}}.project-list{display:flex;flex-direction:row-reverse;justify-content:center;align-items:center;gap:1rem;align-self:stretch;padding:1rem 0;flex-wrap:wrap-reverse;.item{display:flex;flex-direction:column;gap:1rem;min-width:max(30%,18rem);flex:1 0;align-self:stretch;.img{aspect-ratio:16/9;max-height:30rem;.content{& h3{color:var(--font-color)}& p{margin:.5rem 1rem;height:0;overflow:clip}}&:hover{&.white-fade{&:before{--whiteFadeOffset:0%;--whiteFadeBg:rgba(0,0,0,0);--whiteFadeColor:rgba(255,255,255,1)}.content h3{color:var(--highlight-color)}.content p{height:3rem}}}}&.detailed{min-width:max(45%,18rem);.img{&:before{--whiteFadeOffset:25%;--whiteFadeBg:rgba(0,0,0,0);--whiteFadeColor:rgba(100,100,100,.75)}.content h3{color:var(--font-color)}}}&.simple .img{&:before{--whiteFadeOffset:50%;--whiteFadeBg:rgba(0,0,0,.5);--whiteFadeColor:rgba(100,100,100,.75)}.content h3{color:var(--font-color)}}}}.project{padding:0 0 1rem;& nav{display:flex;justify-content:space-between}.img{aspect-ratio:16/9;max-height:30rem;& aside{float:right;text-align:right;margin:0 1rem 1rem;& a{color:var(--bg-color);pointer-events:all}}}.meta{display:flex;padding:1rem;gap:1rem;.roles{flex-direction:column;white-space:nowrap}.roles,.tags{display:flex;gap:.5rem}.tags{flex-wrap:wrap;justify-content:flex-end;align-content:center}}.images{display:flex;gap:1rem}.description{padding:1rem}}.project-form .fields{display:flex;flex-wrap:wrap;gap:.25rem;&>input{display:block;flex:1 0}.children{.child{display:flex;flex-wrap:wrap;gap:.25rem;&>input{display:block;flex:1 0}}}.add,.remove{display:inline-block;padding:.5rem;&:hover{cursor:pointer;color:var(--highlight-color)}}}footer{display:flex;justify-content:flex-end;align-items:center;gap:.5rem;align-self:stretch;font-size:.75rem;padding:1rem 0;grid-column:padded}dialog{pointer-events:none;margin:0 auto;top:50%;transform:translateY(-50%);box-shadow:10px 10px 10px -5px rgba(0,0,0,.5);opacity:0;display:flex;flex-direction:column;outline:0;&[open]{pointer-events:inherit;opacity:1;transition:opacity .5s}& img{align-self:baseline;max-height:75vh;max-width:75vw}.content{padding:1rem;&:empty{display:none}}&::-webkit-backdrop{background-color:rgba(0,0,0,.5)}&::backdrop{background-color:rgba(0,0,0,.5)}}@container img-container (max-width: 25rem){.content{& h3{font-size:1.5rem;text-shadow:1px 1px 0 rgba(0,0,0,.4),2px 2px 0 rgba(0,0,0,.4)}& p{font-size:.8rem}& .url{display:none}}}@media only screen and (max-width:40rem){h1.intro{font-size:2.25rem}.about{grid-template-columns:1fr;grid-template-rows:auto;.desk,.history,.interests,.me,.specialize{grid-column:1;grid-row:auto}.img{min-height:300px}}dialog{& img{align-self:baseline;max-height:90vh;max-width:90vw}}.project{.meta{flex-direction:column;padding:1rem .5rem;.roles{white-space:normal}.tags{justify-content:flex-start}}.images{flex-direction:column}.description{padding:1rem .5rem}}}@keyframes grain{0%,to{transform:translate(0)}10%{transform:translate(-5%,-10%)}20%{transform:translate(-15%,5%)}30%{transform:translate(7%,-25%)}40%{transform:translate(-5%,25%)}50%{transform:translate(-15%,10%)}60%{transform:translate(15%)}70%{transform:translateY(15%)}80%{transform:translate(3%,35%)}90%{transform:translate(-10%,10%)}}.loading-container{width:100%;height:100%;text-align:center;padding-top:5%}.loading-anim{display:inline-block;position:relative;width:80px;height:80px;& div{display:inline-block;position:absolute;left:8px;width:16px;background:#fff;animation:loading-anim 1.2s cubic-bezier(0,.5,.5,1) infinite;&:first-child{left:8px;animation-delay:-.24s}&:nth-child(2){left:32px;animation-delay:-.12s}&:nth-child(3){left:56px;animation-delay:0}}}@keyframes loading-anim{0%{top:8px;height:64px}50%,to{top:24px;height:32px}}:host,:root{--fa-font-solid:normal 900 1em/1 "Font Awesome 6 Free";--fa-font-regular:normal 400 1em/1 "Font Awesome 6 Free";--fa-font-light:normal 300 1em/1 "Font Awesome 6 Pro";--fa-font-thin:normal 100 1em/1 "Font Awesome 6 Pro";--fa-font-duotone:normal 900 1em/1 "Font Awesome 6 Duotone";--fa-font-duotone-regular:normal 400 1em/1 "Font Awesome 6 Duotone";--fa-font-duotone-light:normal 300 1em/1 "Font Awesome 6 Duotone";--fa-font-duotone-thin:normal 100 1em/1 "Font Awesome 6 Duotone";--fa-font-brands:normal 400 1em/1 "Font Awesome 6 Brands";--fa-font-sharp-solid:normal 900 1em/1 "Font Awesome 6 Sharp";--fa-font-sharp-regular:normal 400 1em/1 "Font Awesome 6 Sharp";--fa-font-sharp-light:normal 300 1em/1 "Font Awesome 6 Sharp";--fa-font-sharp-thin:normal 100 1em/1 "Font Awesome 6 Sharp";--fa-font-sharp-duotone-solid:normal 900 1em/1 "Font Awesome 6 Sharp Duotone";--fa-font-sharp-duotone-regular:normal 400 1em/1 "Font Awesome 6 Sharp Duotone";--fa-font-sharp-duotone-light:normal 300 1em/1 "Font Awesome 6 Sharp Duotone";--fa-font-sharp-duotone-thin:normal 100 1em/1 "Font Awesome 6 Sharp Duotone"}svg.svg-inline--fa:not(:host),svg.svg-inline--fa:not(:root){overflow:visible;box-sizing:content-box}.svg-inline--fa{display:var(--fa-display,inline-block);height:1em;overflow:visible;vertical-align:-.125em}.svg-inline--fa.fa-2xs{vertical-align:.1em}.svg-inline--fa.fa-xs{vertical-align:0}.svg-inline--fa.fa-sm{vertical-align:-.07143em}.svg-inline--fa.fa-lg{vertical-align:-.2em}.svg-inline--fa.fa-xl{vertical-align:-.25em}.svg-inline--fa.fa-2xl{vertical-align:-.3125em}.svg-inline--fa.fa-pull-left{margin-right:var(--fa-pull-margin,.3em);width:auto}.svg-inline--fa.fa-pull-right{margin-left:var(--fa-pull-margin,.3em);width:auto}.svg-inline--fa.fa-li{width:var(--fa-li-width,2em);top:.25em}.svg-inline--fa.fa-fw{width:var(--fa-fw-width,1.25em)}.fa-layers svg.svg-inline--fa{bottom:0;left:0;margin:auto;position:absolute;right:0;top:0}.fa-layers-counter,.fa-layers-text{display:inline-block;position:absolute;text-align:center}.fa-layers{display:inline-block;height:1em;position:relative;text-align:center;vertical-align:-.125em;width:1em}.fa-layers svg.svg-inline--fa{transform-origin:center center}.fa-layers-text{left:50%;top:50%;transform:translate(-50%,-50%);transform-origin:center center}.fa-layers-counter{background-color:var(--fa-counter-background-color,#ff253a);border-radius:var(--fa-counter-border-radius,1em);box-sizing:border-box;color:var(--fa-inverse,#fff);line-height:var(--fa-counter-line-height,1);max-width:var(--fa-counter-max-width,5em);min-width:var(--fa-counter-min-width,1.5em);overflow:hidden;padding:var(--fa-counter-padding,.25em .5em);right:var(--fa-right,0);text-overflow:ellipsis;top:var(--fa-top,0);transform:scale(var(--fa-counter-scale,.25));transform-origin:top right}.fa-layers-bottom-right{bottom:var(--fa-bottom,0);right:var(--fa-right,0);top:auto;transform:scale(var(--fa-layers-scale,.25));transform-origin:bottom right}.fa-layers-bottom-left{bottom:var(--fa-bottom,0);left:var(--fa-left,0);right:auto;top:auto;transform:scale(var(--fa-layers-scale,.25));transform-origin:bottom left}.fa-layers-top-right{top:var(--fa-top,0);right:var(--fa-right,0);transform:scale(var(--fa-layers-scale,.25));transform-origin:top right}.fa-layers-top-left{left:var(--fa-left,0);right:auto;top:var(--fa-top,0);transform:scale(var(--fa-layers-scale,.25));transform-origin:top left}.fa-1x{font-size:1em}.fa-2x{font-size:2em}.fa-3x{font-size:3em}.fa-4x{font-size:4em}.fa-5x{font-size:5em}.fa-6x{font-size:6em}.fa-7x{font-size:7em}.fa-8x{font-size:8em}.fa-9x{font-size:9em}.fa-10x{font-size:10em}.fa-2xs{font-size:.625em;line-height:.1em;vertical-align:.225em}.fa-xs{font-size:.75em;line-height:.08333em;vertical-align:.125em}.fa-sm{font-size:.875em;line-height:.07143em;vertical-align:.05357em}.fa-lg{font-size:1.25em;line-height:.05em;vertical-align:-.075em}.fa-xl{font-size:1.5em;line-height:.04167em;vertical-align:-.125em}.fa-2xl{font-size:2em;line-height:.03125em;vertical-align:-.1875em}.fa-fw{text-align:center;width:1.25em}.fa-ul{list-style-type:none;margin-left:var(--fa-li-margin,2.5em);padding-left:0}.fa-ul>li{position:relative}.fa-li{left:calc(-1 * var(--fa-li-width, 2em));position:absolute;text-align:center;width:var(--fa-li-width,2em);line-height:inherit}.fa-border{border-color:var(--fa-border-color,#eee);border-radius:var(--fa-border-radius,.1em);border-style:var(--fa-border-style,solid);border-width:var(--fa-border-width,.08em);padding:var(--fa-border-padding,.2em .25em .15em)}.fa-pull-left{float:left;margin-right:var(--fa-pull-margin,.3em)}.fa-pull-right{float:right;margin-left:var(--fa-pull-margin,.3em)}.fa-beat{animation-name:fa-beat;animation-delay:var(--fa-animation-delay,0s);animation-direction:var(--fa-animation-direction,normal);animation-duration:var(--fa-animation-duration,1s);animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-timing-function:var(--fa-animation-timing,ease-in-out)}.fa-bounce{animation-name:fa-bounce;animation-delay:var(--fa-animation-delay,0s);animation-direction:var(--fa-animation-direction,normal);animation-duration:var(--fa-animation-duration,1s);animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-timing-function:var(--fa-animation-timing,cubic-bezier(.28,.84,.42,1))}.fa-fade{animation-name:fa-fade;animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-timing-function:var(--fa-animation-timing,cubic-bezier(.4,0,.6,1))}.fa-beat-fade,.fa-fade{animation-delay:var(--fa-animation-delay,0s);animation-direction:var(--fa-animation-direction,normal);animation-duration:var(--fa-animation-duration,1s)}.fa-beat-fade{animation-name:fa-beat-fade;animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-timing-function:var(--fa-animation-timing,cubic-bezier(.4,0,.6,1))}.fa-flip{animation-name:fa-flip;animation-delay:var(--fa-animation-delay,0s);animation-direction:var(--fa-animation-direction,normal);animation-duration:var(--fa-animation-duration,1s);animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-timing-function:var(--fa-animation-timing,ease-in-out)}.fa-shake{animation-name:fa-shake;animation-duration:var(--fa-animation-duration,1s);animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-timing-function:var(--fa-animation-timing,linear)}.fa-shake,.fa-spin{animation-delay:var(--fa-animation-delay,0s);animation-direction:var(--fa-animation-direction,normal)}.fa-spin{animation-name:fa-spin;animation-duration:var(--fa-animation-duration,2s);animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-timing-function:var(--fa-animation-timing,linear)}.fa-spin-reverse{--fa-animation-direction:reverse}.fa-pulse,.fa-spin-pulse{animation-name:fa-spin;animation-direction:var(--fa-animation-direction,normal);animation-duration:var(--fa-animation-duration,1s);animation-iteration-count:var(--fa-animation-iteration-count,infinite);animation-timing-function:var(--fa-animation-timing,steps(8))}@media (prefers-reduced-motion:reduce){.fa-beat,.fa-beat-fade,.fa-bounce,.fa-fade,.fa-flip,.fa-pulse,.fa-shake,.fa-spin,.fa-spin-pulse{animation-delay:-1ms;animation-duration:1ms;animation-iteration-count:1;transition-delay:0s;transition-duration:0s}}@keyframes fa-beat{0%,90%{transform:scale(1)}45%{transform:scale(var(--fa-beat-scale,1.25))}}@keyframes fa-bounce{0%{transform:scale(1) translateY(0)}10%{transform:scale(var(--fa-bounce-start-scale-x,1.1),var(--fa-bounce-start-scale-y,.9)) translateY(0)}30%{transform:scale(var(--fa-bounce-jump-scale-x,.9),var(--fa-bounce-jump-scale-y,1.1)) translateY(var(--fa-bounce-height,-.5em))}50%{transform:scale(var(--fa-bounce-land-scale-x,1.05),var(--fa-bounce-land-scale-y,.95)) translateY(0)}57%{transform:scale(1) translateY(var(--fa-bounce-rebound,-.125em))}64%{transform:scale(1) translateY(0)}to{transform:scale(1) translateY(0)}}@keyframes fa-fade{50%{opacity:var(--fa-fade-opacity,.4)}}@keyframes fa-beat-fade{0%,to{opacity:var(--fa-beat-fade-opacity,.4);transform:scale(1)}50%{opacity:1;transform:scale(var(--fa-beat-fade-scale,1.125))}}@keyframes fa-flip{50%{transform:rotate3d(var(--fa-flip-x,0),var(--fa-flip-y,1),var(--fa-flip-z,0),var(--fa-flip-angle,-180deg))}}@keyframes fa-shake{0%{transform:rotate(-15deg)}4%{transform:rotate(15deg)}24%,8%{transform:rotate(-18deg)}12%,28%{transform:rotate(18deg)}16%{transform:rotate(-22deg)}20%{transform:rotate(22deg)}32%{transform:rotate(-12deg)}36%{transform:rotate(12deg)}40%,to{transform:rotate(0deg)}}@keyframes fa-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.fa-rotate-90{transform:rotate(90deg)}.fa-rotate-180{transform:rotate(180deg)}.fa-rotate-270{transform:rotate(270deg)}.fa-flip-horizontal{transform:scaleX(-1)}.fa-flip-vertical{transform:scaleY(-1)}.fa-flip-both,.fa-flip-horizontal.fa-flip-vertical{transform:scale(-1)}.fa-rotate-by{transform:rotate(var(--fa-rotate-angle,0))}.fa-stack{display:inline-block;vertical-align:middle;height:2em;position:relative;width:2.5em}.fa-stack-1x,.fa-stack-2x{bottom:0;left:0;margin:auto;position:absolute;right:0;top:0;z-index:var(--fa-stack-z-index,auto)}.svg-inline--fa.fa-stack-1x{height:1em;width:1.25em}.svg-inline--fa.fa-stack-2x{height:2em;width:2.5em}.fa-inverse{color:var(--fa-inverse,#fff)}.fa-sr-only,.fa-sr-only-focusable:not(:focus),.sr-only,.sr-only-focusable:not(:focus){position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.svg-inline--fa .fa-primary{fill:var(--fa-primary-color,currentColor);opacity:var(--fa-primary-opacity,1)}.svg-inline--fa .fa-secondary{fill:var(--fa-secondary-color,currentColor)}.svg-inline--fa .fa-secondary,.svg-inline--fa.fa-swap-opacity .fa-primary{opacity:var(--fa-secondary-opacity,.4)}.svg-inline--fa.fa-swap-opacity .fa-secondary{opacity:var(--fa-primary-opacity,1)}.svg-inline--fa mask .fa-primary,.svg-inline--fa mask .fa-secondary{fill:black}