*{box-sizing:border-box;border:0 solid;margin:0;padding:0}html{font-size:16px}body{color:#2b2b22;-webkit-font-smoothing:antialiased;background-color:#f5f5f0;font-family:Epilogue,sans-serif;line-height:1.5}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}img,svg{vertical-align:middle;display:block}img{max-width:100%;height:auto}button{font:inherit;color:inherit;cursor:pointer;background:0 0;border:none}@keyframes fadeInUp{0%{opacity:0;filter:blur(8px);transform:translateY(16px)}to{opacity:1;filter:blur();transform:translateY(0)}}.animate-in{opacity:0;animation:.6s ease-out forwards fadeInUp}.animate-delay-1{animation-delay:.1s}.animate-delay-2{animation-delay:.2s}.animate-delay-3{animation-delay:.3s}.animate-delay-4{animation-delay:.4s}.animate-delay-5{animation-delay:.5s}.animate-delay-6{animation-delay:.6s}.animate-delay-7{animation-delay:.7s}.animate-delay-8{animation-delay:.8s}.animate-delay-9{animation-delay:.9s}.animate-delay-10{animation-delay:1s}.animate-delay-11{animation-delay:1.1s}.animate-delay-12{animation-delay:1.2s}.page-wrapper{justify-content:center;width:100%;min-height:100vh;padding:2.5rem 1rem;display:flex}.page-content{flex-direction:column;align-items:center;gap:1.5rem;width:100%;max-width:36rem;display:flex}.header{flex-direction:column;align-items:flex-start;gap:1rem;width:100%;display:flex}.site-logo{align-items:center;display:flex}.site-title{color:#2b2b22;font-size:1.25rem;font-weight:600}.site-subtitle{color:#7a7a5a;font-size:.875rem}.bio{color:#2b2b22;flex-direction:column;gap:1rem;width:100%;font-size:.875rem;line-height:1.7;display:flex}.link{text-underline-offset:4px;font-style:italic;font-weight:500;-webkit-text-decoration:underline #d4d4c8;text-decoration:underline #d4d4c8;transition:text-decoration-color .15s}.link:hover{text-decoration-color:#7a7a5a}.divider{background-color:#7a7a5a33;border:none;width:100%;height:1px;margin:.5rem 0}.section{flex-direction:column;align-items:flex-start;gap:.75rem;width:100%;display:flex}.section-title{color:#7a7a5a;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-family:Sono,monospace;font-size:.75rem}.project-list{flex-direction:column;gap:.5rem;width:100%;display:flex}.project-item{align-items:flex-start;gap:.75rem;width:100%;padding:.5rem 0;transition:opacity .15s;display:flex}.project-item:hover .project-name{text-underline-offset:4px;text-decoration:underline}.project-logo{object-fit:cover;border-radius:4px;flex-shrink:0;width:1.25rem;height:1.25rem;margin-top:2px}.project-details{flex-direction:column;flex:1;gap:.25rem;min-width:0;display:flex}.project-info{flex-wrap:wrap;flex:1;align-items:center;gap:.5rem;min-width:0;display:flex}.project-name{color:#2b2b22;white-space:nowrap;flex-shrink:0;font-size:.875rem;font-weight:600}.project-separator{color:#7a7a5a;flex-shrink:0;font-size:.75rem}.project-about{color:#7a7a5a;white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:.875rem;overflow:hidden}.project-tags{flex-wrap:wrap;gap:.375rem;display:flex}.project-tag{white-space:nowrap;border-radius:3px;padding:.0625rem .375rem;font-family:Sono,monospace;font-size:.6875rem}.project-tag.tag-neutral{color:#5a5a48;background-color:#7a7a5a26}.project-tag.tag-green{color:#1a6b2d;background-color:#22a03c2e}.project-tag.tag-blue{color:#2756a0;background-color:#2864c826}.project-tag.tag-amber{color:#8a6510;background-color:#d296142e}.footer{flex-direction:column;justify-content:center;align-items:center;gap:1rem;width:100%;padding-top:1rem;display:flex}.footer .footer-text{color:#7a7a5a;text-align:center;font-family:Sono,monospace;font-size:.75rem}.footer .footer-text a{font-weight:500;transition:color .15s}.footer .footer-text a:hover{color:#2b2b22}
