*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{background:#fafafa;color:#111;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;line-height:1.6}a{color:inherit;text-decoration:none}::selection{background:#111;color:#fff}.page{max-width:680px;margin:0 auto;padding:16vh 2rem 12vh}.hero{margin-bottom:6vh;opacity:0;animation:up .9s cubic-bezier(.23,1,.32,1) forwards}.pfp{width:72px;height:72px;border-radius:4px;image-rendering:pixelated;margin-bottom:1.5rem}.name{font-size:clamp(2rem,5vw,2.8rem);font-weight:600;letter-spacing:-.03em;line-height:1.15;margin-bottom:1rem}.handle{font-size:.82rem;font-family:SF Mono,Fira Mono,Roboto Mono,Menlo,monospace;color:#999;margin-bottom:2rem;display:flex;align-items:center;gap:.6rem}.handle a{transition:color .2s}.handle a:hover{color:#111}.handle .sep{color:#ddd}.bio{font-size:1.12rem;font-weight:300;line-height:1.65;color:#444;max-width:560px}.bio .hl{color:#111;font-weight:400}.tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.8rem;opacity:0;animation:up .9s cubic-bezier(.23,1,.32,1) .08s forwards}.tag{font-size:.68rem;letter-spacing:.06em;text-transform:uppercase;color:#999;border:1px solid #e0e0e0;padding:.28rem .7rem;border-radius:2px;transition:color .2s,border-color .2s}.tag:hover{color:#555;border-color:#bbb}.tag.scratched{position:relative;color:#888;border-color:#d0d0d0}.tag.scratched:before{content:"";position:absolute;left:-3px;right:-3px;top:50%;height:1.5px;background:#c44;transform:rotate(-12deg);border-radius:1px}.tag.scratched:nth-child(3):before{transform:rotate(-15deg)}.tag.scratched:nth-child(4):before{transform:rotate(-10deg)}.tag.scratched:nth-child(5):before{transform:rotate(-14deg)}.tag.scratched:nth-child(6):before{transform:rotate(-11deg)}.tag.scratched:nth-child(7):before{transform:rotate(-16deg)}.tag.scratched:nth-child(8):before{transform:rotate(-9deg)}.tag.scratched:nth-child(9):before{transform:rotate(-13deg)}.tag.scratched:nth-child(10):before{transform:rotate(-11deg)}.vibecoding{display:inline-block;margin-top:.5rem;font-size:.68rem;letter-spacing:.06em;text-transform:uppercase;color:#111;border:1px solid #111;padding:.28rem .7rem;border-radius:2px;font-weight:600;opacity:0;animation:up .9s cubic-bezier(.23,1,.32,1) .14s forwards}.divider{height:1px;background:#e0e0e0;margin:6vh 0 4vh;opacity:0;animation:up .9s cubic-bezier(.23,1,.32,1) .16s forwards}.section-label{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:#aaa;margin-bottom:2rem;opacity:0;animation:up .9s cubic-bezier(.23,1,.32,1) .2s forwards}.projects{display:flex;flex-direction:column}.project{border-top:1px solid #eee;opacity:0;animation:up .9s cubic-bezier(.23,1,.32,1) forwards}.project:last-child{border-bottom:1px solid #eee}.project:nth-child(1){animation-delay:.24s}.project:nth-child(2){animation-delay:.3s}.project:nth-child(3){animation-delay:.36s}.project:nth-child(4){animation-delay:.42s}.project:nth-child(5){animation-delay:.48s}.project:nth-child(6){animation-delay:.54s}.project:nth-child(7){animation-delay:.6s}.project:nth-child(8){animation-delay:.66s}.project:nth-child(9){animation-delay:.72s}.project summary{display:flex;align-items:baseline;gap:1rem;padding:1.6rem 0;cursor:pointer;list-style:none;position:relative}.project summary::-webkit-details-marker{display:none}.project summary::marker{content:""}.project summary:after{content:"+";position:absolute;right:0;top:1.6rem;font-size:1rem;font-weight:200;color:#ccc;transition:transform .3s ease,color .3s ease}.project[open] summary:after{transform:rotate(45deg);color:#999}.project summary:hover:after{color:#111}.project-num{font-size:.68rem;font-family:SF Mono,Fira Mono,Roboto Mono,Menlo,monospace;color:#ccc;min-width:1.4rem}.project-name{font-size:1.1rem;font-weight:500}.project-brief{font-size:.78rem;color:#aaa;margin-left:auto;padding-right:1.8rem;white-space:nowrap}.project-body{padding:0 0 2rem 2.4rem;max-width:480px}.project-body p{font-size:.88rem;color:#555;line-height:1.75;margin-bottom:1rem}.project-body p:last-of-type{margin-bottom:1.5rem}.project-meta{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.project-status{font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:#bbb;border:1px solid #e5e5e5;padding:.22rem .65rem;border-radius:2px;text-decoration:none;transition:background .2s,color .2s,border-color .2s}.project-status:hover{color:#999;border-color:#ccc}.project-status.live{color:#111;border-color:#111}.project-status.live:hover{background:#111;color:#fff}.project-link{font-size:.78rem;color:#999;text-decoration:none;transition:color .2s}.project-link:hover{color:#111}.background{opacity:0;animation:up .9s cubic-bezier(.23,1,.32,1) .6s forwards}.background-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem 3rem}.bg-item{margin-bottom:.5rem}.bg-label{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:#bbb;margin-bottom:.4rem}.bg-value{font-size:.92rem;color:#444;line-height:1.5}.interests{opacity:0;animation:up .9s cubic-bezier(.23,1,.32,1) .65s forwards}.interest-list{columns:2;column-gap:3rem;list-style:none}.interest-list li{font-size:.88rem;color:#555;padding:.4rem 0;break-inside:avoid}.interest-list li:before{content:"";display:inline-block;width:4px;height:4px;background:#ddd;border-radius:50%;margin-right:.7rem;vertical-align:middle}.footer{margin-top:12vh;padding-top:3rem;border-top:1px solid #eee;display:flex;justify-content:space-between;align-items:center;opacity:0;animation:up .9s cubic-bezier(.23,1,.32,1) .7s forwards}.footer-links{display:flex;gap:1.5rem}.footer-links a{font-size:.78rem;color:#bbb;text-decoration:none;transition:color .2s}.footer-links a:hover{color:#111}.footer-copy{font-size:.68rem;color:#ddd}@keyframes up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 560px){.page{padding:10vh 1.5rem 8vh}.project-brief{display:none}.project-body{padding-left:2rem}.background-grid{grid-template-columns:1fr;gap:1.5rem}.interest-list{columns:1}.footer{flex-direction:column;gap:1rem;align-items:flex-start}}
