@import "https://fonts.googleapis.com/css2?family=Dancing+Script:wght@700&family=Outfit:wght@300;400;500;600;700&family=Playfair+Display:ital,wght@0,400;0,500;0,600;1,400;1,500&display=swap";*{box-sizing:border-box;margin:0;padding:0}html,body,*,:before,:after{cursor:none!important}html{scroll-behavior:smooth}body{overflow-x:hidden}::-webkit-scrollbar{background:0 0;width:0}*{scrollbar-width:none}@keyframes float{0%,to{opacity:.6;transform:translateY(0)translate(0)}33%{opacity:1;transform:translateY(-15px)translate(8px)}66%{opacity:.8;transform:translateY(-8px)translate(-5px)}}@keyframes floatSlow{0%,to{transform:translateY(0)translate(0)scale(1)}50%{transform:translateY(-20px)translate(10px)scale(1.02)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.95)}}@keyframes glow{0%,to{opacity:.6}50%{opacity:1}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes bobble{0%,to{transform:translateY(0)rotate(0)}25%{transform:translateY(-8px)rotate(1deg)}75%{transform:translateY(-4px)rotate(-1deg)}}@keyframes scrollBounce{0%,to{opacity:.4;transform:translateY(0)}50%{opacity:.9;transform:translateY(7px)}}@keyframes gradientShift{0%,to{transform:translate(0)scale(1)}33%{transform:translate(5%,-5%)scale(1.05)}66%{transform:translate(-3%,3%)scale(.98)}}@keyframes blobDrift1{0%{transform:translate(0)scale(1)}20%{transform:translate(-8%,12%)scale(1.06)}45%{transform:translate(10%,18%)scale(.95)}70%{transform:translate(6%,-10%)scale(1.08)}to{transform:translate(0)scale(1)}}@keyframes blobDrift2{0%{transform:translate(0)scale(1)}25%{transform:translate(12%,-14%)scale(1.05)}50%{transform:translate(-10%,-8%)scale(.93)}75%{transform:translate(-6%,16%)scale(1.07)}to{transform:translate(0)scale(1)}}.screen-too-small{z-index:9999;background:linear-gradient(#f5f0eb 0%,#ebe5df 40%,#e8e2dc 100%);justify-content:center;align-items:center;display:none;position:fixed;inset:0}.screen-too-small-inner{text-align:center;flex-direction:column;align-items:center;gap:16px;max-width:320px;padding:40px 32px;display:flex}.screen-too-small-icon{font-size:48px;line-height:1}.screen-too-small-title{color:#1a1a1ad9;margin:0;font-family:Playfair Display,serif;font-size:22px;font-style:italic;font-weight:500}.screen-too-small-sub{color:#1a1a1a80;margin:0;font-family:Outfit,sans-serif;font-size:15px;line-height:1.65}@media (width<=424px){.screen-too-small{display:flex}}@keyframes blobDrift3{0%{transform:translate(0)scale(1)}30%{transform:translate(14%,-12%)scale(1.08)}60%{transform:translate(8%,14%)scale(.94)}80%{transform:translate(-10%,6%)scale(1.04)}to{transform:translate(0)scale(1)}}.floating-particle{pointer-events:none;background:#fffc;border-radius:50%;animation:6s ease-in-out infinite float;position:absolute;box-shadow:0 0 20px #ffffff80}.app-container{color:#1a1a1a;min-height:100vh;font-family:Outfit,sans-serif;overflow-x:hidden}.cursor-ring{pointer-events:none;z-index:99999;will-change:transform;border:2.5px solid #1a1a1ab3;border-radius:50%;width:44px;height:44px;transition:border-color .4s;position:fixed;top:0;left:0;transform:translate(-50%,-50%)}.cursor-ring.on-dark{border-color:#ffffffbf}.cursor-dot{pointer-events:none;z-index:99999;will-change:transform;background:#1a1a1ab3;border-radius:50%;width:6px;height:6px;transition:background .4s;position:fixed;top:0;left:0;transform:translate(-50%,-50%)}.cursor-dot.on-dark{background:#ffffffbf}.nav{z-index:100;background:0 0;justify-content:space-between;align-items:center;padding:24px 48px;display:flex;position:fixed;top:0;left:0;right:0}.nav-logo{color:#1a1a1a;letter-spacing:0;font-family:Dancing Script,cursive;font-size:32px;font-weight:700;line-height:1}.nav-center{gap:52px;display:flex}.nav-link{cursor:pointer;color:#1a1a1a8c;background:0 0;border:none;border-bottom:1px solid #0000;padding-bottom:2px;font-family:Playfair Display,serif;font-size:20px;font-style:italic;font-weight:400;text-decoration:none;transition:color .3s,transform .25s,border-color .3s;display:inline-block}.nav-link:hover{color:#1a1a1a;transform:scale(1.1)}.nav-link--active{color:#1a1a1a;border-bottom-color:#1a1a1a80}.resume-button{color:#fff;transform-origin:50%;background:#1a1a1ae6;border:1.5px solid #0000;border-radius:100px;align-items:center;gap:8px;padding:14px 28px;font-size:16px;font-weight:500;text-decoration:none;transition:background .2s,border-color .2s,color .2s,transform .2s;display:flex}.resume-button:hover{color:#1a1a1a;background:#fff;border-color:#1a1a1a;transform:scale(1.06)}.button-arrow{font-size:14px}.nav-hamburger{cursor:pointer;background:0 0;border:none;flex-direction:column;justify-content:center;gap:5px;width:32px;height:32px;padding:4px;display:none}.nav-hamburger span{transform-origin:50%;background:#1a1a1abf;border-radius:2px;width:22px;height:2px;transition:transform .25s,opacity .25s;display:block}.nav-hamburger--open span:first-child{transform:translateY(7px)rotate(45deg)}.nav-hamburger--open span:nth-child(2){opacity:0}.nav-hamburger--open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.nav-mobile-menu{z-index:99;opacity:0;pointer-events:none;background:linear-gradient(#f5f0eb 0%,#ebe5df 60%,#e8e2dc 100%);flex-direction:column;justify-content:center;align-items:center;gap:12px;transition:opacity .25s;display:none;position:fixed;inset:0}.nav-mobile-menu--open{opacity:1;pointer-events:auto}.nav-mobile-link{color:#1a1a1a8c;cursor:pointer;background:0 0;border:none;padding:4px 0;font-family:Playfair Display,serif;font-size:32px;font-style:italic;font-weight:400;transition:color .2s}.nav-mobile-link:hover,.nav-mobile-link--active{color:#1a1a1ae6}.nav-mobile-resume{color:#1a1a1aa6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff8c;border:1px solid #1a1a1a24;border-radius:100px;align-items:center;gap:8px;margin-top:24px;padding:12px 28px;font-family:Outfit,sans-serif;font-size:15px;font-weight:500;text-decoration:none;transition:background .2s,border-color .2s,color .2s;display:inline-flex}.nav-mobile-resume:hover{color:#1a1a1ae6;background:#ffffffe0;border-color:#1a1a1a47}@media (width<=425px){.nav{padding:14px 20px}.nav-logo{font-size:22px}.nav-center,.resume-button{display:none}.nav-hamburger,.nav-mobile-menu{display:flex}}@media (width<=768px){.nav{padding:16px 20px}.nav-logo{font-size:24px}.nav-center{gap:20px}.nav-link{font-size:14px}.resume-button{padding:9px 16px;font-size:13px}}.hero-section{background:linear-gradient(#f5f0eb 0%,#ebe5df 40%,#e8e2dc 100%);position:fixed;inset:0;overflow:hidden}.hero-gradient-1{filter:blur(60px);background:radial-gradient(#fbbf9299 0%,#ffb47866 30%,#0000 60%);width:70%;height:80%;animation:14s ease-in-out infinite blobDrift1;position:absolute;top:-20%;right:-10%}.hero-gradient-2{filter:blur(80px);background:radial-gradient(#a8e6cf80 0%,#78c8b44d 30%,#0000 60%);width:60%;height:70%;animation:18s ease-in-out infinite blobDrift2;position:absolute;top:10%;left:20%}.hero-gradient-3{filter:blur(70px);background:radial-gradient(#c8b4dc4d 0%,#0000 50%);width:50%;height:50%;animation:11s ease-in-out infinite blobDrift3;position:absolute;bottom:0;left:-10%}.hero-vignette{pointer-events:none;background:radial-gradient(#0000 40%,#f5f0eb66 100%);position:absolute;inset:0}.hero-content{z-index:10;grid-template-columns:1fr 1fr;align-items:center;width:100%;height:calc(100vh - 80px);margin-top:75px;padding:80px 64px;display:grid;position:relative}.hero-meta{background:#4deeb31a;border:1px solid #4deeb34d;border-radius:100px;align-items:center;gap:10px;margin-bottom:24px;padding:8px 16px 8px 12px;display:inline-flex}.status-dot{background:#4deeb3;border-radius:50%;flex-shrink:0;width:8px;height:8px;animation:2s ease-in-out infinite pulse;box-shadow:0 0 10px #4deeb3b3}.status-text{color:#2a8a6e;letter-spacing:.2px;font-size:13px;font-weight:600}.hero-title{color:#1a1a1a;margin-bottom:24px;font-family:Playfair Display,serif;font-size:clamp(56px,9vw,100px);font-weight:500;line-height:1.05}.hero-title-light{color:#1a1a1a59}.hero-tagline{color:#1a1a1a99;max-width:440px;margin-bottom:40px;font-size:18px;line-height:1.7}.hero-highlight{color:#2a8a6e;font-weight:500}.hero-ctas{gap:16px;margin-bottom:60px;display:flex}.primary-btn{color:#fff;cursor:pointer;background:#1a1a1a;border:1.5px solid #0000;border-radius:100px;align-items:center;gap:10px;padding:16px 32px;font-family:Outfit,sans-serif;font-size:15px;font-weight:500;transition:all .2s;display:flex}.primary-btn:hover{color:#1a1a1a;background:#fff;border-color:#1a1a1a;font-size:16px}.secondary-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#1a1a1a;cursor:pointer;background:#fff9;border:1.5px solid #1a1a1a26;border-radius:100px;align-items:center;gap:10px;padding:16px 32px;font-family:Outfit,sans-serif;font-size:15px;font-weight:500;transition:all .2s;display:flex}.secondary-btn:hover{font-size:17px}.btn-arrow{font-size:16px}.hero-stats{align-items:center;gap:30px;margin-top:6rem;display:flex}.stat-item{flex-direction:column;gap:4px;display:flex}.stat-number{color:#1a1a1a;font-size:28px;font-weight:600}.stat-label{color:#1a1a1a80;font-size:13px;font-weight:500}.stat-infinity{color:#1a1a1a;font-family:Playfair Display,serif;font-size:34px;font-weight:700;line-height:1}.stat-divider{background:#1a1a1a26;width:1px;height:40px}.floating-labels{pointer-events:none;width:45%;height:100%;position:absolute;top:0;right:0}.tech-label{color:#1a1a1a80;align-items:center;gap:10px;font-size:13px;font-weight:500;animation:5s ease-in-out infinite bobble;display:flex;position:absolute}.tech-dot{background:#4deeb3cc;border-radius:50%;width:6px;height:6px;box-shadow:0 0 15px #4deeb366}.tech-line{background:linear-gradient(90deg,#1a1a1a33 0%,#0000 100%);width:40px;height:1px;margin-left:10px}.scroll-indicator{z-index:20;align-items:center;gap:16px;display:flex;position:absolute;bottom:80px;left:64px}.scroll-num{color:#1a1a1a66;letter-spacing:1px;font-size:12px;font-weight:500}.scroll-line{background:#1a1a1a33;width:60px;height:1px}.scroll-text{color:#1a1a1a66;font-size:12px;font-weight:500}.scroll-arrow-container{border:1px solid #1a1a1a33;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.scroll-arrow{color:#1a1a1a80;font-size:14px;animation:1.8s ease-in-out infinite scrollBounce}@media (width<=425px){.hero-content{padding:70px 18px 32px}.hero-title{font-size:clamp(36px,14vw,52px)}.hero-tagline{font-size:14px}.primary-btn,.secondary-btn{justify-content:center;width:100%;padding:11px 20px;font-size:13px}.hero-ctas{flex-direction:column}.hero-stats{gap:14px}.stat-number{font-size:20px}.stat-label{font-size:11px}.scroll-indicator{display:none}}@media (width<=768px){.hero-content{grid-template-columns:1fr;align-items:flex-start;height:auto;min-height:calc(100vh - 60px);padding:80px 24px 40px}.hero-title{font-size:clamp(44px,12vw,64px)}.hero-tagline{max-width:100%;font-size:16px}.hero-ctas{flex-wrap:wrap;gap:12px;margin-bottom:40px}.primary-btn,.secondary-btn{padding:13px 24px;font-size:14px}.hero-stats{flex-wrap:wrap;gap:20px;margin-top:2rem}.stat-number{font-size:22px}.floating-labels{display:none}.scroll-indicator{bottom:24px;left:24px}}.about-section{z-index:5;background:linear-gradient(#f5f0eb 0%,#ebe5df 40%,#e8e2dc 100%);flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0;overflow:hidden}.about-gradient-1{filter:blur(60px);pointer-events:none;background:radial-gradient(#fbbf9299 0%,#ffb47866 30%,#0000 60%);width:70%;height:80%;animation:14s ease-in-out infinite blobDrift1;position:absolute;top:-20%;right:-10%}.about-gradient-2{filter:blur(80px);pointer-events:none;background:radial-gradient(#a8e6cf80 0%,#78c8b44d 30%,#0000 60%);width:60%;height:70%;animation:18s ease-in-out infinite blobDrift2;position:absolute;top:10%;left:20%}.about-gradient-3{filter:blur(70px);pointer-events:none;background:radial-gradient(#c8b4dc4d 0%,#0000 50%);width:50%;height:50%;animation:11s ease-in-out infinite blobDrift3;position:absolute;bottom:0;left:-10%}.about-vignette{pointer-events:none;background:radial-gradient(#0000 40%,#f5f0eb66 100%);position:absolute;inset:0}.about-inner{z-index:1;align-items:center;gap:160px;width:100%;max-width:1200px;margin-top:-5rem;padding:0 80px;display:flex;position:relative}.about-left{flex-direction:column;flex-shrink:0;align-items:center;gap:20px;width:280px;display:flex}.about-photo{object-fit:cover;border:2px solid #0000001a;border-radius:50%;width:260px;height:260px;box-shadow:0 4px 32px #00000024}.about-name{color:#000000a6;text-align:center;letter-spacing:.02em;margin:0;font-family:Outfit,sans-serif;font-size:18px}.about-socials{align-items:center;gap:18px;display:flex}.about-social-link{color:#00000059;align-items:center;transition:color .2s;display:flex}.about-social-link svg{width:22px;height:22px}.about-social-link:hover{color:#000c}.about-right{flex-direction:column;flex:1;gap:24px;display:flex}.about-heading{color:#000000d1;margin:0 0 10px;font-family:Playfair Display,serif;font-size:clamp(1.8rem,3vw,2.6rem);font-weight:400;line-height:1.2}.about-heading em{color:#2d9a6e;font-style:italic}.about-bio{color:#00000080;margin:0;font-family:Outfit,sans-serif;font-size:18px;line-height:1.75}.about-highlight{color:#000000bf;font-weight:500}.about-skills-wrapper{z-index:1;flex-direction:column;align-items:center;gap:10px;display:flex;position:absolute;bottom:28px;left:0;right:0}.about-skills-row{scrollbar-width:none;box-sizing:border-box;-webkit-user-select:none;user-select:none;gap:10px;width:100%;padding:4px 80px;display:flex;overflow-x:auto;-webkit-mask-image:linear-gradient(90deg,#0000 0%,#000 6% 94%,#0000 100%);mask-image:linear-gradient(90deg,#0000 0%,#000 6% 94%,#0000 100%)}.skills-scroll-hint{letter-spacing:.14em;color:#00000047;-webkit-user-select:none;user-select:none;pointer-events:none;align-items:center;gap:4px;margin:0;font-family:Outfit,sans-serif;font-size:12px;display:flex}.hint-arrows{gap:1px;display:inline-flex}.hint-chevron{opacity:.12;animation:1.8s ease-in-out infinite chevronPulse}@keyframes chevronPulse{0%,55%,to{opacity:.12}28%{opacity:.75}}.about-skills-row::-webkit-scrollbar{display:none}.about-skill-box{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:default;background:#ffffff80;border:1px solid #1a1a1a14;border-radius:16px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:8px;width:96px;height:84px;transition:background .2s,border-color .2s,box-shadow .2s;display:flex}.about-skill-box:hover{background:#ffffffeb;border-color:#1a1a1a24;box-shadow:0 4px 16px #0000000f}.about-skill-name{color:#1a1a1a8c;text-align:center;font-family:Outfit,sans-serif;font-size:11px;font-weight:500;line-height:1.2}@media (width<=425px){.about-section{justify-content:flex-start;overflow-y:auto}.about-inner{align-items:center;gap:20px;width:100%;margin-top:0;padding:80px 18px 160px}.about-photo{width:120px;height:120px}.about-heading{font-size:clamp(1.4rem,6.5vw,1.9rem)}.about-bio{font-size:14px;line-height:1.65}.about-skill-box{width:72px;height:64px}.about-skills-row{padding:4px 18px}}@media (width<=768px){.about-inner{flex-direction:column-reverse;align-items:center;gap:32px;margin-top:0;padding:0 24px}.about-left{width:auto}.about-photo{width:160px;height:160px}.about-right{gap:16px}.about-heading{margin-bottom:4px;font-size:clamp(1.8rem,6vw,2.4rem)}.about-bio{font-size:15px}.about-skills-wrapper{bottom:16px}.about-skills-row{padding:4px 24px}.about-skill-box{width:80px;height:72px}}.exp-section{z-index:6;background:linear-gradient(#f5f0eb 0%,#ebe5df 40%,#e8e2dc 100%);flex-direction:column;display:flex;position:fixed;inset:0;overflow:hidden}.exp-gradient-1{filter:blur(60px);pointer-events:none;background:radial-gradient(#fbbf9299 0%,#ffb47866 30%,#0000 60%);width:70%;height:80%;animation:14s ease-in-out infinite blobDrift1;position:absolute;top:-20%;right:-10%}.exp-gradient-2{filter:blur(80px);pointer-events:none;background:radial-gradient(#a8e6cf80 0%,#78c8b44d 30%,#0000 60%);width:60%;height:70%;animation:18s ease-in-out infinite blobDrift2;position:absolute;top:10%;left:20%}.exp-gradient-3{filter:blur(70px);pointer-events:none;background:radial-gradient(#c8b4dc4d 0%,#0000 50%);width:50%;height:50%;animation:11s ease-in-out infinite blobDrift3;position:absolute;bottom:0;left:-10%}.exp-vignette{pointer-events:none;background:radial-gradient(#0000 40%,#f5f0eb66 100%);position:absolute;inset:0}.exp-scroll{z-index:1;scrollbar-width:thin;scrollbar-color:#1a1a1a2e transparent;flex:1;padding:130px 96px 80px;position:relative;overflow-y:auto;-webkit-mask-image:linear-gradient(#0000 0 72px,#000 120px 100%);mask-image:linear-gradient(#0000 0 72px,#000 120px 100%)}.exp-scroll::-webkit-scrollbar{width:5px}.exp-scroll::-webkit-scrollbar-track{background:0 0}.exp-scroll::-webkit-scrollbar-thumb{background:#1a1a1a2e;border-radius:99px}.exp-inner{flex-direction:column;width:100%;display:flex;position:relative}.exp-heading{color:#1a1a1ad1;letter-spacing:-.02em;margin:0 0 48px;font-family:Playfair Display,serif;font-size:clamp(2rem,3.5vw,3rem);font-style:italic;font-weight:400;line-height:1.1}.exp-list{flex-direction:column;gap:56px;display:flex}.exp-entry{grid-template-columns:32px 1fr;align-items:start;column-gap:24px;display:grid}.exp-bullet{background:#1a1a1a40;border-radius:50%;flex-shrink:0;width:9px;height:9px;margin-top:10px;transition:background .3s}.exp-entry:hover .exp-bullet{background:#2a8a6e}.exp-body{flex-direction:column;gap:6px;display:flex}.exp-role-row{justify-content:space-between;align-items:baseline;gap:24px;display:flex}.exp-role{color:#1a1a1ae0;margin:0;font-family:Playfair Display,serif;font-size:clamp(1.15rem,1.8vw,1.45rem);font-weight:500;line-height:1.2}.exp-company{color:#2a8a6e;letter-spacing:.01em;margin:0;font-family:Outfit,sans-serif;font-size:18px;font-weight:500}.exp-points{flex-direction:column;gap:10px;margin:10px 0 0;padding:0;list-style:none;display:flex}.exp-point{color:#1a1a1a85;padding-left:18px;font-family:Outfit,sans-serif;font-size:16px;line-height:1.7;position:relative}.exp-point:before{content:"";background:#1a1a1a40;border-radius:1px;width:4px;height:4px;position:absolute;top:9px;left:0}.exp-main{align-items:flex-start;gap:96px;margin-top:4px;display:flex}.exp-stack{flex-wrap:wrap;flex-shrink:0;align-content:flex-start;gap:10px;width:280px;padding-top:2px;display:flex}.exp-stack-chip{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#1a1a1a8c;white-space:normal;text-align:center;background:#ffffff8c;border:1px solid #1a1a1a14;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:7px;width:78px;height:70px;font-family:Outfit,sans-serif;font-size:11px;font-weight:500;line-height:1.2;transition:background .2s,border-color .2s;animation:ease-in-out infinite bobble;display:flex}.exp-stack-chip:hover{background:#ffffffe0;border-color:#1a1a1a29}.exp-date{color:#1a1a1a66;letter-spacing:.8px;white-space:nowrap;flex-shrink:0;font-family:Outfit,sans-serif;font-size:15px;font-weight:400}.exp-divider{background:#1a1a1a14;grid-column:2/3;height:1px;margin:0}@media (width<=425px){.exp-scroll{padding:100px 18px 48px}.exp-heading{margin-bottom:24px;font-size:clamp(1.4rem,7vw,1.8rem)}.exp-entry{grid-template-columns:18px 1fr;column-gap:10px}.exp-role{font-size:clamp(1rem,4vw,1.2rem)}.exp-company{font-size:15px}.exp-point{font-size:14px}.exp-stack-chip{width:62px;height:56px;font-size:10px}}@media (width<=768px){.exp-scroll{padding:110px 24px 60px}.exp-heading{margin-bottom:32px;font-size:clamp(1.6rem,6vw,2.2rem)}.exp-list{gap:40px}.exp-entry{grid-template-columns:24px 1fr;column-gap:14px}.exp-role-row{flex-direction:column;gap:4px}.exp-date{font-size:13px}.exp-main{flex-direction:column;gap:24px}.exp-stack{width:100%}.exp-stack-chip{width:70px;height:62px}}.projects-section{z-index:8;background:linear-gradient(#f5f0eb 0%,#ebe5df 40%,#e8e2dc 100%);position:fixed;inset:0;overflow:hidden}.proj-blob-1{filter:blur(60px);pointer-events:none;background:radial-gradient(#fbbf9299 0%,#ffb47866 30%,#0000 60%);width:70%;height:80%;animation:14s ease-in-out infinite blobDrift1;position:absolute;top:-20%;right:-10%}.proj-blob-2{filter:blur(80px);pointer-events:none;background:radial-gradient(#a8e6cf80 0%,#78c8b44d 30%,#0000 60%);width:60%;height:70%;animation:18s ease-in-out infinite blobDrift2;position:absolute;top:10%;left:20%}.proj-blob-3{filter:blur(70px);pointer-events:none;background:radial-gradient(#c8b4dc4d 0%,#0000 50%);width:50%;height:50%;animation:11s ease-in-out infinite blobDrift3;position:absolute;bottom:0;left:-10%}.proj-vignette{pointer-events:none;background:radial-gradient(#0000 40%,#f5f0eb66 100%);position:absolute;inset:0}.proj-scroll{z-index:1;scroll-snap-type:y mandatory;scrollbar-width:none;height:100%;position:relative;overflow-y:scroll}.proj-scroll::-webkit-scrollbar{display:none}.proj-slide{scroll-snap-align:start;box-sizing:border-box;align-items:center;gap:80px;height:100vh;padding:80px 80px 40px;display:flex}.proj-text{flex-direction:column;flex:1;gap:18px;display:flex}.proj-meta{align-items:center;gap:20px;display:flex}.proj-counter{letter-spacing:2px;font-family:Outfit,sans-serif;font-size:12px}.proj-counter-current{color:#1a1a1abf;font-size:16px;font-weight:700}.proj-counter-total{color:#1a1a1a47;font-size:12px;font-weight:400}.proj-label{letter-spacing:2.5px;text-transform:uppercase;color:#1a1a1a73;font-family:Outfit,sans-serif;font-size:13px;font-weight:700}.proj-name{color:#1a1a1ae0;margin:0;font-family:Playfair Display,serif;font-size:clamp(36px,5vw,62px);font-weight:500;line-height:1.1}.proj-tagline{color:#1a1a1a80;max-width:420px;margin:0;font-family:Outfit,sans-serif;font-size:17px;line-height:1.75}.proj-stack{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.proj-stack-chip{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#1a1a1a8c;white-space:nowrap;background:#ffffff8c;border:1px solid #1a1a1a14;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:7px;width:78px;height:70px;font-family:Outfit,sans-serif;font-size:11px;font-weight:500;transition:background .2s,border-color .2s;display:flex}.proj-stack-chip:hover{background:#ffffffe0;border-color:#1a1a1a29}.proj-link{color:#1a1a1aa6;border-bottom:1px solid #1a1a1a33;align-items:center;gap:6px;width:fit-content;margin-top:10px;padding-bottom:2px;font-family:Outfit,sans-serif;font-size:14px;font-weight:600;text-decoration:none;transition:color .2s,border-color .2s;display:inline-flex}.proj-link:hover{color:#1a1a1ae6;border-color:#1a1a1a8c}.proj-visual{border-radius:24px;flex-shrink:0;width:460px;height:400px;position:relative;overflow:hidden;box-shadow:0 24px 80px #00000029}.proj-visual-img{object-fit:cover;object-position:top left;opacity:1;z-index:0;width:100%;height:100%;position:absolute;inset:0}.proj-visual-glow{filter:blur(60px);position:absolute;inset:-20%}.proj-visual-grid{background-image:linear-gradient(#ffffff0a 1px,#0000 1px),linear-gradient(90deg,#ffffff0a 1px,#0000 1px);background-size:28px 28px;position:absolute;inset:0}.proj-visual-num{color:#ffffff12;-webkit-user-select:none;user-select:none;pointer-events:none;letter-spacing:-6px;font-family:Playfair Display,serif;font-size:clamp(120px,18vw,200px);font-weight:700;line-height:1;position:absolute;top:-16px;left:8px}.proj-dots{z-index:10;flex-direction:column;gap:10px;display:flex;position:absolute;top:50%;right:32px;transform:translateY(-50%)}.proj-dot{cursor:pointer;background:#1a1a1a33;border:none;border-radius:50%;width:6px;height:6px;padding:0;transition:background .25s,transform .25s}.proj-dot--active{background:#1a1a1aa6;transform:scale(1.5)}@media (width<=425px){.proj-slide{gap:24px;padding:70px 18px 32px}.proj-name{font-size:clamp(24px,9vw,36px)}.proj-tagline{font-size:14px}.proj-visual{height:160px}.proj-stack-chip{width:60px;height:54px;font-size:10px}.proj-dots{right:10px}}@media (width<=768px){.proj-slide{flex-direction:column;justify-content:center;align-items:flex-start;gap:32px;padding:80px 24px 40px}.proj-name{font-size:clamp(28px,8vw,44px)}.proj-tagline{max-width:100%;font-size:15px}.proj-visual{width:100%;height:200px}.proj-stack-chip{width:68px;height:60px;font-size:10px}.proj-dots{right:16px}.proj-visual-num{font-size:clamp(80px,22vw,140px)}}.contact-section{z-index:5;background:linear-gradient(#f5f0eb 0%,#ebe5df 40%,#e8e2dc 100%);flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0;overflow:hidden}.contact-gradient-1{filter:blur(60px);pointer-events:none;background:radial-gradient(#fbbf9299 0%,#ffb47866 30%,#0000 60%);width:70%;height:80%;animation:14s ease-in-out infinite blobDrift1;position:absolute;top:-20%;right:-10%}.contact-gradient-2{filter:blur(80px);pointer-events:none;background:radial-gradient(#a8e6cf80 0%,#78c8b44d 30%,#0000 60%);width:60%;height:70%;animation:18s ease-in-out infinite blobDrift2;position:absolute;top:10%;left:20%}.contact-gradient-3{filter:blur(70px);pointer-events:none;background:radial-gradient(#c8b4dc4d 0%,#0000 50%);width:50%;height:50%;animation:11s ease-in-out infinite blobDrift3;position:absolute;bottom:0;left:-10%}.contact-vignette{pointer-events:none;background:radial-gradient(#0000 40%,#f5f0eb66 100%);position:absolute;inset:0}.contact-inner{z-index:1;text-align:center;flex-direction:column;align-items:center;gap:32px;display:flex;position:relative}.contact-eyebrow{letter-spacing:.22em;text-transform:uppercase;color:#00000059;margin:0;font-family:Outfit,sans-serif;font-size:13px;font-weight:500}.contact-heading{color:#000000d9;letter-spacing:-.01em;margin:0;font-family:Playfair Display,serif;font-size:clamp(3.5rem,7vw,6rem);font-weight:400;line-height:1.1}.contact-email{color:#8b6446bf;letter-spacing:-.01em;border-bottom:1px solid #8b644640;padding-bottom:4px;font-family:Outfit,sans-serif;font-size:clamp(1.1rem,2.2vw,1.55rem);font-weight:400;text-decoration:none;transition:color .2s,border-color .2s}.contact-email:hover{color:#8b6446;border-color:#8b644699}.contact-links{align-items:center;gap:40px;margin-top:8px;display:flex}.contact-link{color:#00000073;letter-spacing:.01em;align-items:center;gap:8px;font-family:Outfit,sans-serif;font-size:17px;font-weight:400;text-decoration:none;transition:color .2s;display:flex}.contact-link:hover{color:#000c}.contact-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.contact-dot--linkedin{background:#fbbf92e6}.contact-dot--github{background:#a8d2bee6}
