*,: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}.particle-bg{z-index:-1;pointer-events:none;width:100%;height:100%;position:fixed;inset:0}.ab-launcher{z-index:300;flex-direction:column;align-items:flex-end;gap:.55rem;display:flex;position:fixed;bottom:1.25rem;right:1.25rem}.ab-fab{border:1px solid var(--border);cursor:pointer;background:#fafafa;border-radius:50%;width:64px;height:64px;padding:0;transition:transform .22s cubic-bezier(.16,1,.3,1);position:relative;box-shadow:0 10px 28px #00000038}.ab-fab:hover{transform:translateY(-3px)scale(1.04)}.ab-fab img{object-fit:cover;object-position:center top;border-radius:50%;width:100%;height:100%;display:block}.ab-dot{background:#34c759;border:2px solid #fafafa;border-radius:50%;width:13px;height:13px;position:absolute;bottom:4px;right:4px}.ab-bubble{max-width:220px;font-family:var(--heading);color:#1a1a1a;-webkit-backdrop-filter:blur(14px)saturate(180%);backdrop-filter:blur(14px)saturate(180%);cursor:pointer;background:#ffffffb8;border:1px solid #fff9;border-radius:18px;margin-right:6px;padding:.6rem .9rem;font-size:.85rem;font-weight:500;line-height:1.3;animation:.45s cubic-bezier(.16,1,.3,1) ab-bubble-in;position:relative;box-shadow:0 8px 24px #00000024}.ab-bubble:after{content:"";background:#ffffffb8;border-bottom:1px solid #fff9;border-right:1px solid #fff9;width:11px;height:11px;position:absolute;bottom:-5px;right:22px;transform:rotate(45deg)}[data-theme=dark] .ab-bubble{color:#f0f0f0;background:#28282ab3;border-color:#ffffff1f}[data-theme=dark] .ab-bubble:after{background:#28282ab3;border-color:#ffffff1f}@keyframes ab-bubble-in{0%{opacity:0;transform:translateY(8px)scale(.94)}to{opacity:1;transform:translateY(0)scale(1)}}.chat-panel{z-index:300;background:var(--bg);border:1px solid var(--border);border-radius:18px;flex-direction:column;width:min(380px,100vw - 2rem);height:min(560px,100vh - 2rem);animation:.22s cubic-bezier(.16,1,.3,1) chat-in;display:flex;position:fixed;bottom:1.25rem;right:1.25rem;overflow:hidden;box-shadow:0 16px 48px #00000038}@keyframes chat-in{0%{opacity:0;transform:translateY(12px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.chat-header{border-bottom:1px solid var(--border);background:var(--pill-bg);justify-content:space-between;align-items:center;padding:.9rem 1.1rem;display:flex}.chat-title{font-family:var(--heading);font-size:.95rem;font-weight:700}.chat-subtitle{color:var(--muted);margin-top:.1rem;font-size:.72rem}.chat-close{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:0 .25rem;font-size:1.5rem;line-height:1}.chat-close:hover{color:var(--fg)}.chat-head-left{align-items:center;gap:.6rem;display:flex}.chat-head-avatar{object-fit:cover;object-position:center top;background:#fafafa;border-radius:50%;flex-shrink:0;width:36px;height:36px}.chat-head-right{align-items:center;gap:.45rem;display:flex}.chat-lang-switch{font-family:var(--heading);letter-spacing:.04em;color:var(--muted);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:100px;padding:.2rem .5rem;font-size:.66rem;font-weight:600;transition:color .2s,border-color .2s}.chat-lang-switch:hover{color:var(--fg);border-color:var(--light)}.chat-loading{flex:1;justify-content:center;align-items:center;gap:.4rem;display:flex}.chat-loading span{background:var(--light);border-radius:50%;width:8px;height:8px;animation:1s ease-in-out infinite chat-dot}.chat-loading span:nth-child(2){animation-delay:.15s}.chat-loading span:nth-child(3){animation-delay:.3s}@keyframes chat-dot{0%,to{opacity:.3;transform:translateY(0)}50%{opacity:1;transform:translateY(-3px)}}.chat-body{flex-direction:column;flex:1;gap:.6rem;padding:1rem;display:flex;overflow-y:auto}.chat-msg{white-space:pre-wrap;word-wrap:break-word;border-radius:14px;max-width:85%;padding:.6rem .85rem;font-size:.85rem;line-height:1.55}.chat-msg-bot{background:var(--pill-bg);color:var(--fg);border-bottom-left-radius:4px;align-self:flex-start}.chat-msg-user{background:var(--blue);color:#fff;border-bottom-right-radius:4px;align-self:flex-end}.chat-msg a{word-break:break-word;text-decoration:underline}.chat-msg-bot a{color:var(--blue)}.chat-msg-user a{color:#fff}.chat-suggestions{flex-wrap:wrap;gap:.4rem;margin-top:.2rem;display:flex}.chat-chip{font-family:var(--body);color:var(--fg);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:100px;padding:.4rem .75rem;font-size:.78rem;transition:background .2s,border-color .2s}.chat-chip:hover{background:var(--card-hover);border-color:var(--light)}.chat-input{border-top:1px solid var(--border);align-items:center;gap:.5rem;padding:.75rem;display:flex}.chat-input input{font-family:var(--body);color:var(--fg);background:var(--pill-bg);border:1px solid var(--border);border-radius:100px;outline:none;flex:1;padding:.6rem .95rem;font-size:.85rem}.chat-input input:focus{border-color:var(--blue)}.chat-input button{background:var(--cta-bg);width:38px;height:38px;color:var(--cta-text);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;place-items:center;transition:opacity .2s;display:grid}.chat-input button:disabled{opacity:.4;cursor:not-allowed}.chat-input button svg{width:16px;height:16px}.chat-disclaimer{text-align:center;color:var(--muted);padding:0 .75rem .6rem;font-size:.65rem}.chat-lang{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:1.1rem;padding:1.5rem;display:flex}.chat-lang-q{color:var(--fg);font-size:.92rem;line-height:1.5}.chat-lang-btns{flex-direction:column;gap:.6rem;width:100%;max-width:240px;display:flex}.chat-lang-btns button{font-family:var(--heading);color:var(--cta-text);background:var(--cta-bg);cursor:pointer;border:none;border-radius:100px;padding:.7rem 1rem;font-size:.9rem;font-weight:600;transition:background .25s}.chat-lang-btns button:hover{background:var(--cta-bg-hover)}@media (width<=600px){.ab-fab{width:56px;height:56px}.ab-bubble{max-width:180px;font-size:.8rem}}.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;padding:6rem 2rem 4rem;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;--topbar-h:3.4rem}.controls{top:calc(var(--topbar-h) / 2);right:1.4rem;transform:translateY(-50%)}nav .nav-inner{min-height:var(--topbar-h);padding:0 1.4rem}.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{display:none}.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}}
