*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#fdfcfa;--fg:#1a1a1a;--muted:#888;--light:#bbb;--border:#ebebeb;--pill-bg:#f3f3f1;--card-hover:#f7f7f5;--blue:#1d9bf0;--text-secondary:#555;--nav-bg:#fdfcfad9;--cta-bg:#1a1a1a;--cta-bg-hover:#2a2a2a;--cta-text:#fdfcfa;--heading:"Plus Jakarta Sans", system-ui, sans-serif;--body:"DM Sans", system-ui, sans-serif;--max-w:720px;--section-gap:5rem}[data-theme=dark]{--bg:#111;--fg:#e8e8e8;--muted:#888;--light:#555;--border:#2a2a2a;--pill-bg:#1e1e1e;--card-hover:#1a1a1a;--text-secondary:#999;--nav-bg:#111111d9;--cta-bg:#e8e8e8;--cta-bg-hover:#d0d0d0;--cta-text:#111}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background:var(--bg);color:var(--fg);font-family:var(--body);font-weight:300;line-height:1.7;transition:background .35s,color .35s;overflow-x:hidden}::selection{background:var(--fg);color:var(--bg)}a{color:inherit;text-decoration:none}.controls{z-index:200;background:var(--bg);border:1px solid var(--border);border-radius:100px;align-items:center;gap:.35rem;padding:.3rem;transition:background .35s,border-color .35s;display:flex;position:fixed;top:1rem;right:1.5rem}.ctrl-btn{font-family:var(--heading);letter-spacing:.04em;color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:100px;justify-content:center;align-items:center;padding:.35rem .65rem;font-size:.68rem;font-weight:600;line-height:1;transition:all .25s;display:flex}.ctrl-btn:hover{color:var(--fg)}.ctrl-btn.active{background:var(--fg);color:var(--bg)}.ctrl-divider{background:var(--border);flex-shrink:0;width:1px;height:14px}.ctrl-theme{width:30px;height:30px;padding:0}.ctrl-theme svg{width:14px;height:14px}nav{z-index:100;background:var(--nav-bg);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);transition:transform .4s cubic-bezier(.16,1,.3,1),background .35s,border-color .35s;position:fixed;top:0;left:0;right:0;transform:translateY(-100%)}nav.visible{transform:translateY(0)}nav .nav-inner{max-width:var(--max-w);justify-content:space-between;align-items:center;margin:0 auto;padding:.8rem 2rem;display:flex}nav .nav-name{font-family:var(--heading);letter-spacing:-.02em;font-size:.85rem;font-weight:700}nav .nav-links{gap:1.6rem;list-style:none;display:flex}nav .nav-links a{font-family:var(--body);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-size:.72rem;font-weight:400;transition:color .25s}nav .nav-links a:hover{color:var(--fg)}.section{max-width:var(--max-w);margin:0 auto;padding:0 2rem}.section-label{font-family:var(--heading);letter-spacing:.22em;text-transform:uppercase;color:var(--light);margin-bottom:3rem;font-size:.65rem;font-weight:600}.section-divider{background:var(--border);width:100%;height:1px;margin:var(--section-gap) auto;max-width:var(--max-w);transition:background .35s}.hero{justify-content:center;align-items:center;min-height:100svh;padding:4rem 2rem;display:flex}.hero-inner{max-width:var(--max-w);width:100%}.hero-top{align-items:center;gap:1.8rem;margin-bottom:2.4rem;display:flex}.hero-photo{background:var(--pill-bg);border:2px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:120px;height:120px;transition:background .35s,border-color .35s;display:flex;overflow:hidden}.hero-photo img{object-fit:cover;width:100%;height:100%}.hero-name-row{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.hero-name{font-family:var(--heading);letter-spacing:-.035em;font-size:clamp(2rem,5vw,2.8rem);font-weight:800;line-height:1.1}.verified-badge{flex-shrink:0;width:24px;height:24px;margin-top:2px}.hero-tagline{font-family:var(--heading);color:var(--muted);letter-spacing:-.01em;margin-top:.5rem;font-size:clamp(.85rem,2vw,1rem);font-weight:500}.hero-summary{color:var(--text-secondary);margin-bottom:2.4rem;font-size:1rem;line-height:1.8}.hero-links{flex-wrap:wrap;gap:1.4rem;list-style:none;display:flex}.hero-links a{font-family:var(--body);letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-size:.78rem;font-weight:400;transition:color .3s;position:relative}.hero-links a:after{content:"";background:var(--fg);width:0;height:1px;transition:width .35s cubic-bezier(.16,1,.3,1);position:absolute;bottom:-2px;left:0}.hero-links a:hover{color:var(--fg)}.hero-links a:hover:after{width:100%}.exp-item{margin-bottom:3.5rem}.exp-item:last-child{margin-bottom:0}.exp-role{font-family:var(--heading);letter-spacing:-.02em;font-size:1.05rem;font-weight:700;line-height:1.3}.exp-meta{color:var(--muted);margin-top:.2rem;margin-bottom:.8rem;font-size:.82rem}.exp-bullets{flex-direction:column;gap:.75rem;list-style:none;display:flex}.exp-bullets li{color:var(--text-secondary);padding-left:1rem;font-size:.88rem;line-height:1.65;position:relative}.exp-bullets li:before{content:"";background:var(--light);border-radius:50%;width:4px;height:4px;position:absolute;top:.65em;left:0}.project-grid{grid-template-columns:1fr;gap:2rem;display:grid}.project-card{border-bottom:1px solid var(--border);padding:1.8rem 0;transition:border-color .35s}.project-card:first-child{border-top:1px solid var(--border)}.project-name{font-family:var(--heading);letter-spacing:-.01em;margin-bottom:.4rem;font-size:.95rem;font-weight:700}.project-desc{color:var(--text-secondary);margin-bottom:.7rem;font-size:.85rem;line-height:1.65}.project-metric{font-family:var(--heading);color:var(--fg);background:var(--pill-bg);border-radius:4px;margin-bottom:.3rem;margin-right:.4rem;padding:.25rem .7rem;font-size:.82rem;font-weight:700;transition:background .35s;display:inline-block}.portfolio-cta{background:var(--cta-bg);border-radius:8px;justify-content:space-between;align-items:center;gap:1.2rem;margin-top:3rem;padding:1.4rem 1.6rem;transition:background .3s;display:flex}.portfolio-cta:hover{background:var(--cta-bg-hover)}.portfolio-cta-text{flex-direction:column;gap:.15rem;display:flex}.portfolio-cta-title{font-family:var(--heading);color:var(--cta-text);letter-spacing:-.01em;font-size:.88rem;font-weight:700}.portfolio-cta-sub{color:#999;font-size:.75rem}.portfolio-cta-arrow{color:var(--cta-text);flex-shrink:0;font-size:1.1rem;transition:transform .35s cubic-bezier(.16,1,.3,1)}.portfolio-cta:hover .portfolio-cta-arrow{transform:translate(4px)}.stack-group{margin-bottom:2.4rem}.stack-group:last-child{margin-bottom:0}.stack-group-label{font-family:var(--heading);letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:.7rem;font-size:.72rem;font-weight:600}.stack-tags{flex-wrap:wrap;gap:.45rem;display:flex}.stack-tag{font-family:var(--body);color:var(--text-secondary);background:var(--pill-bg);white-space:nowrap;border-radius:100px;padding:.35rem .75rem;font-size:.78rem;font-weight:400;transition:background .35s,color .35s}.award-list{flex-direction:column;gap:1.2rem;list-style:none;display:flex}.award-item{align-items:baseline;gap:1rem;display:flex}.award-rank{font-family:var(--heading);color:var(--fg);white-space:nowrap;min-width:fit-content;font-size:.85rem;font-weight:800}.award-detail{color:var(--text-secondary);font-size:.85rem;line-height:1.5}.cert-list{flex-direction:column;gap:1rem;list-style:none;display:flex}.cert-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:baseline;gap:1rem;padding-bottom:1rem;transition:border-color .35s;display:flex}.cert-item:last-child{border-bottom:none;padding-bottom:0}.cert-name{color:var(--text-secondary);font-size:.88rem;line-height:1.5}.cert-name strong{font-family:var(--heading);color:var(--fg);font-weight:600}.cert-year{font-family:var(--heading);color:var(--light);white-space:nowrap;flex-shrink:0;font-size:.78rem;font-weight:700}footer{max-width:var(--max-w);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin:0 auto;padding:6rem 2rem 3rem;display:flex}footer .footer-copy{letter-spacing:.12em;text-transform:uppercase;color:var(--light);font-size:.68rem}footer .footer-nav{gap:1.2rem;list-style:none;display:flex}footer .footer-nav a{letter-spacing:.1em;text-transform:uppercase;color:var(--light);font-size:.65rem;transition:color .25s}footer .footer-nav a:hover{color:var(--fg)}.reveal{opacity:0;transition:opacity .7s,transform .7s cubic-bezier(.16,1,.3,1);transform:translateY(20px)}.reveal.vis{opacity:1;margin-top:1rem;transform:translateY(0)}.hero-enter{opacity:0;animation:.9s cubic-bezier(.16,1,.3,1) forwards enter;transform:translateY(24px)}.hero-enter-d1{animation-delay:.1s}.hero-enter-d2{animation-delay:.25s}.hero-enter-d3{animation-delay:.4s}@keyframes enter{to{opacity:1;transform:translateY(0)}}.links-page{flex-direction:column;align-items:center;min-height:100vh;padding:3rem 1.5rem 2rem;display:flex}.back{z-index:200;font-family:var(--heading);letter-spacing:.04em;color:var(--muted);background:var(--bg);border:1px solid var(--border);border-radius:100px;align-items:center;gap:.4rem;padding:.45rem .85rem;font-size:.68rem;font-weight:600;transition:color .25s,background .35s,border-color .35s;display:flex;position:fixed;top:1rem;left:1.5rem}.back:hover{color:var(--fg)}.back svg{width:12px;height:12px}.container{flex-direction:column;align-items:center;width:100%;max-width:440px;margin-top:2rem;display:flex}.profile{text-align:center;flex-direction:column;align-items:center;margin-bottom:2.4rem;display:flex}.profile-photo{background:var(--pill-bg);border:2px solid var(--border);border-radius:50%;justify-content:center;align-items:center;width:96px;height:96px;margin-bottom:1.2rem;transition:background .35s,border-color .35s;display:flex;overflow:hidden}.profile-photo img{object-fit:cover;width:100%;height:100%}.profile-name-row{align-items:center;gap:.45rem;margin-bottom:.4rem;display:flex}.profile-name{font-family:var(--heading);letter-spacing:-.03em;font-size:1.4rem;font-weight:800;line-height:1.2}.profile-bio{color:var(--muted);max-width:340px;font-size:.82rem;line-height:1.55}.link-group{width:100%;margin-bottom:2rem}.link-group-label{font-family:var(--heading);letter-spacing:.2em;text-transform:uppercase;color:var(--light);margin-bottom:.7rem;padding-left:.1rem;font-size:.6rem;font-weight:600}.link-list{flex-direction:column;gap:.55rem;width:100%;display:flex}.link-item{background:var(--pill-bg);border:1px solid #0000;border-radius:10px;justify-content:space-between;align-items:center;width:100%;padding:.9rem 1.1rem;transition:border-color .25s,background .25s,transform .25s cubic-bezier(.16,1,.3,1);display:flex}.link-item:hover{border-color:var(--border);transform:translateY(-1px)}.link-item-left{align-items:center;gap:.8rem;min-width:0;display:flex}.link-icon{background:var(--bg);border:1px solid var(--border);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.85rem;transition:background .35s,border-color .35s;display:flex}.link-label{font-family:var(--heading);letter-spacing:-.01em;white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;overflow:hidden}.link-arrow{color:var(--light);flex-shrink:0;font-size:.8rem;transition:transform .3s cubic-bezier(.16,1,.3,1),color .25s}.link-item:hover .link-arrow{color:var(--fg);transform:translate(3px)}.link-item-thumb{flex-direction:column;padding:0;overflow:hidden}.link-thumb{aspect-ratio:16/9;background:var(--border);border-radius:9px 9px 0 0;width:100%;overflow:hidden}.link-thumb img{object-fit:cover;width:100%;height:100%;transition:transform .4s cubic-bezier(.16,1,.3,1);display:block}.link-item-thumb:hover .link-thumb img{transform:scale(1.03)}.link-item-bottom{justify-content:space-between;align-items:center;width:100%;padding:.8rem 1.1rem;display:flex}.links-footer{text-align:center;margin-top:auto;padding-top:3rem}.links-footer p{letter-spacing:.12em;text-transform:uppercase;color:var(--light);font-size:.62rem}.fade-in{opacity:0;animation:.6s cubic-bezier(.16,1,.3,1) forwards appear;transform:translateY(14px)}.fd1{animation-delay:50ms}.fd2{animation-delay:.1s}.fd3{animation-delay:.15s}.fd4{animation-delay:.2s}.fd5{animation-delay:.25s}.fd6{animation-delay:.3s}.fd7{animation-delay:.35s}.fd8{animation-delay:.4s}.fd9{animation-delay:.45s}.fd10{animation-delay:.5s}.fd11{animation-delay:.55s}.fd12{animation-delay:.6s}.fd13{animation-delay:.65s}.fd14{animation-delay:.7s}.fd15{animation-delay:.75s}@keyframes appear{to{opacity:1;transform:translateY(0)}}@media (width<=640px){:root{--section-gap:3.5rem}.controls{top:.8rem;right:.8rem}.hero{min-height:auto;padding:7rem 1.4rem 4rem}.hero-top{flex-direction:column;align-items:flex-start;gap:1.2rem}.hero-photo{width:90px;height:90px}.verified-badge{width:20px;height:20px}.section{padding:0 1.4rem}.section-label{margin-bottom:2rem}.hero-links{gap:1rem}.exp-item{margin-bottom:3rem}.award-item{flex-direction:column;gap:.2rem}.cert-item{flex-direction:column;gap:.3rem}footer{flex-direction:column;align-items:flex-start;padding:4rem 1.4rem 2rem}nav .nav-links{gap:.8rem}nav .nav-links a{font-size:.62rem}.section-divider{width:auto;margin-left:1.4rem;margin-right:1.4rem}}@media (width<=500px){.links-page{padding:2.5rem 1rem 1.5rem}.back{padding:.4rem .7rem;top:.8rem;left:.8rem}.container{margin-top:1.5rem}.link-label{font-size:.8rem}}@media (width<=400px){nav .nav-links{display:none}}
