*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{color:#fff;background:#000;height:100%;font-family:sans-serif}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ddfa4233;border-radius:2px}::-webkit-scrollbar-thumb:hover{background:#ddfa4266}*{scrollbar-width:thin;scrollbar-color:#ddfa4233 #0000}img,picture,video,canvas,svg{max-width:100%;display:block}input,button,textarea,select{font:inherit}a{color:inherit;text-decoration:none}main{padding:0}.font-yellow{color:#ddfa42}.bg-yellow{background-color:#ddfa42}.mouse-follower{--circle-size:30px;height:var(--circle-size);width:var(--circle-size);top:calc(var(--circle-size)/2*-1);left:calc(var(--circle-size)/2*-1);pointer-events:none;z-index:9999;border:1px solid #ddfa42;border-radius:50%;position:fixed}.project-carousel-section{background:#0a0a0a;padding:10vw 8vw;position:relative;overflow:hidden}@media (max-width:768px){.project-carousel-section{padding:15vw 5vw}}.project-carousel-section .section-title{letter-spacing:.2em;text-transform:uppercase;color:#ddfa42;align-items:center;gap:1rem;margin-bottom:4rem;font-size:.75rem;font-weight:500;display:flex}.project-carousel-section .section-title:after{content:"";background:#ffffff14;flex:1;max-width:100px;height:1px}.carousel-3d-wrapper{perspective:1200px;perspective-origin:50%;height:70vh;min-height:500px;max-height:800px;position:relative}@media (max-width:768px){.carousel-3d-wrapper{height:50vh;min-height:400px}}.carousel-3d-stage{transform-style:preserve-3d;width:100%;height:100%;position:absolute;top:50%;left:50%;transform:translate(-50%)translateY(-50%)}.plane-3d{width:420px;height:270px;transform-style:preserve-3d;cursor:pointer;will-change:transform;margin-top:-135px;margin-left:-210px;position:absolute;top:50%;left:50%}@media (max-width:1200px){.plane-3d{width:350px;height:225px;margin-top:-112px;margin-left:-175px}}@media (max-width:768px){.plane-3d{width:280px;height:180px;margin-top:-90px;margin-left:-140px}}.plane-content{width:100%;height:100%;transform-style:preserve-3d;border:1px solid;border-radius:12px;transition:box-shadow .4s;position:relative;overflow:hidden;box-shadow:0 30px 60px -15px #0009,0 0 0 1px #ffffff14}.plane-content:hover{box-shadow:0 40px 80px -20px #000000b3,0 0 0 1px #ffffff26}.plane-image{background-position:50%;background-repeat:no-repeat;background-size:cover;transition:transform .5s;position:absolute;inset:0}.plane-3d:hover .plane-image{transform:scale(1.05)}.plane-overlay{pointer-events:none;transition:opacity .4s;position:absolute;inset:0}.plane-3d:hover .plane-overlay{opacity:.8}.plane-glow{pointer-events:none;z-index:-1;border-radius:50%;transition:opacity .5s;position:absolute;inset:-80px}.plane-label{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);text-align:center;z-index:10000;min-width:160px;transform-style:preserve-3d;background:#000000f2;border:1px solid;border-radius:10px;padding:12px 18px;position:absolute;bottom:-55px;left:50%;transform:translate(-50%);box-shadow:0 20px 40px #00000080}.label-title{letter-spacing:-.02em;margin-bottom:3px;font-family:SF Mono,Fira Code,monospace;font-size:1rem;font-weight:600;display:block}.label-desc{color:#ffffff80;white-space:nowrap;font-size:.75rem;display:block}.background-grid{pointer-events:none;opacity:.6;background-image:linear-gradient(#ffffff04 1px,#0000 1px),linear-gradient(90deg,#ffffff04 1px,#0000 1px);background-size:50px 50px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(#000 20%,#0000 70%);mask-image:radial-gradient(#000 20%,#0000 70%)}@media (max-width:768px){.carousel-3d-wrapper{perspective:800px}.plane-label{min-width:140px;padding:10px 14px;bottom:-45px}.label-title{font-size:.9rem}.label-desc{font-size:.65rem}}
*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{color:#fff;background:#000;height:100%;font-family:sans-serif}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ddfa4233;border-radius:2px}::-webkit-scrollbar-thumb:hover{background:#ddfa4266}*{scrollbar-width:thin;scrollbar-color:#ddfa4233 #0000}img,picture,video,canvas,svg{max-width:100%;display:block}input,button,textarea,select{font:inherit}a{color:inherit;text-decoration:none}main{padding:0}.font-yellow{color:#ddfa42}.bg-yellow{background-color:#ddfa42}.mouse-follower{--circle-size:30px;height:var(--circle-size);width:var(--circle-size);top:calc(var(--circle-size)/2*-1);left:calc(var(--circle-size)/2*-1);pointer-events:none;z-index:9999;border:1px solid #ddfa42;border-radius:50%;position:fixed}:root{--ease-smooth:cubic-bezier(.25,.46,.45,.94);--ease-out-expo:cubic-bezier(.16,1,.3,1);--ease-micro:cubic-bezier(.25,.1,.25,1);--duration-micro:.18s;--duration-fast:.3s;--duration-normal:.5s}.resume{background:#0a0a0a;width:100%;position:relative;overflow-x:hidden}.cursor-glow{pointer-events:none;z-index:9999;isolation:isolate;background:radial-gradient(circle,#ddfa4214 0%,#0000 70%);border-radius:50%;width:400px;height:400px;position:fixed;transform:translate(-50%,-50%)}@media (max-width:768px){.cursor-glow{display:none}}.gradient-overlay{pointer-events:none;z-index:100;height:150px;position:fixed;left:0;right:0}.gradient-overlay.top{background:linear-gradient(#0a0a0a 0%,#0000 100%);top:0}.gradient-overlay.bottom{background:linear-gradient(#0000 0%,#0a0a0a 100%);bottom:0}.hero{flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:0 5vw;display:flex;position:relative}.hero-content{text-align:center;perspective:1000px;width:100%;max-width:800px}.hero-name{letter-spacing:-.04em;color:#fff;will-change:transform,opacity;margin-bottom:2rem;font-size:clamp(4rem,15vw,10rem);font-weight:600;line-height:1}.hero-tagline{color:#ffffff80;letter-spacing:.1em;text-transform:uppercase;margin-bottom:2.5rem;font-size:clamp(1rem,2vw,1.25rem);font-weight:400}.hero-contact{flex-wrap:wrap;justify-content:center;align-items:center;gap:1.25rem;display:flex}.hero-contact a{color:#ffffff80;letter-spacing:.02em;transition:color var(--duration-micro)var(--ease-micro),letter-spacing var(--duration-fast)var(--ease-out-expo);font-size:.875rem;position:relative}.hero-contact a:after{content:"";transform-origin:100%;width:100%;height:1px;transition:transform var(--duration-fast)var(--ease-out-expo);background:#ddfa42;position:absolute;bottom:-2px;left:0;transform:scaleX(0)}.hero-contact a:hover{color:#ddfa42;letter-spacing:.04em}.hero-contact a:hover:after{transform-origin:0;transform:scaleX(1)}.hero-contact a:active{transition:transform .1s var(--ease-micro);transform:scale(.98)}.hero-contact .divider{color:#ffffff4d;font-size:.75rem}.scroll-indicator{position:absolute;bottom:3rem;left:50%;transform:translate(-50%)}.scroll-line{transform-origin:top;background:linear-gradient(#ddfa42,#0000);width:1px;height:60px;transform:scaleY(.5)}section{padding:10vw 8vw;position:relative}@media (max-width:768px){section{padding:15vw 5vw}}.section-title{letter-spacing:.2em;text-transform:uppercase;color:#ddfa42;align-items:center;gap:1rem;margin-bottom:4rem;font-size:.75rem;font-weight:500;display:flex}.section-title:after{content:"";background:#ffffff14;flex:1;max-width:100px;height:1px}.about-content{color:#fff;word-break:keep-all;max-width:900px;font-size:clamp(1.5rem,3.5vw,2.5rem);font-weight:700;line-height:1.6}.about-word{transition:opacity .1s;display:inline}.competencies-grid{background:#ffffff14;grid-template-columns:repeat(2,1fr);gap:1px;display:grid}@media (max-width:768px){.competencies-grid{grid-template-columns:1fr}}.competency-card{transition:background var(--duration-fast)var(--ease-smooth),transform var(--duration-fast)var(--ease-out-expo),box-shadow var(--duration-fast)var(--ease-smooth);background:#0a0a0a;padding:3rem;position:relative}.competency-card:before{content:"";opacity:0;transition:opacity var(--duration-normal)var(--ease-smooth);background:linear-gradient(135deg,#ddfa4200 0%,#ddfa4208 100%);position:absolute;inset:0}.competency-card:hover{background:#ffffff05;transform:translateY(-4px)}.competency-card:hover:before{opacity:1}.competency-card:hover .card-index{color:#ddfa42;transform:translate(6px)}.competency-card:hover h3{color:#ddfa42;letter-spacing:.01em}.competency-card:hover p{color:#fff9}.competency-card:active{transition:transform .1s var(--ease-micro);transform:translateY(-2px)}.competency-card .card-index{color:#ffffff4d;letter-spacing:.1em;transition:color var(--duration-micro)var(--ease-micro),transform var(--duration-fast)var(--ease-out-expo);margin-bottom:1.5rem;font-size:.75rem;display:block}.competency-card h3{color:#fff;transition:color var(--duration-micro)var(--ease-micro),letter-spacing var(--duration-fast)var(--ease-out-expo);margin-bottom:1rem;font-size:1.25rem;font-weight:500}.competency-card p{color:#ffffff80;word-break:keep-all;transition:color var(--duration-fast)var(--ease-smooth);font-size:.95rem;line-height:1.7}.experience-item{max-width:900px}.experience-header{border-bottom:1px solid #ffffff14;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:2rem;padding-bottom:2rem;display:flex}.experience-company h3{color:#fff;margin-bottom:.5rem;font-size:clamp(1.75rem,4vw,2.5rem);font-weight:500}.experience-role{color:#ddfa42;font-size:1rem}.experience-period{color:#ffffff80;white-space:nowrap;font-size:.875rem}.experience-highlights{list-style:none}.experience-highlight{color:#ffffff80;word-break:keep-all;transition:color var(--duration-micro)var(--ease-micro),padding-left var(--duration-fast)var(--ease-out-expo),background var(--duration-fast)var(--ease-smooth);border-bottom:1px solid #ffffff14;padding:1rem 0 1rem 1.5rem;font-size:1rem;line-height:1.6;position:relative}.experience-highlight:last-child{border-bottom:none}.experience-highlight:before{content:"→";color:#ddfa42;opacity:.6;transition:transform var(--duration-fast)var(--ease-out-expo),opacity var(--duration-micro)var(--ease-micro);position:absolute;left:0}.experience-highlight:hover{color:#fff;background:#ddfa4205;padding-left:2rem}.experience-highlight:hover:before{opacity:1;transform:translate(6px)}.experience-highlight:active{background:#ddfa420a}.project-card{border-bottom:1px solid #ffffff14;margin-bottom:8rem;padding-bottom:8rem}.project-card:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.project-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:2rem;margin-bottom:4rem;display:flex}.project-name{color:#fff;letter-spacing:-.02em;margin-bottom:.75rem;font-size:clamp(2rem,5vw,3.5rem);font-weight:500}.project-description{color:#ffffff80;font-size:1rem}.project-meta{flex-direction:column;align-items:flex-end;gap:.5rem;display:flex}@media (max-width:768px){.project-meta{align-items:flex-start}}.project-period{color:#ffffff80;font-size:.875rem}.project-role{color:#ddfa42;border:1px solid #ddfa424d;border-radius:100px;padding:.5rem 1rem;font-size:.75rem}.project-content{grid-template-columns:repeat(2,1fr);gap:3rem;display:grid}@media (max-width:1024px){.project-content{grid-template-columns:1fr;gap:4rem}}.project-section h4{color:#ffffff4d;letter-spacing:.15em;text-transform:uppercase;margin-bottom:1.5rem;font-size:.75rem}.project-section p{color:#ffffff80;word-break:keep-all;font-size:1rem;line-height:1.7}.project-section ul{list-style:none}.project-section ul li{color:#ffffff80;word-break:keep-all;margin-bottom:.75rem;padding-left:1.25rem;font-size:1rem;line-height:1.6;position:relative}.project-section ul li:before{content:"·";color:#ddfa42;font-weight:700;position:absolute;left:0}.results-section{background:#ddfa4208;border:1px solid #ddfa421a;border-radius:8px;margin-top:3rem;padding:2.5rem}.results-section h4{color:#ddfa42;letter-spacing:.15em;text-transform:uppercase;margin-bottom:2rem;font-size:.75rem}.results-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1.5rem;display:grid}@media (max-width:768px){.results-grid{grid-template-columns:repeat(2,1fr)}}.result-item{text-align:left;transition:background var(--duration-fast)var(--ease-smooth),transform var(--duration-fast)var(--ease-out-expo);border-radius:4px;padding:1rem}.result-item:hover{background:#ddfa420d;transform:translateY(-3px)}.result-item:hover .result-value{text-shadow:0 0 20px #ddfa424d;transform:scale(1.03)}.result-item:hover .result-label{color:#ffffff80}.result-item:active{transition:transform .1s var(--ease-micro);transform:translateY(-1px)}.result-value{color:#ddfa42;letter-spacing:-.02em;font-variant-numeric:tabular-nums;transition:transform var(--duration-fast)var(--ease-out-expo),text-shadow var(--duration-normal)var(--ease-smooth);margin-bottom:.5rem;font-size:clamp(1.5rem,3vw,2rem);font-weight:500;display:block}.result-label{color:#ffffff4d;text-transform:uppercase;letter-spacing:.05em;font-size:.8rem}.troubleshooting{counter-reset:ts-step;border-top:1px solid #ffffff14;margin-top:4rem;padding-top:4rem}.troubleshooting h4{color:#ffffff4d;letter-spacing:.15em;text-transform:uppercase;margin-bottom:2.5rem;font-size:.75rem;font-weight:400}.troubleshooting-content{flex-direction:column;gap:0;display:flex;position:relative}.troubleshooting-content:before{content:"";background:linear-gradient(#ffffff14 0%,#ddfa424d 50%,#ffffff14 100%);width:1px;position:absolute;top:1.5rem;bottom:1.5rem;left:.5rem}@media (min-width:768px){.troubleshooting-content:before{left:.75rem}}.troubleshooting-item{counter-increment:ts-step;padding-bottom:2rem;padding-left:2.5rem;position:relative}@media (min-width:768px){.troubleshooting-item{padding-left:3rem}}.troubleshooting-item:last-child{padding-bottom:0}.troubleshooting-item:before{content:counter(ts-step);color:#ffffff4d;width:1.25rem;height:1.25rem;transition:all var(--duration-fast)var(--ease-smooth);background:#0a0a0a;border:1px solid #ffffff14;border-radius:50%;justify-content:center;align-items:center;font-size:.65rem;font-weight:500;display:flex;position:absolute;top:0;left:0}@media (min-width:768px){.troubleshooting-item:before{width:1.5rem;height:1.5rem;font-size:.7rem}}.troubleshooting-item:hover:before{color:#ddfa42;background:#ddfa420d;border-color:#ddfa42}.troubleshooting-item:hover .label{color:#ddfa42}.troubleshooting-item:hover p{color:#fff}.troubleshooting-item.active:before{color:#0a0a0a;background:#ddfa42;border-color:#ddfa42}.troubleshooting-item.active .label{color:#ddfa42}.troubleshooting-item.active p{color:#fff}.troubleshooting-item.read:before{color:#ddfa42cc;background:#ddfa421a;border-color:#ddfa4280}.troubleshooting-item.read .label{color:#ddfa4299}.troubleshooting-item.read p{color:#ffffff80}.troubleshooting-item .label{color:#ffffff4d;text-transform:uppercase;letter-spacing:.15em;transition:color var(--duration-fast)var(--ease-smooth);margin-bottom:.5rem;font-size:.65rem;font-weight:500;display:block}.troubleshooting-item p{color:#ffffff80;word-break:keep-all;transition:color var(--duration-fast)var(--ease-smooth);font-size:.9rem;line-height:1.7}.education-list{flex-direction:column;display:flex}.education-item{cursor:pointer;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:2rem 0;display:flex;position:relative}.education-item:first-child{padding-top:0}.education-item.hovered .education-info h3{color:#ddfa42}.education-underline-svg{width:100%;height:8px;position:absolute;bottom:0;left:0;overflow:visible}.education-item:last-child .education-underline-svg{display:none}.education-info h3{color:#fff;margin-bottom:.5rem;font-size:1.25rem;font-weight:500;transition:color .3s}.education-info p{color:#ffffff80;font-size:.95rem}.education-period{color:#ffffff4d;font-size:.875rem}.footer{text-align:center;border-top:1px solid #ffffff14;padding:8rem 8vw}.footer .footer-download-wrapper{display:inline-block}.footer .footer-download{color:#ddfa42;letter-spacing:.1em;background:#ddfa420d;border:1px solid #ddfa42;border-radius:50px;justify-content:center;align-items:center;min-width:140px;padding:1rem 2.5rem;font-size:clamp(1rem,2.5vw,1.25rem);font-weight:600;transition:background .5s cubic-bezier(.22,1,.36,1),color .5s cubic-bezier(.22,1,.36,1),box-shadow .5s cubic-bezier(.22,1,.36,1),min-width .5s cubic-bezier(.22,1,.36,1),padding .5s cubic-bezier(.22,1,.36,1);display:inline-flex;box-shadow:0 4px 20px #ddfa4226,0 8px 40px #ddfa421a}.footer .footer-download__text{width:60px;height:1.4em;line-height:1.4em;transition:width .5s cubic-bezier(.22,1,.36,1);display:block;position:relative;overflow:hidden}.footer .footer-download__default,.footer .footer-download__hover{text-align:center;white-space:nowrap;transition:transform .5s cubic-bezier(.22,1,.36,1),opacity .4s cubic-bezier(.22,1,.36,1);display:block}.footer .footer-download__default{opacity:1;transform:translate(0)}.footer .footer-download__hover{opacity:0;width:100%;position:absolute;top:0;left:0;transform:translate(-100%)}.footer .footer-download:hover{color:#000;background:#ddfa42;animation-play-state:paused;box-shadow:0 6px 30px #ddfa424d,0 12px 50px #ddfa4233}.footer .footer-download:hover .footer-download__text{width:140px}.footer .footer-download:hover .footer-download__default{opacity:0;transform:translate(100%)}.footer .footer-download:hover .footer-download__hover{opacity:1;transform:translate(0)}.footer .footer-download:active{transform:scale(.98)}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@media (max-width:768px){.experience-header,.project-header{flex-direction:column;align-items:flex-start}.project-meta{flex-direction:row;gap:1rem}.education-item{flex-direction:column;align-items:flex-start}.gradient-overlay{height:80px}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.cursor-glow{display:none}.scroll-line{animation:none}.about-word{opacity:1!important;filter:none!important;transform:none!important}}
