@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=Syne:wght@700;800&display=swap";:root{--bg:#020617;--bg2:#0f172a66;--bg3:#1e293b4d;--border:#94a3b81a;--b-hover:#94a3b840;--accent:#8b5cf6;--acc2:#a78bfa;--acc3:#c4b5fd;--acc-rgb:139, 92, 246;--acc-glow:#8b5cf640;--green:#10b981;--pink:#ec4899;--yellow:#f59e0b;--t1:#f8fafc;--t2:#94a3b8;--t3:#64748b;--f-body:"Plus Jakarta Sans", system-ui, sans-serif;--f-head:"Syne", sans-serif;--r:18px;--rs:10px;--rf:999px;--ease:cubic-bezier(.16, 1, .3, 1);--spring:cubic-bezier(.175, .885, .32, 1.275)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}.global-bg{background-color:var(--bg);z-index:-2;background-image:linear-gradient(#ffffff05 1px,#0000 1px),linear-gradient(90deg,#ffffff05 1px,#0000 1px);background-size:40px 40px;width:100vw;height:100vh;position:fixed;top:0;left:0}.bg-canvas{z-index:-1;pointer-events:none;width:100vw;height:100vh;position:fixed;top:0;left:0}body{color:var(--t1);font-family:var(--f-body);cursor:none;background:0 0;line-height:1.65;overflow-x:hidden}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}ul{list-style:none}button{cursor:none;background:0 0;border:none;font-family:inherit}input,textarea{font-family:inherit}.cursor{background:var(--accent);pointer-events:none;z-index:9999;border-radius:50%;width:9px;height:9px;transition:width .2s,height .2s,background .2s;position:fixed;transform:translate(-50%,-50%)}.cursor-ring{pointer-events:none;z-index:9998;border:1.5px solid #7c6ff773;border-radius:50%;width:34px;height:34px;position:fixed;transform:translate(-50%,-50%)}.cursor.hov{background:var(--acc2);width:18px;height:18px}.cursor-ring.hov{border-color:#a78bfa59;width:56px;height:56px}.ambient{pointer-events:none;filter:blur(110px);z-index:0;border-radius:50%;position:fixed}.a1{background:radial-gradient(circle,#7c6ff71f 0%,#0000 70%);width:650px;height:650px;top:-200px;right:-100px}.a2{background:radial-gradient(circle,#a78bfa14 0%,#0000 70%);width:420px;height:420px;bottom:10%;left:-120px}.a3{background:radial-gradient(circle,#34d3990f 0%,#0000 70%);width:300px;height:300px;bottom:-60px;right:15%}.wrap{z-index:1;max-width:1160px;margin:0 auto;padding:0 28px;position:relative}.section{padding:120px 0}#nav{z-index:1000;padding:16px 40px;transition:background .4s,border .4s;position:fixed;top:0;left:0;right:0;overflow:hidden}#nav.scrolled{-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);background:#04040ad9}.nav-wrap{justify-content:space-between;align-items:center;gap:32px;max-width:1160px;margin:0 auto;display:flex}.logo{font-family:var(--f-head);font-size:22px;font-weight:800}.logo span{color:var(--accent)}.nav-list{align-items:center;gap:28px;display:flex}.nl{color:var(--t2);font-size:14px;font-weight:500;transition:color .2s;position:relative}.nl:after{content:"";background:var(--accent);width:0;height:1px;transition:width .3s var(--ease);position:absolute;bottom:-3px;left:0}.nl:hover,.nl.active{color:var(--t1)}.nl:hover:after,.nl.active:after{width:100%}.nav-btn{background:var(--accent);color:#fff;border-radius:var(--rf);flex-shrink:0;padding:10px 22px;font-size:14px;font-weight:700;transition:background .3s,transform .3s}.nav-btn:hover{background:var(--acc2);transform:translateY(-2px)}.burger{flex-direction:column;gap:5px;padding:6px;display:none}.burger span{background:var(--t1);border-radius:2px;width:22px;height:2px;transition:all .3s;display:block}.burger.open span:first-child{transform:translateY(7px)rotate(45deg)}.burger.open span:nth-child(2){opacity:0}.burger.open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.mob-menu{background:var(--bg);z-index:1050;opacity:0;pointer-events:none;justify-content:center;align-items:center;transition:opacity .35s;display:flex;position:fixed;inset:0}.mob-menu.open{opacity:1;pointer-events:all}.mob-menu ul{text-align:center;flex-direction:column;gap:28px;display:flex}.mob-link{font-family:var(--f-head);color:var(--t2);font-size:32px;font-weight:800;transition:color .2s}.mob-link:hover{color:var(--t1)}.btn{border-radius:var(--rf);transition:transform .3s var(--spring), box-shadow .3s, background .3s, border-color .3s;align-items:center;gap:8px;padding:13px 28px;font-size:15px;font-weight:700;display:inline-flex}.btn.primary{background:var(--accent);color:#fff}.btn.primary:hover{background:var(--acc2);box-shadow:0 14px 40px rgba(var(--acc-rgb), .4);transform:translateY(-3px)}.btn.ghost{border:1px solid var(--b-hover);color:var(--t1)}.btn.ghost:hover{background:#00000008;border-color:#00000026;transform:translateY(-2px)}.btn.full{justify-content:center;width:100%}.sec-label{letter-spacing:.1em;text-transform:uppercase;color:var(--accent);align-items:center;gap:12px;margin-bottom:18px;font-size:12px;font-weight:700;display:flex}.ll{background:var(--accent);width:30px;height:1px;display:inline-block}.sec-heading{font-family:var(--f-head);letter-spacing:-.04em;margin-bottom:56px;font-size:clamp(34px,5vw,56px);font-weight:800;line-height:1.08}.grad{background:linear-gradient(135deg, var(--accent) 0%, var(--acc2) 50%, var(--pink) 100%);-webkit-text-fill-color:transparent;background-clip:text}.fup{opacity:0;transition:opacity .75s var(--ease), transform .75s var(--ease);transform:translateY(36px)}.fup.vis{opacity:1;transform:translateY(0)}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-14px)}}@keyframes float-slow{0%,to{transform:translateY(0)}50%{transform:translateY(-9px)}}.floating{animation:6s ease-in-out infinite float}.floating-slow{animation:8s ease-in-out infinite float-slow}.hero{background:0 0;flex-direction:column;justify-content:center;min-height:100vh;padding-top:80px;display:flex;position:relative;overflow:hidden}.hero .split-name,.hero .body-text,.hero .hero-title{color:var(--t1)}.hero p.hero-title{color:var(--t2)}.hero .wrap{z-index:1;grid-template-columns:1fr 1fr;align-items:center;gap:80px;padding-top:40px;padding-bottom:80px;display:grid;position:relative}.hero-tag{border-radius:var(--rf);color:var(--green);background:#34d3990d;border:1px solid #34d39947;align-items:center;gap:8px;margin-bottom:24px;padding:7px 16px;font-size:13px;font-weight:600;display:inline-flex}.tag-dot{background:var(--green);border-radius:50%;width:7px;height:7px;animation:2s ease-in-out infinite pulse-d}@keyframes pulse-d{0%,to{box-shadow:0 0 #34d39980}50%{box-shadow:0 0 0 5px #34d39900}}.hero-name-row{margin-bottom:14px}.split-name{font-family:var(--f-head);letter-spacing:-.04em;white-space:nowrap;flex-wrap:nowrap;gap:0;font-size:clamp(44px,6.5vw,82px);font-weight:800;line-height:1;display:flex}.split-name .sl{opacity:0;transform-origin:top;animation:letter-in .55s var(--spring) forwards;display:inline-block;transform:translateY(40px)rotateX(-90deg)}.split-name .sp{width:.35em;display:inline-block}@keyframes letter-in{to{opacity:1;transform:translateY(0)rotateX(0)}}.hero-title{color:var(--acc2);letter-spacing:.01em;margin-bottom:20px;font-size:clamp(15px,1.8vw,20px);font-weight:600}.hero-sub{color:var(--t2);max-width:460px;margin-bottom:36px;font-size:16px;line-height:1.75}.hero-btns{flex-wrap:wrap;gap:12px;margin-bottom:52px;display:flex}.hero-stats{align-items:center;display:flex}.stat{flex-direction:column;padding:0 28px;display:flex}.stat:first-child{padding-left:0}.snum{font-family:var(--f-head);letter-spacing:-.03em;color:var(--t1);font-size:33px;font-weight:800;line-height:1}.splus{color:var(--accent);font-size:22px;font-weight:800}.slabel{color:var(--t3);letter-spacing:.06em;text-transform:uppercase;margin-top:4px;font-size:11px;font-weight:600}.sdiv{background:var(--border);flex-shrink:0;width:1px;height:38px}.hero-visual{aspect-ratio:1;justify-content:center;align-items:center;width:100%;max-width:400px;margin:0 auto;display:flex;position:relative}.img-ring{border-radius:50%;animation:linear infinite spin;position:absolute}.r1{border:1px dashed #ffffff14;animation-duration:35s;inset:0}.r2{border:1px solid rgba(var(--acc-rgb), .12);animation-duration:22s;animation-direction:reverse;inset:11%}.r3{border:1px solid rgba(var(--acc-rgb), .06);animation-duration:16s;inset:22%}@keyframes spin{to{transform:rotate(360deg)}}.hero-img-box{z-index:2;border:3px solid rgba(var(--acc-rgb), .3);width:64%;height:64%;box-shadow:0 0 60px rgba(var(--acc-rgb), .22), 0 0 120px rgba(var(--acc-rgb), .08);border-radius:50%;overflow:hidden}.hero-img{object-fit:cover;object-position:top;width:100%;height:100%}.chip{border-radius:var(--rs);border:1px solid var(--b-hover);z-index:3;backdrop-filter:blur(10px);background:#0a0a14e6;align-items:center;gap:7px;padding:9px 15px;font-size:13px;font-weight:600;animation:5s ease-in-out infinite chip-f;display:inline-flex;position:absolute}.chip-a{animation-delay:0s;top:8%;right:-4%}.chip-b{animation-delay:1.6s;bottom:14%;left:-6%}.chip-c{animation-delay:.8s;bottom:28%;right:-8%}@keyframes chip-f{0%,to{transform:translateY(0)}50%{transform:translateY(-9px)}}.scroll-hint{z-index:1;flex-direction:column;align-items:center;gap:9px;display:flex;position:absolute;bottom:28px;left:50%;transform:translate(-50%)}.scroll-box{border:2px solid var(--b-hover);border-radius:11px;justify-content:center;width:22px;height:36px;padding-top:5px;display:flex}.scroll-ball{background:var(--accent);border-radius:2px;width:4px;height:7px;animation:1.8s ease-in-out infinite scroll-b}@keyframes scroll-b{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(12px)}}.scroll-hint span{color:var(--t3);letter-spacing:.07em;text-transform:uppercase;font-size:11px}.about-grid{grid-template-columns:.8fr 1.2fr;align-items:start;gap:72px;display:grid}.about-img-frame{position:relative}.about-img{border-radius:var(--r);border:1px solid var(--border);object-fit:cover;object-position:top;width:100%;max-height:480px}.frame-deco{border:1px solid rgba(var(--acc-rgb), .18);border-radius:var(--r);z-index:-1;width:100%;height:100%;position:absolute;bottom:-14px;right:-14px}.body-text{color:var(--t2);margin-bottom:18px;font-size:16px;line-height:1.8}.body-text strong{color:var(--t1);font-weight:600}.about-btns{flex-wrap:wrap;gap:12px;margin-top:8px;display:flex}.marquee-wrap{margin-bottom:56px;overflow:hidden;mask-image:linear-gradient(90deg,#0000,#000 12% 88%,#0000)}.marquee-track{white-space:nowrap;align-items:center;gap:24px;width:max-content;animation:22s linear infinite marquee;display:flex}.marquee-wrap:hover .marquee-track{animation-play-state:paused}.marquee-track span{font-family:var(--f-head);color:var(--t3);font-size:26px;font-weight:700}.marquee-track span:hover{color:var(--t1);cursor:default}.marquee-track .dot{color:var(--accent);font-size:22px}@keyframes marquee{to{transform:translate(-50%)}}.skills-grid{grid-template-columns:repeat(3,1fr);gap:18px;display:grid}.sk-card{-webkit-backdrop-filter:blur(12px);transition:transform .35s var(--spring), background .3s, border-color .3s, box-shadow .3s;cursor:default;background:#0f172aa6;border:1px solid #8b5cf64d;border-radius:16px;padding:30px;box-shadow:0 0 15px #8b5cf61a}.sk-card:hover{background:#1e293bd9;border-color:#8b5cf6b3;transform:translateY(-8px);box-shadow:0 15px 40px #8b5cf64d}.sk-icon{background:rgba(var(--acc-rgb), .1);border-radius:var(--rs);width:50px;height:50px;color:var(--acc2);justify-content:center;align-items:center;margin-bottom:18px;display:flex}.sk-card h3{letter-spacing:-.02em;margin-bottom:14px;font-size:17px;font-weight:700}.sk-tags{flex-wrap:wrap;gap:7px;display:flex}.sk-tags span{border-radius:var(--rf);border:1px solid var(--border);color:var(--t2);background:#ffffff0a;padding:4px 12px;font-size:12px;font-weight:500}.proj-grid{grid-template-columns:repeat(2,1fr);gap:22px;display:grid}.proj-card{-webkit-backdrop-filter:blur(12px);transition:transform .4s var(--spring), background .3s, border-color .3s, box-shadow .3s;cursor:pointer;background:#0f172aa6;border:1px solid #8b5cf64d;border-radius:16px;overflow:hidden;box-shadow:0 0 15px #8b5cf61a}.proj-card:hover{background:#1e293bd9;border-color:#8b5cf6b3;transform:translateY(-10px);box-shadow:0 20px 50px #8b5cf64d}.proj-img-real img{object-fit:cover;width:100%;height:100%;transition:transform .5s var(--ease);position:absolute;inset:0}.proj-card:hover .proj-img-real img{transform:scale(1.07)}.proj-img{justify-content:center;align-items:center;height:220px;display:flex;position:relative;overflow:hidden}.proj-icon-wrap{width:80px;height:80px;transition:transform .4s var(--spring);background:#fff3;border:1px solid #fff6;border-radius:50%;justify-content:center;align-items:center;display:flex}.proj-card:hover .proj-icon-wrap{transform:scale(1.1)}.proj-overlay{opacity:0;background:#fffc;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:absolute;inset:0}.proj-card:hover .proj-overlay{opacity:1}.proj-link-btn{color:#000;border-radius:var(--rf);transition:transform .25s var(--spring), background .2s;background:#fff;padding:9px 20px;font-size:13px;font-weight:700}.proj-link-btn:hover{background:var(--acc2);color:#fff;transform:scale(1.06)}.proj-info{padding:24px}.pnum{color:var(--accent);font-size:12px;font-weight:700;font-family:var(--f-head);margin-bottom:8px;display:block}.proj-info h3{letter-spacing:-.02em;margin-bottom:10px;font-size:19px;font-weight:700}.proj-info p{color:var(--t2);margin-bottom:14px;font-size:14px;line-height:1.65}.ptags{flex-wrap:wrap;gap:7px;display:flex}.ptags span{border-radius:var(--rf);background:rgba(var(--acc-rgb), .08);border:1px solid rgba(var(--acc-rgb), .2);color:var(--acc3);padding:4px 12px;font-size:11px;font-weight:600}.timeline{max-width:780px;margin:0 auto;position:relative}.timeline:before{content:"";background:linear-gradient(to bottom, transparent, var(--border) 10%, var(--border) 90%, transparent);width:1px;position:absolute;top:0;bottom:0;left:16px}.tl-item{margin-bottom:44px;padding-left:52px;position:relative}.tl-dot{background:var(--accent);border:3px solid var(--bg);width:15px;height:15px;box-shadow:0 0 0 2px var(--acc-glow);border-radius:50%;position:absolute;top:22px;left:9px}.tl-card{-webkit-backdrop-filter:blur(12px);transition:transform .35s var(--spring), background .3s, border-color .3s, box-shadow .3s;background:#0f172aa6;border:1px solid #8b5cf64d;border-radius:16px;padding:28px;box-shadow:0 0 15px #8b5cf61a}.tl-card:hover{background:#1e293bd9;border-color:#8b5cf6b3;transform:translateY(-5px);box-shadow:0 15px 40px #8b5cf64d}.tl-date{color:var(--accent);margin-bottom:6px;font-size:12px;font-weight:700;display:block}.tl-role{letter-spacing:-.02em;margin-bottom:4px;font-size:20px;font-weight:700}.tl-org{color:var(--t2);margin-bottom:16px;font-size:14px}.tl-list{color:var(--t2);margin-bottom:16px;padding-left:18px;font-size:14px;line-height:1.75;list-style:outside}.tl-tags{flex-wrap:wrap;gap:7px;display:flex}.tl-tags span{border-radius:var(--rf);background:rgba(var(--acc-rgb), .08);border:1px solid rgba(var(--acc-rgb), .16);color:var(--acc3);padding:4px 12px;font-size:11px;font-weight:600}.edu-grid{grid-template-columns:1fr 1fr;gap:22px;margin-bottom:60px;display:grid}.edu-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);transition:transform .35s var(--spring), border-color .3s;overflow:hidden}.edu-card:hover{border-color:rgba(var(--acc-rgb), .28);transform:translateY(-6px)}.edu-year-badge{background:rgba(var(--acc-rgb), .08);border-bottom:1px solid var(--border);color:var(--accent);letter-spacing:.05em;padding:10px 20px;font-size:12px;font-weight:700}.edu-body{align-items:flex-start;gap:18px;padding:26px;display:flex}.edu-icon{background:rgba(var(--acc-rgb), .1);border-radius:var(--rs);width:48px;height:48px;color:var(--acc2);flex-shrink:0;justify-content:center;align-items:center;display:flex}.edu-body h3{letter-spacing:-.01em;margin-bottom:5px;font-size:17px;font-weight:700}.edu-inst{color:var(--t2);margin-bottom:3px;font-size:14px}.edu-place{color:var(--t3);margin-bottom:14px;font-size:13px}.edu-score{align-items:baseline;gap:6px;display:flex}.score-val{font-family:var(--f-head);color:var(--accent);font-size:28px;font-weight:800}.score-lbl{color:var(--t2);letter-spacing:.04em;text-transform:uppercase;font-size:12px;font-weight:600}.sub-head{letter-spacing:-.02em;color:var(--t1);margin-bottom:22px;font-size:20px;font-weight:700}.cert-row{flex-wrap:wrap;gap:12px;display:flex}.cert-pill{background:var(--bg2);border:1px solid var(--border);border-radius:var(--rf);color:var(--t2);align-items:center;gap:10px;padding:11px 20px;font-size:14px;font-weight:500;transition:border-color .3s,color .3s,transform .3s;display:inline-flex}.cert-pill:hover{border-color:rgba(var(--acc-rgb), .3);color:var(--t1);transform:translateY(-3px)}.cpill-dot{background:var(--accent);border-radius:50%;flex-shrink:0;width:7px;height:7px}.contact-grid{grid-template-columns:1fr 1.5fr;align-items:start;gap:72px;display:grid}.contact-info{flex-direction:column;gap:28px;display:flex}.ci-item{flex-direction:column;gap:4px;display:flex}.ci-label{letter-spacing:.08em;text-transform:uppercase;color:var(--t3);font-size:11px;font-weight:700}.ci-val{color:var(--t1);font-size:15px;font-weight:500;transition:color .2s}a.ci-val:hover{color:var(--accent)}.socials{flex-direction:column;gap:12px;margin-top:8px;display:flex}.soc-btn{background:var(--bg2);border:1px solid var(--border);border-radius:var(--rs);color:var(--t2);align-items:center;gap:12px;padding:13px 20px;font-size:15px;font-weight:700;transition:border-color .3s,color .3s,transform .3s;display:flex}.soc-btn:hover{border-color:rgba(var(--acc-rgb), .3);color:var(--t1);transform:translate(4px)}.contact-form{flex-direction:column;gap:18px;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:18px;display:grid}.fg{flex-direction:column;gap:7px;display:flex}.fg label{color:var(--t2);font-size:13px;font-weight:600}input,textarea{background:var(--bg3);border:1px solid var(--border);border-radius:var(--rs);width:100%;color:var(--t1);resize:none;outline:none;padding:13px 16px;font-size:15px;transition:border-color .25s,box-shadow .25s}input:focus,textarea:focus{border-color:rgba(var(--acc-rgb), .5);box-shadow:0 0 0 3px rgba(var(--acc-rgb), .08)}input::placeholder,textarea::placeholder{color:var(--t3)}.form-ok{color:var(--green);text-align:center;border-radius:var(--rs);background:#34d39914;border:1px solid #34d39933;padding:12px;font-size:14px;display:none}.form-ok.show{display:block}#footer{border-top:1px solid var(--border);margin-top:40px;padding:36px 0}.footer-inner{justify-content:space-between;align-items:center;display:flex}.footer-copy{color:var(--t3);font-size:14px}.footer-socials{gap:20px;display:flex}.footer-socials a{color:var(--t3);transition:color .2s}.footer-socials a:hover{color:var(--t1)}.mag,.mag-soft{transition:transform .3s var(--spring)}@media (width<=1024px){.hero .wrap{text-align:center;grid-template-columns:1fr;gap:60px}.hero-sub,.hero-btns,.hero-stats,.hero-tag{margin-left:auto;margin-right:auto}.hero-btns,.hero-stats{justify-content:center}.hero-visual{max-width:320px}.about-grid{grid-template-columns:1fr}.about-img-col{max-width:340px;margin:0 auto}.skills-grid{grid-template-columns:repeat(2,1fr)}.contact-grid{grid-template-columns:1fr;gap:52px}.edu-grid{grid-template-columns:1fr}}@media (width<=768px){.section{padding:80px 0}#nav{padding:14px 20px}.nav-list,.nav-btn{display:none}.burger{display:flex}.proj-grid,.form-row{grid-template-columns:1fr}.footer-inner{text-align:center;flex-direction:column;gap:12px}.skills-grid{grid-template-columns:1fr}.split-name{font-size:clamp(44px,11vw,72px)}.hero-stats{flex-wrap:wrap}.cert-row{flex-direction:column}}@media (width<=480px){.wrap{padding:0 18px}.split-name{font-size:40px}.hero-visual{max-width:260px}.sec-heading{font-size:30px}}