@import "https://fonts.googleapis.com/css2?family=Kode+Mono:wght@400;500;600;700&display=swap";:root{--main-bg-color:lab(2.51107% .242703 -.886115);--favorite-color:#8100ca;--main-color:#0886fe;--main-text-color:#f1f1f1}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:17pt}body{background:var(--main-bg-color);color:var(--main-text-color);flex-direction:column;align-items:center;font-family:sans-serif;display:flex}ul,ol{list-style:none}a{color:inherit;text-decoration:none;transition:color .25s}:root{--kofi-color:#ff5a16;--mastodon-color:#5237e6;--bluesky-color:#0886fe;--itch-color:#fa5c5c;--nav-text-color:#fff;--nav-active-color:#1d95ff}#bg-canvas{z-index:-1;pointer-events:none;width:100%;height:100%;position:fixed;top:0;left:0}#navbar{z-index:100;pointer-events:none;justify-content:center;display:flex;position:fixed;top:1rem;left:0;right:0}#navbar-inner{-webkit-backdrop-filter:blur(12px);pointer-events:all;background:#ffffff14;border:.5px solid #ffffff26;border-radius:999px;grid-template-columns:1fr auto 1fr;align-items:center;width:72rem;max-width:calc(100vw - 2rem);height:2.5rem;padding:0 1.25rem;display:grid}#navbar-logo{flex-shrink:0;align-items:center;display:flex}#navbar-logo svg{width:1.5rem;height:1.5rem}#navbar-links{align-items:center;gap:.25rem;display:flex}.navigation-button{cursor:pointer;color:var(--nav-text-color);background:0 0;border:none;border-radius:5px;padding:.375rem .75rem;font-family:Kode Mono,monospace;font-size:.75rem;transition:background-color .125s,color .125s}.navigation-button:hover{color:var(--nav-active-color);background-color:#ffffff14}.navigation-button.active{color:var(--nav-active-color)}#main{padding-top:5rem}.section{border-bottom:.5px solid #ffffff12;justify-content:center;align-items:center;min-height:100vh;display:flex}.section-inner{width:100%;max-width:72rem;padding:5rem 2rem}.section-inner.centered{text-align:center;flex-direction:column;align-items:center;display:flex}.section-heading{color:#fff;letter-spacing:-.025rem;margin-bottom:2.5rem;font-family:Kode Mono,monospace;font-size:1.75rem;font-weight:400}.section-header-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2.5rem;display:flex}.section-header-row .section-heading{margin-bottom:0}.home-name{text-transform:uppercase;letter-spacing:.4rem;color:var(--main-text-color);font-family:Inter,sans-serif;font-size:2.5rem;font-weight:300;line-height:2.25}.home-decoration{text-transform:uppercase;letter-spacing:.4rem;color:var(--main-text-color);font-family:Inter,sans-serif;font-size:2rem;font-weight:300;line-height:2.25}.home-title-row{flex-direction:column;align-items:center;gap:1rem;width:100%;margin-bottom:1rem;display:flex}.home-title-row .home-name{text-align:right;justify-self:end}.home-title-cycling{justify-self:start;position:relative;overflow:hidden}.home-title{text-transform:uppercase;letter-spacing:.4rem;color:var(--main-text-color);font-family:Inter,sans-serif;font-size:1.5rem;font-weight:300;line-height:2.25}.home-title-cycling .cycling-text--enter{animation:.5s forwards fade-in-bottom}.home-title-cycling .cycling-text--exit{animation:.5s forwards fade-out-top}@keyframes fade-in-right{0%{opacity:0;transform:translate(50px)}to{opacity:1;transform:translate(0)}}@keyframes fade-in-bottom{0%{opacity:0;transform:translateY(50px)}50%{opacity:.9}to{opacity:1;transform:translateY(0)}}@keyframes fade-out-top{0%{opacity:1;transform:translateY(0)}50%{opacity:.1}to{opacity:0;transform:translateY(-50px)}}.home-sub{color:var(--main-text-color);margin-bottom:2rem;font-family:Kode Mono,monospace;font-size:1rem}.highlight{color:var(--main-color)}.home-actions{flex-wrap:wrap;justify-content:center;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.home-email{color:var(--main-text-color);font-family:Kode Mono,monospace;font-size:.875rem}.email-button{color:#fff;border:2px solid var(--main-color);border-radius:2.5rem;align-items:center;gap:.5rem;height:2.5rem;padding:0 1.5rem;font-family:Kode Mono,monospace;font-size:.9rem;font-weight:700;text-decoration:none;transition:background-color .125s,opacity .125s;display:inline-flex}.email-button:hover{background-color:var(--main-color);border-color:var(--main-color);color:#000}.resume-button{color:#fff;border:2px solid var(--nav-active-color);border-radius:2.5rem;align-items:center;gap:.5rem;height:2.5rem;padding:0 1.5rem;font-family:Kode Mono,monospace;font-size:.9rem;font-weight:700;text-decoration:none;transition:background-color .125s,opacity .125s;display:inline-flex}.resume-button:hover{background-color:var(--nav-active-color);border-color:var(--nav-active-color);color:#000}.icons-row{flex-wrap:wrap;justify-content:center;gap:.125rem;margin:.5rem 0 0;font-size:1.125em;display:flex}.icon-btn{background-color:#0000;border-radius:.5rem;justify-content:center;align-items:center;width:2em;height:2em;transition:color .125s,background-color .125s,border-color .125s;display:flex}.icon-btn:hover{background-color:#141414e3}.icon-btn span{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.icon-btn img,.icon-btn svg{width:60%;height:60%;display:block;overflow:visible}#itch path{fill:var(--itch-color)}#mastodon path{fill:var(--mastodon-color)}#bluesky path{fill:var(--bluesky-color)}#kofi path{fill:var(--kofi-color)}.gallery-list{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.gallery-item{box-sizing:border-box;border-radius:.25rem;display:inline-block;position:relative}.gallery-item .thumbnail{box-sizing:border-box;filter:brightness();transition:filter .375s;display:block}.gallery-item .thumbnail img{box-sizing:border-box;object-fit:cover;border-radius:1rem;width:15rem;height:15rem;display:block}.gallery-item .caption{pointer-events:none;text-align:center;color:#fff;opacity:0;background-image:linear-gradient(90deg,#0000 0%,#000000db 50%,#0000 100%);flex-direction:column;justify-content:center;align-items:center;width:100%;padding:.5rem 0;font-family:Kode Mono,monospace;transition:opacity .25s;display:flex;position:absolute;top:6rem;left:0}.gallery-item .caption p{text-shadow:1px 1px 2px #000;margin:.25rem .5rem;padding:0;font-weight:600}.gallery-item .caption .subcaption{font-size:.8em;font-weight:400}.gallery-item.hovered .thumbnail{filter:brightness(110%)}.gallery-item.hovered .caption{opacity:1}.skills-grid{grid-template-columns:repeat(auto-fill,minmax(14rem,1fr));gap:.75rem;display:grid}.skill-card{background-color:#1a1a1a;border:.5px solid #ffffff14;border-radius:.5rem;align-items:center;gap:.875rem;padding:.75rem 1rem;transition:border-color .2s,background-color .2s;display:flex}.skill-card:hover{border-color:var(--main-color);background-color:#1f1f1f}.skill-card--no-image{justify-content:center}.skill-card-img-wrap{border-radius:.25rem;flex-shrink:0;justify-content:center;align-items:center;width:2rem;height:2rem;display:flex}.skill-card-img-wrap--bg{background-color:#ffffff4d}.skill-card-img{object-fit:contain;width:1.5rem;height:1.5rem}.skill-card-img--svg{filter:brightness(0)invert()}.skill-card-name{color:#e0e0e0;white-space:nowrap;text-overflow:ellipsis;font-family:Kode Mono,monospace;font-size:.8rem;font-weight:500;overflow:hidden}.blog-list{flex-flow:wrap;gap:1.25rem;display:flex}.blog-card{color:inherit;cursor:pointer;text-align:left;background-color:#1a1a1a;border:2px solid #ffffff14;border-radius:.5rem;flex-direction:column;flex-shrink:0;width:14rem;height:18rem;padding:0;font-family:inherit;transition:border-color .2s,background-color .2s;display:flex;overflow:hidden}.blog-card:hover{border-color:var(--main-color);background-color:#1f1f1f}.blog-card-img{object-fit:cover;flex-shrink:0;width:100%;height:10rem;display:block}.blog-card-body{flex-direction:column;flex:1;gap:.375rem;padding:.75rem 1rem;display:flex;overflow:hidden}.blog-card-date{letter-spacing:.03em;color:var(--main-text-color);opacity:.7;font-family:Inter,sans-serif;font-size:.6rem}.blog-card-title{color:#e0e0e0;-webkit-line-clamp:3;-webkit-box-orient:vertical;font-family:Inter,sans-serif;font-size:.85rem;font-weight:600;line-height:1.35;display:-webkit-box;overflow:hidden}.blog-empty{color:var(--main-text-color);font-family:Inter,sans-serif;font-size:.9rem}.blog-empty code{color:var(--main-color)}@media (width<=640px){#navbar-inner{padding:0 1rem}.navigation-button{padding:.25rem .5rem;font-size:.75rem}.section-inner{padding:4rem 1.25rem}.gallery-item .thumbnail img{width:44vw;height:44vw}.section-header-row{flex-direction:column;align-items:flex-start}}.blog-post{width:100%;max-width:52rem;color:var(--main-text-color);margin:0 auto;padding:0 0 6rem;font-family:Inter,sans-serif}.blog-banner{border-radius:.25rem;width:100%;height:clamp(10rem,40vw,12rem);margin-bottom:0;position:relative;overflow:hidden}.blog-banner-img{object-fit:cover;object-position:center;width:100%;height:100%;display:block}.blog-banner-overlay{background:linear-gradient(to bottom, transparent 40%, var(--main-bg-color) 100%);position:absolute;inset:0}.blog-header{padding:2rem 2rem 0}.blog-title{color:#fff;letter-spacing:-.03em;text-align:center;margin-bottom:1rem;font-family:Inter,sans-serif;font-size:clamp(1.75rem,5vw,3rem);font-weight:700;line-height:1.15}.blog-meta-row{flex-wrap:wrap;justify-content:center;align-items:center;gap:1rem;display:flex}.blog-author{text-transform:uppercase;letter-spacing:.25em;color:var(--main-color);font-size:.7rem;font-weight:400}.blog-date{text-transform:uppercase;letter-spacing:.2em;color:var(--main-text-color);opacity:.6;font-size:.7rem;font-weight:400}.blog-divider{background:linear-gradient(to right, transparent, var(--main-color) 30%, #ffffff14 70%, transparent);height:1px;margin:1.75rem 2rem}.blog-body{flex-direction:column;gap:1.25rem;padding:0 2rem;display:flex}.blog-p{color:var(--main-text-color);font-size:.95rem;line-height:1.85}.blog-h{color:#fff;letter-spacing:-.02em;margin-top:.5rem;font-family:Kode Mono,monospace;font-weight:600;line-height:1.2}.blog-h1{font-size:1.6rem}.blog-h2{color:#e0e0e0;font-size:1.3rem}.blog-h3{color:#ccc;font-size:1.1rem}.blog-h4{color:#aaa;text-transform:uppercase;letter-spacing:.1em;font-size:.95rem}.blog-h5,.blog-h6{color:#888;text-transform:uppercase;letter-spacing:.1em;font-size:.85rem}.blog-inline-code{color:var(--main-color);background:#8100ca1f;border:.5px solid #8100ca40;border-radius:3px;padding:.1em .35em;font-family:Kode Mono,monospace;font-size:.82em}.blog-code-block{border:.5px solid #ffffff14;border-left:2px solid var(--main-color);color:#ccc;background:#ffffff08;border-radius:.5rem;padding:1.25rem 1.5rem;font-family:Kode Mono,monospace;font-size:.8rem;line-height:1.7;overflow-x:auto}.blog-blockquote{border-left:2px solid var(--main-color);background:#8100ca0f;border-radius:0 .375rem .375rem 0;padding:.75rem 1.25rem}.blog-blockquote p{color:#aaa;font-size:.9rem;font-style:italic;line-height:1.8}.blog-ul,.blog-ol{flex-direction:column;gap:.4rem;padding-left:1.5rem;display:flex}.blog-ul{list-style:none}.blog-ol{list-style:decimal}.blog-ul li{color:var(--main-text-color);padding-left:1rem;font-size:.95rem;line-height:1.75;position:relative}.blog-ul li:before{content:"·";color:var(--main-color);font-size:1.1em;position:absolute;left:0}.blog-ol li{color:var(--main-text-color);font-size:.95rem;line-height:1.75}.blog-hr{background:#ffffff12;border:none;height:1px;margin:.5rem 0}.blog-body a{color:var(--main-color);text-underline-offset:3px;-webkit-text-decoration:underline #8100ca66;text-decoration:underline #8100ca66;transition:color .15s,text-decoration-color .15s}.blog-body a:hover{color:#b44fff;text-decoration-color:#b44fff}.blog-loading,.blog-error{color:var(--main-text-color);text-align:center;padding:4rem 2rem;font-family:Kode Mono,monospace;font-size:.85rem}.blog-error code{color:var(--main-color)}@media (width<=640px){.blog-header{padding:1.5rem 1.25rem 0}.blog-divider{margin:1.25rem}.blog-body{padding:0 1.25rem}.blog-meta-row{flex-direction:column;align-items:flex-start;gap:.375rem}}
