*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-snap-type:y mandatory;scroll-behavior:smooth}body{color:#cbd5e1;cursor:none;background:#04080f;font-family:Inter,sans-serif;overflow-x:hidden}@media (hover:none){body{cursor:auto}}.cursor{pointer-events:none;z-index:9999;border-radius:50%;position:fixed;transform:translate(-50%,-50%)}.cursor--dot{mix-blend-mode:screen;background:#38bdf8;width:8px;height:8px;transition:width .15s,height .15s,background .15s}.cursor--ring{z-index:9998;border:1px solid #38bdf859;width:32px;height:32px;transition:width .2s,height .2s}.cursor--large .cursor--dot{background:#fb923c;width:18px;height:18px}.cursor--large .cursor--ring{width:46px;height:46px}@media (hover:none){.cursor{display:none}}.progress-bar{z-index:300;background:linear-gradient(90deg,#38bdf8,#818cf8);width:0%;height:2px;transition:width .1s linear;position:fixed;top:0;left:0;box-shadow:0 0 8px #38bdf880}.nav{z-index:200;border-bottom:1px solid #0000;justify-content:space-between;align-items:center;height:60px;padding:0 clamp(1.5rem,4vw,3rem);transition:background .4s,border-color .4s;display:flex;position:fixed;top:0;left:0;right:0}.nav--stuck{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#04080feb;border-color:#38bdf81a}.nav__logo{color:#38bdf8;letter-spacing:.25em;font-family:Space Mono,monospace;font-size:.75rem;font-weight:700;text-decoration:none}.nav__links{gap:1.75rem;list-style:none;display:flex}@media (width<=700px){.nav__links{display:none}}.nav__link{color:#ffffffa6;letter-spacing:.15em;font-family:Space Mono,monospace;font-size:.6rem;text-decoration:none;transition:color .2s;position:relative}.nav__link:after{content:"";background:#38bdf8;height:1px;transition:transform .25s;position:absolute;bottom:-3px;left:0;right:0;transform:scaleX(0)}.nav__link:hover{color:#38bdf8}.nav__link:hover:after{transform:scaleX(1)}.snap-section{scroll-snap-align:start;scroll-snap-stop:always;justify-content:center;align-items:center;width:100%;min-height:100vh;display:flex;overflow:hidden}.page-section{flex-direction:column;justify-content:center;width:100%;max-width:1100px;min-height:100vh;margin:0 auto;padding:7rem clamp(1.5rem,5vw,3rem);display:flex}.sec-eye{letter-spacing:.3em;color:#38bdf8;align-items:center;gap:.75rem;margin-bottom:.6rem;font-family:Space Mono,monospace;font-size:.6rem;display:flex}.sec-eye:before{content:"";background:#38bdf8;flex-shrink:0;width:1.5rem;height:1px;display:block}.sec-eye--center{justify-content:center}.sec-eye--center:before{display:none}.sec-title{color:#fff;margin-bottom:3rem;font-family:Syne,sans-serif;font-size:clamp(1.6rem,3.5vw,2.6rem);font-weight:700;line-height:1.15}.sec-title span{color:#38bdf8}.btn{letter-spacing:.12em;cursor:pointer;border:none;border-radius:3px;align-items:center;gap:.4rem;padding:.7rem 1.8rem;font-family:Space Mono,monospace;font-size:.7rem;text-decoration:none;transition:all .2s;display:inline-flex}.btn--solid{color:#04080f;background:#38bdf8;font-weight:700}.btn--solid:hover{color:#38bdf8;background:0 0;box-shadow:inset 0 0 0 1px #38bdf8,0 0 18px #38bdf833}.btn--outline{color:#cbd5e1;background:0 0;box-shadow:inset 0 0 0 1px #cbd5e133}.btn--outline:hover{color:#38bdf8;box-shadow:inset 0 0 0 1px #38bdf8,0 0 14px #38bdf826}.reveal{opacity:0;transition:opacity .7s,transform .7s;transform:translateY(24px)}.reveal.in{opacity:1;transform:none}footer{text-align:center;letter-spacing:.12em;color:#64748b;scroll-snap-align:start;border-top:1px solid #38bdf81a;padding:2rem;font-family:Space Mono,monospace;font-size:.58rem}@keyframes up{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}@keyframes fadeIn{to{opacity:.45}}.hero{text-align:center;scroll-snap-align:start;scroll-snap-stop:always;flex-direction:column;justify-content:center;align-items:center;height:100vh;min-height:100vh;display:flex;position:relative;overflow:hidden}.hero__canvas{width:100%;height:100%;display:block;position:absolute;inset:0}.hero__inner{z-index:2;flex-direction:column;align-items:center;display:flex;position:relative}.hero__tag{letter-spacing:.35em;color:#38bdf8;opacity:0;margin-bottom:1.5rem;font-family:Space Mono,monospace;font-size:.65rem;animation:.7s .2s forwards up}.hero__name{color:#fff;opacity:0;margin-bottom:.6rem;font-family:Syne,sans-serif;font-size:clamp(3.5rem,10vw,7rem);font-weight:800;line-height:.95;animation:.7s .4s forwards up}.hero__name span{background:linear-gradient(135deg,#38bdf8 0%,#818cf8 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero__role{color:#fb923c;letter-spacing:.12em;opacity:0;margin-bottom:1.5rem;font-family:Syne,sans-serif;font-size:clamp(1rem,2.5vw,1.4rem);font-weight:600;animation:.7s .6s forwards up}.hero__desc{color:#ffffffbf;opacity:0;max-width:440px;margin-bottom:2.5rem;font-size:.95rem;line-height:1.8;animation:.7s .8s forwards up}.hero__btns{opacity:0;gap:1rem;animation:.7s 1s forwards up;display:flex}.hero__socials{opacity:0;gap:1.5rem;margin-top:2rem;animation:.7s 1.2s forwards up;display:flex}.hero__social-link{letter-spacing:.12em;color:#ffffffa6;align-items:center;gap:.4rem;font-family:Space Mono,monospace;font-size:.6rem;text-decoration:none;transition:color .2s;display:flex}.hero__social-link svg{flex-shrink:0}.hero__social-link:hover{color:#38bdf8}.hero__scroll-hint{z-index:2;letter-spacing:.2em;color:#ffffff8c;opacity:0;flex-direction:column;align-items:center;gap:.5rem;font-family:Space Mono,monospace;font-size:.55rem;animation:1s 1.8s forwards fadeIn;display:flex;position:absolute;bottom:2.5rem;left:50%;transform:translate(-50%)}.hero__scroll-hint .line{background:linear-gradient(#38bdf8,#0000);width:1px;height:36px}.about__grid{grid-template-columns:1fr 1fr;align-items:start;gap:5rem;display:grid}@media (width<=720px){.about__grid{grid-template-columns:1fr;gap:2.5rem}}.about__text p{color:#94a3b8;margin-bottom:1rem;font-size:.93rem;line-height:1.85}.about__text p strong{color:#cbd5e1;font-weight:500}.about__stats{background:#38bdf81a;border:1px solid #38bdf81a;border-radius:4px;grid-template-columns:1fr 1fr;gap:1px;display:grid;overflow:hidden}.about__stat{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#070d1abf;padding:1.5rem;transition:background .2s}.about__stat:hover{background:#38bdf80a}.about__stat-n{color:#38bdf8;margin-bottom:.4rem;font-family:Syne,sans-serif;font-size:1.8rem;font-weight:800;line-height:1;display:block}.about__stat-l{letter-spacing:.1em;color:#64748b;font-family:Space Mono,monospace;font-size:.58rem}.skills__wrap{position:relative}@media (width>=769px){.skills__blocks{grid-template-columns:1fr 1fr;gap:2rem 3rem;display:grid}}@media (width<=768px){.skills__blocks{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;cursor:grab;gap:1rem;padding-bottom:1rem;display:flex;overflow-x:auto}.skills__blocks::-webkit-scrollbar{display:none}.skills__blocks.grabbing{cursor:grabbing}}@media (width>=769px){.skills__block{margin-bottom:0}}@media (width<=768px){.skills__block{scroll-snap-align:start;scroll-snap-stop:always;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#070d1abf;border:1px solid #38bdf81a;border-radius:4px;flex:0 0 85vw;padding:1.5rem}}.skills__block-title{letter-spacing:.2em;color:#fb923c;border-bottom:1px solid #fb923c26;margin-bottom:1rem;padding-bottom:.5rem;font-family:Space Mono,monospace;font-size:.6rem}.skills__row{flex-wrap:wrap;gap:.6rem;display:flex}.skills__pill{letter-spacing:.05em;color:#cbd5e1;cursor:default;background:#ffffff05;border:1px solid #cbd5e11a;border-radius:2px;padding:.4rem 1rem;font-family:Space Mono,monospace;font-size:.65rem;transition:all .2s}.skills__pill:hover{color:#38bdf8;background:#38bdf80f;border-color:#38bdf8;transform:translateY(-2px)}.skills__controls{align-items:center;gap:1rem;margin-top:1.25rem;display:flex}@media (width>=769px){.skills__controls{display:none}}.skills__dots{align-items:center;gap:.5rem;display:flex}.skills__dot{cursor:pointer;background:#64748b;border:none;border-radius:50%;width:4px;height:4px;padding:0;transition:all .25s}.skills__dot.active{background:#38bdf8;border-radius:2px;width:20px;box-shadow:0 0 8px #38bdf880}.skills__count{color:#64748b;letter-spacing:.1em;margin-left:auto;font-family:Space Mono,monospace;font-size:.6rem}.projects__tabs{border-bottom:1px solid #38bdf81a;gap:0;margin-bottom:1.5rem;display:flex}.projects__tab{letter-spacing:.15em;color:#94a3b8;cursor:pointer;background:0 0;border:none;padding:.65rem 1.5rem;font-family:Space Mono,monospace;font-size:.65rem;transition:color .2s;position:relative}.projects__tab:after{content:"";background:#38bdf8;height:2px;transition:transform .25s;position:absolute;bottom:-1px;left:0;right:0;transform:scaleX(0)}.projects__tab.active{color:#38bdf8}.projects__tab.active:after{transform:scaleX(1)}.projects__tab:hover{color:#cbd5e1}.projects__panel{display:none}.projects__panel.active{display:block}.projects__slider-wrap{position:relative}.projects__slider{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;cursor:grab;scrollbar-width:none;gap:1.25rem;padding-bottom:1.5rem;display:flex;overflow-x:auto}.projects__slider::-webkit-scrollbar{display:none}.projects__slider.grabbing{cursor:grabbing}.proj{scroll-snap-align:start;background:#070d1abf;border:1px solid #38bdf81a;border-radius:4px;flex-direction:column;flex:0 0 340px;padding:1.75rem;transition:border-color .25s,transform .25s;display:flex;position:relative;overflow:hidden}.proj:before{content:"";transform-origin:0;background:linear-gradient(90deg,#38bdf8,#818cf8);height:2px;transition:transform .3s;position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.proj:hover{border-color:#38bdf859;transform:translateY(-4px)}.proj:hover:before{transform:scaleX(1)}.proj__thumb{border-radius:2px;flex-shrink:0;width:100%;height:160px;margin-bottom:1.25rem;position:relative;overflow:hidden}.proj__thumb svg{width:100%;height:100%;display:block}.proj__thumb img{width:100%}.proj__num{color:#64748b;letter-spacing:.05em;margin-bottom:1rem;font-family:Space Mono,monospace;font-size:.6rem}.proj__title{color:#fff;margin-bottom:.5rem;font-family:Syne,sans-serif;font-size:1.05rem;font-weight:700}.proj__desc{color:#94a3b8;flex:1;margin-bottom:1rem;font-size:.83rem;line-height:1.7}.proj__tags{flex-wrap:wrap;gap:.4rem;margin-bottom:1.25rem;display:flex}.proj__tag{letter-spacing:.05em;color:#818cf8;background:#818cf81a;border:1px solid #818cf833;border-radius:2px;padding:.2rem .5rem;font-family:Space Mono,monospace;font-size:.55rem}.proj__links{gap:.75rem;margin-top:auto;display:flex}.proj__link{letter-spacing:.1em;color:#cbd5e1;border:1px solid #cbd5e133;border-radius:2px;align-items:center;gap:.35rem;padding:.3rem .75rem;font-family:Space Mono,monospace;font-size:.62rem;text-decoration:none;transition:all .2s;display:inline-flex}.proj__link:hover{color:#38bdf8;background:#38bdf80d;border-color:#38bdf873}.proj__link--live:hover{color:#fb923c;background:#fb923c0d;border-color:#fb923c73}.slider-controls{align-items:center;gap:1rem;margin-top:1.5rem;display:flex}.slider-btn{color:#94a3b8;cursor:pointer;background:0 0;border:1px solid #cbd5e126;border-radius:2px;justify-content:center;align-items:center;width:36px;height:36px;font-family:Space Mono,monospace;font-size:.8rem;transition:all .2s;display:flex}.slider-btn:hover{color:#38bdf8;background:#38bdf80f;border-color:#38bdf8}.slider-btn:disabled{opacity:.25;cursor:default;pointer-events:none}.slider-dots{align-items:center;gap:.5rem;display:flex}.slider-dot{cursor:pointer;background:#64748b;border:none;border-radius:50%;width:4px;height:4px;padding:0;transition:all .25s}.slider-dot.active{background:#38bdf8;border-radius:2px;width:20px;box-shadow:0 0 8px #38bdf880}.slider-count{color:#64748b;letter-spacing:.1em;margin-left:auto;font-family:Space Mono,monospace;font-size:.6rem}.timeline{padding-left:1.5rem;position:relative}.timeline:before{content:"";opacity:.25;background:linear-gradient(#38bdf8 0%,#0000 90%);width:1px;position:absolute;top:8px;bottom:0;left:0}@media (width>=769px){.timeline{grid-template-columns:1fr 1fr;gap:0 3rem;padding-left:0;display:grid}.timeline:before{display:none}}@media (width<=768px){.timeline{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;cursor:grab;gap:1rem;padding:0 0 1rem;display:flex;position:static;overflow-x:auto}.timeline::-webkit-scrollbar{display:none}.timeline.grabbing{cursor:grabbing}.timeline:before{display:none}}.tl__item{padding-bottom:2rem;position:relative}.tl__item:last-child{padding-bottom:0}.tl__item:before{content:"";background:#38bdf8;border-radius:50%;width:7px;height:7px;position:absolute;top:7px;left:-1.85rem;box-shadow:0 0 8px #38bdf899}@media (width>=769px){.tl__item{border-left:1px solid #38bdf826;padding-bottom:1.75rem;padding-left:1.25rem}.tl__item:before{left:-4px}}@media (width<=768px){.tl__item{scroll-snap-align:start;scroll-snap-stop:always;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#070d1abf;border:1px solid #38bdf81a;border-radius:4px;flex:0 0 85vw;padding:1.5rem;position:relative}.tl__item:before{display:none}.tl__item:after{content:"";background:linear-gradient(90deg,#38bdf8,#818cf8);border-radius:4px 4px 0 0;height:2px;position:absolute;top:0;left:0;right:0}}.tl__meta{flex-wrap:wrap;align-items:baseline;gap:1rem;margin-bottom:.25rem;display:flex}.tl__date{letter-spacing:.1em;color:#38bdf8;font-family:Space Mono,monospace;font-size:.6rem}.tl__location{letter-spacing:.05em;color:#fb923c;font-family:Space Mono,monospace;font-size:.6rem}.tl__company{color:#fff;margin-bottom:.25rem;font-family:Syne,sans-serif;font-size:1.05rem;font-weight:700}.tl__role{color:#cbd5e1;margin-bottom:.6rem;font-family:Space Mono,monospace;font-size:.85rem;font-weight:400}.tl__desc{color:#94a3b8;max-width:100%;font-size:.8rem;line-height:1.7}.tl-controls{align-items:center;gap:1rem;margin-top:1.25rem;display:flex}@media (width>=769px){.tl-controls{display:none}}.tl-dots{align-items:center;gap:.5rem;display:flex}.tl-dot{cursor:pointer;background:#64748b;border:none;border-radius:50%;width:4px;height:4px;padding:0;transition:all .25s}.tl-dot.active{background:#38bdf8;border-radius:2px;width:20px;box-shadow:0 0 8px #38bdf880}.tl-count{color:#64748b;letter-spacing:.1em;margin-left:auto;font-family:Space Mono,monospace;font-size:.6rem}.edu-certs-snap{scroll-snap-align:start;scroll-snap-stop:always;justify-content:center;align-items:center;width:100%;min-height:100vh;display:flex;overflow:hidden}@media (width<=768px){.edu-certs-snap{scroll-snap-align:none;min-height:auto;display:block}}.edu-certs-page{flex-direction:column;justify-content:center;gap:4rem;width:100%;max-width:1100px;padding:7rem clamp(1.5rem,5vw,3rem);display:flex}@media (width<=768px){.edu-certs-page{gap:0;max-width:100%;padding:0}}.edu-subsection,.edu-cert-subsection{width:100%}@media (width<=768px){.edu-subsection,.edu-cert-subsection{scroll-snap-align:start;scroll-snap-stop:always;flex-direction:column;justify-content:center;min-height:100vh;padding:5rem clamp(1.5rem,5vw,3rem);display:flex}}.edu__grid{background:#38bdf81a;border:1px solid #38bdf81a;border-radius:4px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1px;display:grid;overflow:hidden}.edu__card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#070d1abf;padding:1.75rem;transition:background .2s}.edu__card:hover{background:#38bdf80a}.edu__degree{color:#fff;margin-bottom:.35rem;font-family:Syne,sans-serif;font-size:.95rem;font-weight:700;line-height:1.35}.edu__field{letter-spacing:.08em;color:#818cf8;margin-bottom:.75rem;font-family:Space Mono,monospace;font-size:.58rem}.edu__uni{color:#cbd5e1;margin-bottom:.2rem;font-size:.83rem}.edu__loc{letter-spacing:.08em;color:#64748b;font-family:Space Mono,monospace;font-size:.58rem}.certs-list{background:#38bdf81a;border:1px solid #38bdf81a;border-radius:4px;flex-direction:column;gap:1px;display:flex;overflow:hidden}.cert__item{background:#070d1abf;grid-template-columns:1fr auto;align-items:center;gap:.5rem 2rem;padding:1.4rem 1.5rem;transition:background .2s;display:grid}.cert__item:hover{background:#38bdf80a}@media (width<=560px){.cert__item{grid-template-columns:1fr}}.cert__name{color:#fff;margin-bottom:.25rem;font-family:Syne,sans-serif;font-size:.95rem;font-weight:700}.cert__issuer{color:#94a3b8;font-size:.8rem}.cert__loc{color:#64748b;font-size:.75rem}.cert__year{color:#38bdf8;letter-spacing:.08em;white-space:nowrap;align-self:start;padding-top:.2rem;font-family:Space Mono,monospace;font-size:.65rem}.contact__wrap{text-align:center;max-width:620px;margin:0 auto}.contact__sub{color:#94a3b8;margin-bottom:3rem;font-size:.93rem;line-height:1.85}.contact__grid{flex-wrap:wrap;justify-content:center;gap:.75rem;margin-bottom:2.5rem;display:flex}.contact__link{letter-spacing:.1em;color:#cbd5e1;border:1px solid #cbd5e133;border-radius:3px;align-items:center;gap:.4rem;padding:.65rem 1.4rem;font-family:Space Mono,monospace;font-size:.65rem;text-decoration:none;transition:all .2s;display:flex}.contact__link:hover{color:#38bdf8;background:#38bdf80d;border-color:#38bdf880}
