@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500&family=IBM+Plex+Sans:ital,wght@0,300;0,400;0,500;1,400&display=swap";:root{--bg: #0d0d0d;--bg-alt: #111111;--bg-card: #141414;--border: #242424;--border-h: #333333;--text: #e8e4dc;--muted: #666666;--muted2: #3a3a3a;--green: #5a9a6e;--green-d: #3d6b52;--sans: "IBM Plex Sans", sans-serif;--mono: "IBM Plex Mono", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--sans);background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}a{text-decoration:none;color:inherit}img{max-width:100%;display:block}.mono{font-family:var(--mono)}.accent{color:var(--green)}.btn{font-family:var(--mono);font-size:12px;letter-spacing:.04em;padding:10px 20px;border:.5px solid var(--border-h);background:transparent;color:var(--text);cursor:pointer;transition:border-color .2s,color .2s,background .2s;display:inline-block}.btn:hover{border-color:var(--green);color:var(--green)}.btn-primary{background:var(--green);border-color:var(--green);color:#0d0d0d;font-weight:500}.btn-primary:hover{background:#4e8a62;border-color:#4e8a62;color:#0d0d0d}.btn-ghost{background:transparent}.navbar{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:1.25rem 4rem;transition:background .3s,border-color .3s}.navbar-scrolled{background:#0d0d0deb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:.5px solid var(--border)}.nav-logo{font-size:13px;color:var(--text)}.nav-links{display:flex;gap:2rem}.nav-link{font-size:12px;color:var(--muted);letter-spacing:.08em;transition:color .2s}.nav-link:hover{color:var(--text)}.nav-hamburger{display:none;background:transparent;border:.5px solid var(--border);color:var(--muted);font-size:12px;cursor:pointer;padding:6px 10px}.nav-mobile{position:fixed;top:56px;left:0;right:0;background:var(--bg);border-bottom:.5px solid var(--border);padding:1.5rem 2rem;display:flex;flex-direction:column;gap:1.25rem}.nav-mobile-link{font-size:14px;color:var(--muted);transition:color .2s}.nav-mobile-link:hover{color:var(--green)}.hero{padding:9rem 4rem 0;border-bottom:.5px solid var(--border);max-width:1200px;margin:0 auto}.hero-inner{padding-bottom:4rem}.hero-tag{font-family:var(--mono);font-size:12px;color:var(--green);letter-spacing:.08em;margin-bottom:1.5rem}.hero-h1{font-size:clamp(2.6rem,6vw,4.2rem);font-weight:300;line-height:1.08;letter-spacing:-.025em;margin-bottom:1.5rem}.hero-h1 strong{font-weight:500}.hero-sub{font-size:16px;color:var(--muted);max-width:460px;line-height:1.75;margin-bottom:2.5rem}.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:3rem}.terminal{background:var(--bg-card);border:.5px solid var(--border);padding:1.25rem 1.5rem;max-width:520px}.term-bar{display:flex;gap:6px;margin-bottom:1rem}.dot{width:9px;height:9px;border-radius:50%;background:var(--muted2)}.term-line{font-family:var(--mono);font-size:12px;color:var(--muted);margin-bottom:4px;line-height:1.6}.term-path{color:var(--muted2)}.term-prompt{color:var(--green)}.term-cmd{color:var(--text)}.term-out{color:var(--muted)}.term-ok{color:var(--green);margin-right:6px}.term-link{color:var(--green)}.term-muted{color:#3a3a3a}.cursor{display:inline-block;width:7px;height:13px;background:var(--green);animation:blink 1.1s step-end infinite;vertical-align:-2px;margin-left:1px}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);border-top:.5px solid var(--border)}.stat{padding:1.5rem 2rem;border-right:.5px solid var(--border);display:flex;flex-direction:column;gap:4px}.stat:last-child{border-right:none}.stat-n{font-family:var(--mono);font-size:1.8rem;font-weight:500;color:var(--text)}.stat-l{font-size:12px;color:var(--muted)}.section{border-bottom:.5px solid var(--border)}.section-alt{background:var(--bg-alt)}.section-inner{max-width:1200px;margin:0 auto;padding:4.5rem 4rem}.section-label{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.1em;margin-bottom:1rem}.section-title{font-size:clamp(1.8rem,4vw,2.6rem);font-weight:300;line-height:1.15;letter-spacing:-.02em;margin-bottom:2.5rem}.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}.about-body{font-size:15px;color:var(--muted);line-height:1.8;margin-bottom:1.25rem;max-width:440px}.about-fun{font-style:italic;color:var(--muted2)}.about-links{display:flex;gap:1rem;flex-wrap:wrap;margin-top:2rem}.photo-frame{position:relative;width:100%;aspect-ratio:3/4;background:var(--bg-card);border:.5px solid var(--border);overflow:hidden;margin-bottom:1.5rem;display:flex;align-items:center;justify-content:center}.photo{width:100%;height:100%;object-fit:cover}.photo-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:1rem;text-align:center}.about-badge-stack{display:flex;flex-direction:column;gap:0}.about-badge{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:.5px solid var(--border);font-size:13px}.about-badge:first-child{border-top:.5px solid var(--border)}.badge-key{font-family:var(--mono);color:var(--muted);font-size:11px;letter-spacing:.06em}.badge-val{color:var(--text);text-align:right}.skills-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}.skill-row{display:flex;align-items:center;gap:12px;margin-bottom:14px}.skill-name{font-size:12px;color:var(--text);width:100px;flex-shrink:0}.skill-track{flex:1;height:1px;background:var(--border)}.skill-fill{height:1px;background:var(--green)}.skill-pct{font-size:11px;color:var(--muted);width:26px;text-align:right}.tools-label{font-size:11px;color:var(--muted);letter-spacing:.08em;margin-bottom:1rem}.tools-list{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:2rem}.tool-tag{font-size:11px;color:var(--green);border:.5px solid var(--green-d);padding:3px 8px;letter-spacing:.04em}.skills-note{margin-top:1rem}.projects-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border:.5px solid var(--border)}.project-card{padding:1.75rem;border-right:.5px solid var(--border);border-bottom:.5px solid var(--border);display:flex;flex-direction:column;gap:12px;transition:background .2s}.project-card:hover{background:var(--bg-alt)}.project-card:nth-child(2n){border-right:none}.project-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.project-title{font-size:15px;font-weight:500}.project-status{font-family:var(--mono);font-size:10px;padding:3px 7px;border:.5px solid;white-space:nowrap;flex-shrink:0}.status-production{color:var(--green);border-color:var(--green-d)}.status-shipped{color:#7a9baa;border-color:#3a5560}.status-building{color:var(--muted);border-color:var(--muted2)}.project-desc{font-size:13px;color:var(--muted);line-height:1.65;flex:1}.project-tech{display:flex;flex-wrap:wrap;gap:6px}.tech-tag{font-size:10px;color:var(--muted);border:.5px solid var(--border);padding:2px 6px}.project-footer{margin-top:auto;padding-top:4px}.project-link{font-size:11px;color:var(--muted);letter-spacing:.04em;transition:color .2s}.project-link:hover{color:var(--green)}.projects-more{margin-top:2rem}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}.contact-sub{font-size:15px;color:var(--muted);line-height:1.75;margin-bottom:2rem;max-width:360px}.contact-links{display:flex;flex-direction:column;gap:12px}.contact-link{font-size:12px;color:var(--muted);transition:color .2s}.contact-link:hover{color:var(--green)}.contact-form{display:flex;flex-direction:column;gap:1.25rem}.form-row{display:flex;flex-direction:column;gap:6px}.form-label{font-size:11px;color:var(--muted);letter-spacing:.08em}.form-input{background:var(--bg-card);border:.5px solid var(--border);color:var(--text);font-family:var(--mono);font-size:13px;padding:10px 12px;outline:none;transition:border-color .2s;width:100%;resize:vertical}.form-input:focus{border-color:var(--green)}.form-input::placeholder{color:var(--muted2)}.form-textarea{min-height:120px}.form-success{font-size:12px;color:var(--green)}.form-error{font-size:12px;color:#c05050}.footer{max-width:1200px;margin:0 auto;padding:1.5rem 4rem;display:flex;justify-content:space-between;align-items:center}.footer-left{font-family:var(--mono);font-size:11px;color:var(--muted)}.footer-links{display:flex;gap:1.5rem}.footer-link{font-size:12px;color:var(--muted);transition:color .2s}.footer-link:hover{color:var(--green)}.code-rain{position:fixed;top:0;bottom:0;width:52px;overflow:hidden;pointer-events:none;z-index:0;display:flex;flex-direction:column;align-items:center}.code-rain-left{left:0;border-right:.5px solid var(--border)}.code-rain-right{right:0;border-left:.5px solid var(--border)}.code-rain canvas{width:52px;height:100%}@media (max-width: 900px){.code-rain{display:none}}@media (max-width: 700px){.nav-links{display:none}.nav-hamburger{display:block}.hero{padding:7rem 1.5rem 0}.hero-stats{grid-template-columns:1fr}.stat{border-right:none;border-bottom:.5px solid var(--border)}.section-inner{padding:3rem 1.5rem}.about-grid,.skills-grid,.contact-grid{grid-template-columns:1fr;gap:2.5rem}.about-photo-col{order:-1}.photo-frame{aspect-ratio:1/1}.projects-grid{grid-template-columns:1fr}.project-card{border-right:none}.footer{flex-direction:column;gap:1rem;text-align:center;padding:1.5rem}}
