:root{--bg-primary:#0a1f14;--bg-secondary:#000;--bg-card:#0d2318;--bg-elevated:#122b1e;--bg-hover:#163524;--bg-active:#1a3f2a;--accent:#10b981;--accent-bright:#059669;--accent-light:#34d399;--accent-dim:#10b98114;--accent-glow:#10b98126;--text-primary:beige;--text-secondary:#c8c8b0;--text-tertiary:#8a8a72;--syntax-keyword:#34d399;--syntax-string:#86efac;--syntax-number:#fbbf24;--syntax-function:#7dd3fc;--syntax-comment:#5a6e62;--syntax-property:#f9a8d4;--border-subtle:#f5f5dc1a;--radius-sm:0px;--radius-md:4px;--radius-lg:4px;--radius-xl:4px;--font-heading:"Space Grotesk",system-ui,-apple-system,sans-serif;--font-sans:"Inter",system-ui,-apple-system,sans-serif;--font-mono:"Space Mono","SF Mono","Fira Code",ui-monospace,monospace;--section-gap:96px;--container-px:20px;--container-max:1080px}[data-theme=light]{--bg-primary:beige;--bg-secondary:#fff;--bg-card:#fff;--bg-elevated:#eeeed8;--bg-hover:#e8e8cc;--bg-active:#e0e0c0;--accent:#0a1f14;--accent-bright:#0a1f14;--accent-light:#1a3f2a;--accent-dim:#0a1f140f;--accent-glow:#0a1f141a;--text-primary:#0a1f14;--text-secondary:#3c4a42;--text-tertiary:#6a7a70;--border-subtle:#0a1f141a;--syntax-keyword:#059669;--syntax-string:#16a34a;--syntax-number:#d97706;--syntax-function:#2563eb;--syntax-comment:#7a9080;--syntax-property:#db2777}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:57px}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6;overflow-x:hidden}a{color:inherit;text-decoration:none}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}img{max-width:100%;display:block}ul,ol{list-style:none}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-active);border-radius:0}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.container{width:100%;max-width:var(--container-max);padding:0 var(--container-px);margin:0 auto}.nav{z-index:100;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);position:fixed;top:0;left:0;right:0}[data-theme=light] .nav{background:var(--bg-primary)}.navInner{max-width:var(--container-max);padding:0 var(--container-px);justify-content:space-between;align-items:center;height:56px;margin:0 auto;display:flex}.navLogo{font-family:var(--font-heading);letter-spacing:-.05em;color:var(--text-primary);font-size:15px;font-weight:700;transition:color .2s}.navLogoAccent{color:var(--accent)}.navLinks{align-items:center;gap:32px;display:none}.navLink{font-family:var(--font-mono);color:var(--text-secondary);letter-spacing:.2em;text-transform:uppercase;font-size:11px;font-weight:400;transition:color .15s}.navLink:hover{color:var(--accent)}.navToggles{align-items:center;gap:4px;display:flex}.navToggle{border-radius:var(--radius-md);width:32px;height:32px;color:var(--text-tertiary);justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.navToggle:hover{background:var(--bg-hover);color:var(--text-primary)}.navToggle:active{transform:scale(.98)}.navToggleLang{font-family:var(--font-mono);letter-spacing:.15em;text-transform:uppercase;font-size:10px;font-weight:400}.scanline{background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:.2;height:1px}.mobileNav{z-index:100;background:var(--bg-secondary);border-top:1px solid var(--border-subtle);padding:6px 0;padding-bottom:max(6px,env(safe-area-inset-bottom));position:fixed;bottom:0;left:0;right:0}[data-theme=light] .mobileNav{background:var(--bg-primary)}.mobileNavInner{justify-content:space-around;align-items:center;max-width:400px;margin:0 auto;display:flex}.mobileNavLink{color:var(--text-tertiary);flex-direction:column;align-items:center;gap:3px;padding:6px 20px;transition:color .15s;display:flex}.mobileNavLink:hover,.mobileNavLink:active{color:var(--accent)}.mobileNavIcon{font-size:16px;line-height:1}.mobileNavLabel{font-family:var(--font-mono);letter-spacing:.15em;text-transform:uppercase;font-size:9px;font-weight:400}.sectionLabel{font-family:var(--font-mono);letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:24px;font-size:11px;font-weight:400}.sectionTitle{font-family:var(--font-heading);letter-spacing:-.05em;color:var(--text-primary);margin-bottom:16px;font-size:28px;font-weight:700;line-height:1.15}.hero{border-bottom:1px solid var(--border-subtle);align-items:center;min-height:100dvh;padding:100px 0 80px;display:flex}.heroInner{width:100%}.heroContent{max-width:640px}.heroNameRow{align-items:flex-end;gap:20px;margin-bottom:12px;display:flex}.heroAvatar{border-radius:var(--radius-md);object-fit:cover;object-position:top;flex-shrink:0;width:110px;height:140px}.heroStatus{font-family:var(--font-mono);letter-spacing:.15em;text-transform:uppercase;color:var(--accent);background:var(--accent-dim);border-radius:var(--radius-md);border:1px solid #10b98126;align-items:center;gap:8px;margin-bottom:24px;padding:6px 14px;font-size:11px;font-weight:400;display:inline-flex}[data-theme=light] .heroStatus{border-color:#0a1f141f}.heroStatusDot{background:var(--accent);border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.heroName{font-family:var(--font-heading);letter-spacing:-.05em;color:var(--text-primary);font-size:40px;font-weight:800;line-height:1}.heroRole{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:20px;font-size:13px;font-weight:400}.heroDesc{color:var(--text-secondary);max-width:520px;margin-bottom:36px;font-size:15px;line-height:1.7}.heroCtas{flex-wrap:wrap;gap:12px;display:flex}.btnPrimary{font-family:var(--font-mono);letter-spacing:.15em;text-transform:uppercase;border-radius:var(--radius-md);background:var(--text-primary);color:var(--bg-primary);border:1px solid var(--text-primary);align-items:center;gap:8px;padding:12px 22px;font-size:11px;font-weight:400;transition:opacity .15s,transform .1s;display:inline-flex}.btnPrimary:hover{opacity:.88}.btnPrimary:active{transform:scale(.98)}.btnSecondary{font-family:var(--font-mono);letter-spacing:.15em;text-transform:uppercase;border-radius:var(--radius-md);color:var(--text-primary);border:1px solid var(--border-subtle);background:0 0;align-items:center;gap:8px;padding:12px 22px;font-size:11px;font-weight:400;transition:border-color .15s,color .15s,transform .1s;display:inline-flex}.btnSecondary:hover{border-color:var(--text-secondary);color:var(--text-primary)}.btnSecondary:active{transform:scale(.98)}.heroCode{background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-subtle);margin-top:56px;overflow:hidden}.codeHeader{border-bottom:1px solid var(--border-subtle);background:var(--bg-card);align-items:center;gap:6px;padding:10px 16px;display:flex}.codeDot{border-radius:50%;width:10px;height:10px}.codeDotRed{background:#ff5f57}.codeDotYellow{background:#febc2e}.codeDotGreen{background:#28c840}.codeFilename{font-family:var(--font-mono);color:var(--text-tertiary);letter-spacing:.05em;margin-left:8px;font-size:11px}.codeBody{font-family:var(--font-mono);padding:16px;font-size:13px;line-height:1.8;overflow-x:auto}.codeLine{gap:16px;display:flex}.codeLineNum{color:var(--text-tertiary);-webkit-user-select:none;user-select:none;text-align:right;opacity:.4;min-width:16px}.codeKeyword{color:var(--syntax-keyword)}.codeString{color:var(--syntax-string)}.codeNumber{color:var(--syntax-number)}.codeFunction{color:var(--syntax-function)}.codeComment{color:var(--syntax-comment)}.codeProperty{color:var(--syntax-property)}.codePunctuation{color:var(--text-tertiary)}.codeCursor{background:var(--accent);vertical-align:middle;width:2px;height:14px;margin-left:2px;animation:1s step-end infinite blink;display:inline-block}@keyframes blink{50%{opacity:0}}.projects{padding:var(--section-gap)0;border-bottom:1px solid var(--border-subtle)}.projectsGrid{flex-direction:column;gap:24px;display:flex}.projectCard{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-subtle);transition:background .2s,border-color .2s;overflow:hidden}.projectCard:hover{background:var(--bg-elevated);border-color:#f5f5dc2e}[data-theme=light] .projectCard:hover{border-color:#0a1f142e}.projectBrowser{border-bottom:1px solid var(--border-subtle);background:var(--bg-secondary);align-items:center;gap:6px;padding:10px 14px;display:flex}[data-theme=light] .projectBrowser{background:var(--bg-elevated)}.projectBrowserDot{border-radius:50%;width:8px;height:8px}.projectBrowserUrl{font-family:var(--font-mono);color:var(--text-tertiary);text-overflow:ellipsis;white-space:nowrap;letter-spacing:.04em;margin-left:8px;font-size:10px;overflow:hidden}.projectPreview{aspect-ratio:9/16;background:var(--bg-elevated);border-bottom:1px solid var(--border-subtle);justify-content:center;align-items:center;width:100%;display:flex;position:relative;overflow:hidden}.projectIframeWrap{justify-content:center;align-items:flex-start;width:100%;height:100%;display:flex;position:relative;overflow:hidden}.projectIframe{transform-origin:0 0;pointer-events:none;background:var(--bg-primary);border:none;width:1440px;height:900px;position:absolute;top:0;left:50%;transform:scale(.22)translate(-50%)}.projectPreviewLink{cursor:pointer;width:100%;height:100%;transition:opacity .15s;display:block;position:absolute;inset:0}.projectPreviewLink:hover{opacity:.85}.projectPreviewLink:active{transform:scale(.99)}.projectPreviewImg{object-fit:cover;object-position:top center}.projectPreviewText{font-family:var(--font-mono);color:var(--text-tertiary);opacity:.4;letter-spacing:.1em;font-size:11px}.projectBody{padding:24px}.projectStatus{font-family:var(--font-mono);letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:8px;font-size:10px;font-weight:400}.projectTitle{font-family:var(--font-heading);letter-spacing:-.03em;color:var(--text-primary);margin-bottom:8px;font-size:18px;font-weight:700}.projectDesc{color:var(--text-secondary);margin-bottom:20px;font-size:14px;line-height:1.65}.projectTags{flex-wrap:wrap;gap:6px;margin-bottom:20px;display:flex}.projectTag{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;border-radius:var(--radius-md);background:var(--accent-dim);color:var(--accent);border:1px solid #10b9811f;padding:3px 10px;font-size:10px}[data-theme=light] .projectTag{border-color:#0a1f141a}.projectLinks{gap:16px;display:flex}.projectLink{font-family:var(--font-mono);letter-spacing:.15em;text-transform:uppercase;color:var(--accent);align-items:center;gap:6px;font-size:10px;font-weight:400;transition:opacity .15s;display:inline-flex}.projectLink:hover{opacity:.7}.projectLinkArrow{font-size:12px;transition:transform .15s}.projectLink:hover .projectLinkArrow{transform:translate(2px)}.stack{padding:var(--section-gap)0;border-bottom:1px solid var(--border-subtle)}.stackGrid{border:1px solid var(--border-subtle);flex-direction:column;gap:0;display:flex}.stackItem{border-bottom:1px solid var(--border-subtle);flex-direction:column;gap:8px;padding:16px 20px;display:flex}.stackItem:last-child{border-bottom:none}.stackItemHeader{justify-content:space-between;align-items:center;display:flex}.stackName{font-family:var(--font-sans);color:var(--text-primary);font-size:14px;font-weight:500}.stackLevel{font-family:var(--font-mono);color:var(--accent);letter-spacing:.1em;font-size:11px}.stackBar{background:var(--bg-elevated);border-radius:0;height:2px;overflow:hidden}.stackBarFill{background:var(--accent);border-radius:0;width:0;height:100%;transition:width 1s ease-out}.contact{padding:var(--section-gap)0}.contactCard{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-subtle);text-align:center;padding:48px 24px}.contactHeading{font-family:var(--font-heading);letter-spacing:-.05em;color:var(--text-primary);margin-bottom:12px;font-size:24px;font-weight:700;line-height:1.2}.contactSub{color:var(--text-secondary);margin-bottom:32px;font-size:14px;line-height:1.6}.contactBtn{font-family:var(--font-mono);letter-spacing:.15em;text-transform:uppercase;border-radius:var(--radius-md);background:var(--text-primary);color:var(--bg-primary);border:1px solid var(--text-primary);align-items:center;gap:8px;padding:14px 28px;font-size:11px;font-weight:400;transition:opacity .15s,transform .1s;display:inline-flex}.contactBtn:hover{opacity:.88}.contactBtn:active{transform:scale(.98)}.footer{background:var(--bg-secondary);padding:32px 0;padding-bottom:max(32px,calc(32px + env(safe-area-inset-bottom) + 56px));border-top:1px solid var(--border-subtle)}.footerInner{text-align:center;flex-direction:column;align-items:center;gap:16px;display:flex}.footerLinks{gap:24px;display:flex}.footerLink{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary);font-size:11px;font-weight:400;transition:color .15s}.footerLink:hover{color:var(--accent)}.footerCopy{font-family:var(--font-mono);color:var(--text-tertiary);letter-spacing:.08em;font-size:10px}.reveal{opacity:0;transition:opacity .45s,transform .45s;transform:translateY(12px)}.reveal.visible{opacity:1;transform:translateY(0)}@media (min-width:768px){:root{--container-px:32px;--section-gap:120px}.navLinks{display:flex}.mobileNav{display:none}.heroName{font-size:56px}.heroAvatar{width:130px;height:170px}.heroRole{font-size:14px}.heroDesc{font-size:16px}.sectionTitle{font-size:32px}.projectPreview{aspect-ratio:16/9;height:auto}.projectIframe{transform:scale(.35)translate(-50%)}.projectsGrid{gap:32px}.stackGrid{grid-template-columns:repeat(2,1fr);display:grid}.stackItem{border-right:1px solid var(--border-subtle)}.stackItem:nth-child(2n){border-right:none}.stackItem:nth-last-child(-n+2){border-bottom:none}.contactCard{padding:64px 48px}.contactHeading{font-size:28px}.footer{padding-bottom:32px}.footerInner{flex-direction:row;justify-content:space-between}.codeBody{font-size:14px}}@media (min-width:1024px){:root{--container-px:40px;--section-gap:140px}.heroName{font-size:64px}.heroAvatar{width:150px;height:190px}.contactCard{padding:80px 64px}.contactHeading{font-size:32px}.codeBody{padding:20px 24px}}
