@import"https://fonts.googleapis.com/css2?family=Inter:wght@100..900&display=swap";*{margin:0;padding:0;box-sizing:border-box}:root{--ring-size: clamp(260px, 52vw, 350px);--bubble-ratio: .72;--bubble-size: calc(var(--ring-size) * var(--bubble-ratio));--circle-size: calc(var(--bubble-size) * .6);--circle-offset: calc((var(--bubble-size) - var(--circle-size)) / 2);--ring-speed: 20s;--bg: #0B1012}.intro-container{display:flex;justify-content:center;align-items:center;min-height:100svh;width:100%;background-color:var(--bg);overflow:hidden;padding:0 1rem}.intro-title{font-size:8rem;word-break:break-word;font-weight:700;letter-spacing:-8px;color:#fff;text-align:center;margin:0;font-family:Inter,sans-serif;position:relative;display:inline-block}.intro-letter{display:inline-block;position:relative}.moving-dot{position:absolute;top:0;left:0;font-weight:700;font-family:inherit;line-height:1;pointer-events:none;transition:transform .4s ease;opacity:1;will-change:transform}.final-period{visibility:hidden}.final-period.visible{visibility:visible}.bubble{position:absolute;top:50%;left:50%;width:var(--ring-size);height:var(--ring-size);transform:translate(-50%,-50%);z-index:10}.bubble-delayed{opacity:0;transform:translate(-50%,-50%) scale(.9);transition:opacity .8s ease,transform .8s cubic-bezier(.25,.9,.35,1)}.bubble-delayed.visible{opacity:1;transform:translate(-50%,-50%) scale(1)}.bubble-circle{position:absolute;overflow:hidden;top:calc((var(--ring-size) - var(--bubble-size)) / 2);left:calc((var(--ring-size) - var(--bubble-size)) / 2);width:var(--bubble-size);height:var(--bubble-size);border:2px solid white;border-radius:50%;transition:all .3s ease}.bubble-image{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:1;clip-path:circle(0px at 50% 50%);transition:clip-path .6s ease-out;will-change:clip-path;pointer-events:auto;filter:grayscale(100%)}.bubble-circle:hover .bubble-image{clip-path:circle(50% at 50% 50%)}.bubble-image.reversing{transition:clip-path .45s ease-in}.rotating-text{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;animation:rotate var(--ring-speed) linear infinite}.circle-text{font-family:Inter,sans-serif;font-size:clamp(10px,1.25vw,14px);font-weight:800;fill:#dbdbdb;letter-spacing:clamp(7px,1.1vw,11px)}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: reduce){.rotating-text{animation:none}}@media (max-width: 1024px){.circle-text,.ring-text{font-size:clamp(9px,3.2vw,11px);letter-spacing:clamp(5px,1.8vw,9px)}:root{--bubble-ratio: .6;--circle-size: calc(var(--bubble-size) * .52);--circle-offset: calc((var(--bubble-size) - var(--circle-size)) / 2)}.intro-title{font-size:clamp(2.6rem,11vw,7rem);letter-spacing:-6px}}@media (max-width: 768px){.circle-text,.ring-text{font-size:clamp(9px,3.2vw,11px);letter-spacing:clamp(5px,1.8vw,9px)}:root{--bubble-ratio: .52;--circle-size: calc(var(--bubble-size) * .44);--circle-offset: calc((var(--bubble-size) - var(--circle-size)) / 2)}.intro-title{font-size:clamp(2.2rem,10.5vw,4.4rem);letter-spacing:-3px}}@media (max-width: 480px){.circle-text,.ring-text{font-size:clamp(9px,3.2vw,11px);letter-spacing:clamp(5px,1.8vw,9px)}.intro-title{font-size:clamp(2rem,12vw,3.6rem);letter-spacing:-2px}}@media (hover: none),(pointer: coarse){.bubble-image{clip-path:circle(75% at 50% 50%)!important;filter:grayscale(100%);transition:none}.bubble-circle:hover .bubble-image{clip-path:circle(80% at 50% 50%)}}.page-transition-overlay{position:fixed;inset:0;background:var(--bg);opacity:0;transition:opacity .5s ease;pointer-events:none;z-index:9999}.page-transition-overlay.active{opacity:1;pointer-events:all}.intro-container .bubble,.intro-container .rotating-text{transition:opacity .4s ease,transform .5s ease}.page-transition-overlay.active~.bubble{opacity:.5;transform:translate(-50%,-50%) scale(.98)}.intro-title .char{display:inline-block;opacity:0;animation-duration:.9375s;animation-fill-mode:forwards;animation-timing-function:cubic-bezier(.25,.9,.35,1);will-change:transform,opacity,filter;backface-visibility:hidden}.intro-title .variant-fade{animation-name:at-fadeUp;transform:translateY(20px)}.intro-title .variant-rotate{animation-name:at-rotateIn;transform:translateY(25px) rotate(15deg)}.intro-title .variant-scale{animation-name:at-scaleIn;transform:scale(.4) translateY(10px)}.intro-title .variant-blur{animation-name:at-blurIn;filter:blur(6px);transform:translateY(30px)}.intro-title .variant-flip{animation-name:at-flipIn;transform:rotateX(90deg) translateY(10px);transform-origin:50% 60%;perspective:800px}.intro-title .char.space{white-space:pre}@keyframes at-fadeUp{0%{opacity:0;transform:translateY(20px)}60%{opacity:1}to{opacity:1;transform:translateY(0)}}@keyframes at-rotateIn{0%{opacity:0;transform:translateY(25px) rotate(15deg)}70%{opacity:1}to{opacity:1;transform:translateY(0) rotate(0)}}@keyframes at-scaleIn{0%{opacity:0;transform:scale(.4) translateY(10px)}55%{opacity:1}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes at-blurIn{0%{opacity:0;filter:blur(6px);transform:translateY(30px)}60%{opacity:1}to{opacity:1;filter:blur(0);transform:translateY(0)}}@keyframes at-flipIn{0%{opacity:0;transform:rotateX(90deg) translateY(10px)}60%{opacity:1}to{opacity:1;transform:rotateX(0) translateY(0)}}.intro-title.skip-anim .char{animation:none!important;opacity:1!important;transform:none!important;filter:none!important}.intro-title.skip-anim .variant-flip{transform-origin:50% 60%!important;perspective:none!important}.navbar{top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:1.15rem 1.725rem;background:#0b1012;color:#f5f5f5;font-family:Segoe UI,Fira Sans,Roboto,Oxygen,Ubuntu,Cantarell,Droid Sans,Helvetica Neue,Arial,sans-serif;font-size:1.08rem;font-weight:500;letter-spacing:.01em;box-shadow:0 2px 6px #00000059;position:sticky}.scroll-progress{position:absolute;top:0;left:0;right:0;height:4px;z-index:2;pointer-events:none;background:linear-gradient(90deg,#8fd6b326,#8fd6b30d);border-radius:0 0 2px 2px;overflow:hidden}.scroll-progress__bar{height:100%;width:0%;background:linear-gradient(90deg,#5ea88e90,#8fd6b290,#baf2db90);box-shadow:0 0 8px #8fd6b399;transition:width .1s linear;border-radius:inherit}.nav-left{display:flex;align-items:center}.nav-left .logo{height:25px;width:auto;display:block;object-fit:contain}.nav-links{list-style:none;display:flex;gap:5.25rem;padding:0;margin:0 0 0 300px}.nav-links a{color:#ddd;text-decoration:none;font-size:1.1rem;transition:color .2s;font-family:inherit;font-weight:500;letter-spacing:.02em}.nav-links a:hover{color:#fff}.resume-btn{background:none;border:rgb(255,255,255) 1.2px solid;color:#fff;padding:.63rem 1.73rem;margin-right:20px;border-radius:16px;cursor:pointer;font-size:.85rem;font-weight:600;letter-spacing:.03em;transition:transform .15s,box-shadow .15s}.resume-btn:hover{transform:translateY(-2px)}.resume-btn:active{transform:translateY(0)}.section-block{min-height:60vh;padding:4rem 1.5rem 2rem;max-width:900px;margin:0 auto;color:#222;font-family:inherit;font-weight:400;letter-spacing:.01em}.decode{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;letter-spacing:.02em;display:inline-block;white-space:pre}.nav-links a:hover .decode{color:#fff}@media (prefers-reduced-motion: reduce){.decode{transition:none!important}}@media (max-width: 680px){.nav-links{gap:1rem}.resume-btn{padding:.5rem .9rem}}.burger{display:none;background:none;border:none;flex-direction:column;justify-content:center;align-items:center;width:38px;height:38px;cursor:pointer;z-index:200;padding:0;transition:right .2s}.burger-bar{width:26px;height:3px;background:#fff;margin:3px 0;border-radius:2px;transition:all .3s ease-in-out;display:block;transform-origin:center}.burger.open .burger-bar:nth-child(1){transform:rotate(45deg) translate(6px,6px)}.burger.open .burger-bar:nth-child(2){opacity:0;transform:scaleX(0)}.burger.open .burger-bar:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}.nav-overlay{position:fixed;inset:0;background:#00000059;z-index:110;animation:fadeIn .3s ease-out}.nav-overlay.closing{animation:fadeOut .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@media (max-width: 680px){.nav-links{position:fixed;top:0;right:0;height:100vh;width:70vw;max-width:270px;background:#0b1012;box-shadow:-2px 0 16px #00000040;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:2.5rem;padding:5.5rem 2.2rem 2rem;margin:0;transform:translate(100%);transition:transform .35s cubic-bezier(.25,.46,.45,.94);z-index:130;opacity:1;pointer-events:none;visibility:hidden}.nav-links.open{transform:translate(0);pointer-events:auto;visibility:visible}.nav-links li{width:100%}.nav-links a{font-size:1.25rem;width:100%;display:block;padding:.5rem 0}.burger{display:flex;position:fixed;top:18px;right:18px;margin:0;z-index:200}.resume-btn{display:none}.nav-left{z-index:140}}@media (max-width: 680px){.nav-links{gap:0}}.intro-role{--flip-font-size: 3.2rem;--flip-height: 4.2rem;--flip-pad-v: .5rem;--flip-pad-h: 1rem;display:inline-flex;align-items:center;flex-wrap:nowrap;white-space:nowrap}.iam-label{display:inline-block;font-weight:300;font-size:2.8rem;line-height:var(--flip-height);color:#fff;margin-right:1.2rem;font-family:Inter,sans-serif;position:relative;z-index:2}.flip-card-wrap{--flip-font-size: 3.2rem;--flip-height: 4.2rem;--flip-pad-v: .5rem;--flip-pad-h: 1rem;display:inline-block;position:relative;height:var(--flip-height);white-space:nowrap;perspective:1000px;overflow:visible;vertical-align:middle;z-index:1}.flip-width-ghost{visibility:hidden;pointer-events:none;display:inline-block;padding:var(--flip-pad-v) var(--flip-pad-h);font-weight:600;font-size:var(--flip-font-size);white-space:nowrap;box-sizing:border-box}.flip-width-measure{position:absolute;top:0;left:0}.flip-card{display:inline-block;position:absolute;top:0;left:0;height:var(--flip-height);transform-style:preserve-3d;background:#8fd6b3;border-radius:8px;padding:var(--flip-pad-v) var(--flip-pad-h);box-sizing:border-box;transition:transform .6s ease,width .6s ease}.flip-sizer{visibility:hidden;pointer-events:none;white-space:nowrap}.flip-face{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:transparent;color:#000;font-weight:600;font-size:var(--flip-font-size);backface-visibility:hidden}.front{transform:rotateX(0)}.back{transform:rotateX(180deg)}@media (max-width: 900px){.intro-role{--flip-font-size: 2.1rem;--flip-height: 2.8rem;font-size:1.1rem}.iam-label{font-size:2.1rem;line-height:2.8rem;margin-right:.8rem}.flip-card-wrap{--flip-font-size: 2.1rem;--flip-height: 2.8rem}}@media (max-width: 600px){.intro-role{--flip-font-size: 1.2rem;--flip-height: 1.7rem;font-size:1rem}.iam-label{font-size:1.2rem;line-height:1.7rem;margin-right:.5rem}.flip-card-wrap{--flip-font-size: 1.2rem;--flip-height: 1.7rem}.flip-width-ghost,.flip-width-measure,.flip-card,.flip-face{font-size:1.2rem!important}}@media (min-width: 901px){.intro-role{--flip-font-size: 4.2rem;--flip-height: 5.5rem;font-size:1.7rem}.iam-label{font-size:3.8rem;line-height:5.5rem;margin-right:1.7rem}.flip-card-wrap{--flip-font-size: 4.2rem;--flip-height: 5.5rem}}html,body{margin:0;padding:0;background:#0b1012;color:#f5f5f5;font-family:Segoe UI,Fira Sans,Roboto,Oxygen,Ubuntu,Cantarell,Droid Sans,Helvetica Neue,Arial,sans-serif;font-size:18px;font-weight:400;letter-spacing:.01em;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}*{box-sizing:border-box}a{color:#4da3ff;text-decoration:none}a:hover{text-decoration:underline}::selection{background:#444;color:red}h1,h2,h3,h4,h5,h6{font-family:inherit;font-weight:700;letter-spacing:.02em;margin-bottom:.5em;color:#f5f5f5}p,li,span,label,input,textarea,button{font-family:inherit;font-weight:400;letter-spacing:.01em}.intro{min-height:80vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:4rem 2rem}.intro-greeting{font-size:4rem;margin:0;color:#f5f5f5;font-family:inherit;font-weight:700;letter-spacing:.03em}.highlight{font-weight:700;font-size:7rem;color:#8fd6b3;font-family:inherit;font-weight:800;letter-spacing:.04em}.intro-subtitle{margin-top:1rem;font-size:1.5rem;color:#a3a3a3;font-family:inherit;font-weight:400;letter-spacing:.01em}.accent{color:#8fd6b3}.intro-role{margin-top:2rem;font-size:1.8rem;color:#fff;font-family:inherit;font-weight:600;letter-spacing:.02em}.tech-stack{display:flex;gap:1rem;padding:.8rem 1.2rem;border-radius:10px}.tech{width:50px;height:50px;padding:0;background:transparent;box-shadow:none;object-fit:contain;display:inline-block;transition:filter .3s ease,transform .25s ease}.tech:hover{filter:grayscale(0) saturate(1) drop-shadow(0 0 10px rgba(143,214,179,.5));transform:translateY(-2px);transition:.25s ease}.main-page{opacity:0;transform:translateY(8px);transition:opacity .5s ease,transform .6s ease}.main-page.page-visible{opacity:1;transform:translateY(0)}.typewriter-text{font-size:1.3rem;color:#f5f5f5;font-family:inherit;font-weight:400;letter-spacing:.01em}button,.back-to-top{font-family:inherit;font-weight:600;letter-spacing:.02em}.back-to-top{position:fixed;right:24px;bottom:24px;width:64px;height:64px;border:2px solid #7ec8a5;border-radius:50%;background:linear-gradient(135deg,#8fd6b3 60%,#5bbfa1);color:#0b1012;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 10px 24px #8fd6b32e,0 2px 8px #0000002e;opacity:0;visibility:hidden;transform:translateY(12px) scale(.96);transition:opacity .25s ease,transform .25s cubic-bezier(.4,2,.6,1),visibility .25s ease,background .2s,box-shadow .2s;z-index:1000;outline:none}.back-to-top.show{opacity:1;visibility:visible;transform:translateY(0) scale(1)}.back-to-top:hover,.back-to-top:focus{background:linear-gradient(135deg,#a6e3c9 60%,#8fd6b3);box-shadow:0 0 0 4px #8fd6b3a0,0 10px 32px #8fd6b340;border-color:#a6e3c9}.back-to-top__icon{font-size:2rem;line-height:1;transition:transform .25s cubic-bezier(.4,2,.6,1),color .2s;color:#0b1012}.back-to-top:hover .back-to-top__icon,.back-to-top:focus .back-to-top__icon{transform:translateY(-4px) scale(1.15) rotate(-10deg);color:#2d4739;text-shadow:0 2px 12px #a6e3c9}@media (max-width: 640px){.back-to-top{right:16px;bottom:16px;width:52px;height:52px}.back-to-top__icon{font-size:1.5rem}}@media (max-width: 900px){.intro{padding:2.5rem 1rem}.intro-greeting{font-size:2.5rem}.highlight{font-size:3.5rem}.intro-role{font-size:1.1rem}.tech{width:36px;height:36px}}@media (max-width: 600px){.intro{padding:1.5rem .5rem}.intro-greeting{font-size:1.5rem}.highlight{font-size:2rem}.intro-role{font-size:.95rem;margin-top:1.2rem}.tech-stack{gap:.5rem;padding:.5rem}.tech{width:24px;height:24px}.typewriter-text,.typewriter-text span{font-size:.85rem!important}}:root{--bg: #0b0f10;--text: #e6efec;--text-soft: rgba(230, 239, 236, .9);--accent: #9ccbbf}html{scroll-behavior:smooth}.about{background:var(--bg);color:var(--text);padding-block:clamp(56px,7vw,112px);padding-inline:0;overflow-x:clip;width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);min-block-size:100svh;display:grid;scroll-margin-top:72px;scroll-snap-align:start;scroll-snap-stop:always}.about__inner{max-width:none;width:100%;margin:0;padding-inline:clamp(16px,5vw,64px);display:grid;grid-template-columns:1.2fr .8fr;align-items:center;gap:clamp(24px,5vw,64px);min-block-size:100%;align-content:center}.about__title{margin:0 0 28px;font-weight:600;letter-spacing:.2px;line-height:1.2;font-size:clamp(80px,2.4vw + 1rem,56px)}.about__title-line{display:block;word-break:keep-all;overflow-wrap:normal;-webkit-hyphens:none;hyphens:none}.about__title-line--hello{font-weight:600;font-size:clamp(84px,1.4vw + 1rem,44px);line-height:1.1;display:inline-block;transform:translateY(var(--hello-y, 0px)) rotate(var(--hello-r, 0deg)) scale(var(--hello-s, 1));will-change:transform;transition:transform 90ms ease-out}.about__title-line--role{color:var(--text);font-size:clamp(26px,1.6vw + 1rem,44px);line-height:1.16;margin-top:6px}.gradient{background:linear-gradient(90deg,#9cebb1,#a8d5cb);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.accent{color:var(--accent)}.mark{background:linear-gradient(180deg,transparent 62%,rgba(156,203,191,.22) 0);border-radius:2px;padding:0 2px 2px}.about__lead{margin:0 0 18px;color:var(--text-soft);line-height:1.35;font-size:clamp(18px,1.1vw + .6rem,28px);white-space:normal;overflow-wrap:normal;word-break:keep-all;-webkit-hyphens:none;hyphens:none;max-width:100%}.about__lead span{display:inline-block;white-space:nowrap}.about__text{overflow-wrap:normal;word-break:keep-all;-webkit-hyphens:none;hyphens:none;word-spacing:.01em}.about__links{margin:12px 0 18px;display:flex;flex-wrap:wrap;gap:10px}.btn{display:inline-flex;align-items:center;gap:8px;padding:clamp(8px,1.5vw,12px) clamp(10px,2vw,16px);border-radius:8px;font-size:clamp(.8rem,1.8vw,1rem);color:var(--text);background:#9ccbbf14;border:1px solid rgba(156,203,191,.35);text-decoration:none;transition:transform .12s ease,background .16s ease,border-color .16s ease;font-weight:600;letter-spacing:.02em}.about__media{position:relative;width:min(500px,32vw);margin-left:auto;align-self:center;transform:translateY(-10%);height:500px;touch-action:pan-y}.about__img{position:absolute;width:100%;height:auto;max-height:100%;object-fit:cover;border-radius:18px;top:0;left:0;transition:transform .26s ease,opacity .22s ease,filter .26s ease;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;z-index:1}.about__img--main{position:relative;z-index:2;transform:rotate(-3.5deg);box-shadow:0 18px 48px #0000008c}.about__img--back{position:absolute;z-index:1;width:86%;top:8%;left:-8%;transform:rotate(8deg);filter:grayscale(1) contrast(1.05) brightness(.9);box-shadow:0 12px 30px #00000073;opacity:.95}.about__img.is-front{transform:rotate(-3.5deg);filter:none;cursor:grab;box-shadow:0 18px 48px #0000008c;z-index:10}.about__img.is-front.is-dragging{transition:none;cursor:grabbing;z-index:11}.about__img.is-back{transform:rotate(8deg) scale(.86) translate(-8%,8%);filter:grayscale(1) contrast(1.05) brightness(.9);opacity:.95;box-shadow:0 12px 30px #00000073;z-index:1}.about__img.swipe-out-left{transform:translate(-140%) rotate(-12deg);opacity:.85;z-index:11}.about__img.swipe-out-right{transform:translate(140%) rotate(12deg);opacity:.85;z-index:11}@media (max-width: 640px){.about__img--back{display:block}}@media (max-width: 980px){.about__inner{grid-template-columns:1fr}.about__media{width:min(325px,53.75vw);margin:24px auto 0}}@media (max-width: 640px){.about__img--back{display:none}.about__title-line--role{font-size:clamp(22px,6vw,34px)}.about__lead{font-size:clamp(17px,4.4vw,22px)}}.hover-fill .word{display:inline-block;opacity:0;transform:translateY(.6em) scale(.985);filter:blur(4px);will-change:opacity,transform,filter}.hover-fill.is-animating .word{animation:wordRise 1.4s cubic-bezier(.22,.76,.12,.98) forwards;animation-delay:calc(var(--wi, 0) * 16ms)}@keyframes wordRise{0%{opacity:0;transform:translateY(.6em) scale(.985);filter:blur(4px)}60%{opacity:1;transform:translateY(.04em) scale(1);filter:blur(.6px)}to{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}}@media (prefers-reduced-motion: reduce){.about__title-line--hello{transform:none!important;transition:none!important}.hover-fill .word{opacity:1!important;transform:none!important;filter:none!important;animation:none!important}.about__img{transition:none!important}}.project-card{display:flex;align-items:center;justify-content:center;background:#151515;border-radius:16px;padding:clamp(1rem,3vw,5.5rem);margin:0;box-shadow:0 4px 12px #0000004d;position:relative;width:100%;--bubble-size: clamp(100px, 20vw, 160px);--bubble-offset: clamp(8px, 2vw, 24px);--bubble-extra-gap: clamp(12px, 2vw, 28px);font-family:Segoe UI,Fira Sans,Roboto,Oxygen,Ubuntu,Cantarell,Droid Sans,Helvetica Neue,Arial,sans-serif;font-size:2rem;font-weight:400;letter-spacing:.01em;min-height:clamp(420px,80svh,640px);box-sizing:border-box}.project-image img{width:clamp(280px,45vw,500px);height:clamp(280px,45vw,500px);border-radius:12px;object-fit:cover;max-width:100%}.project-content{flex:1;margin-left:clamp(1rem,3vw,3rem);position:relative;margin-top:var(--bubble-extra-gap);max-width:calc(100% - var(--bubble-size) - var(--bubble-offset))}.project-title{color:#9be3c0;font-size:3rem;font-weight:700;letter-spacing:.02em;margin-bottom:clamp(1rem,3vw,2.5rem);line-height:1.2}.project-description{color:#e0e0e0;font-size:clamp(.95rem,1.8vw,1.4rem);line-height:1.6;margin-bottom:clamp(1.5rem,3vw,2.5rem);white-space:normal;word-break:normal;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;font-weight:400;letter-spacing:.01em}.project-links{display:flex;flex-wrap:wrap;gap:clamp(8px,1.5vw,12px);font-weight:700}.project-links a{display:inline-flex;align-items:center;padding:clamp(8px,1.5vw,12px) clamp(10px,2vw,16px);border-radius:8px;font-size:clamp(.8rem,1.8vw,1rem);color:#e6efec;background:#9ccbbf14;border:1px solid rgba(156,203,191,.35);text-decoration:none;transition:transform .12s ease,background .16s ease,border-color .16s ease;font-family:inherit;font-weight:600;letter-spacing:.02em}.project-links a:hover{transform:translateY(-1px);background:#9ccbbf1f;text-decoration:none}.video-circle{position:absolute;top:var(--bubble-offset);right:var(--bubble-offset);z-index:1;width:var(--bubble-size);height:var(--bubble-size);border-radius:50%;background:#000;display:block;overflow:hidden;cursor:pointer;border:none;outline:none}.video-circle video{width:100%;height:100%;object-fit:cover;display:block;border-radius:50%;pointer-events:none}.video-circle .play-icon{position:absolute;inset:50% auto auto 50%;transform:translate(-50%,-50%);display:grid;place-items:center;width:50px;height:50px;border-radius:999px;background:#15151599;border:2.5px solid #9be3c041;color:#9be3c0bf;font-size:14px;font-weight:700;box-shadow:0 2px 8px #00000059;pointer-events:none}.video-circle.is-playing .play-icon{opacity:0}.video-circle .play-icon:empty:before{content:"";display:block;width:0;height:0;margin-left:2px;border-left:.6em solid currentColor;border-top:.38em solid transparent;border-bottom:.38em solid transparent}@media (max-width: 480px){.project-card{flex-direction:column;text-align:center;padding:clamp(.8rem,4vw,1.5rem);--bubble-size: 80px;--bubble-offset: 12px;--bubble-extra-gap: 8px;min-height:90svh;width:100%;max-width:100%}.project-image img{width:clamp(220px,70vw,300px);height:clamp(220px,70vw,300px);margin-bottom:1rem}.project-content{margin-left:0;max-width:100%;padding:0 .5rem}.project-title{font-size:clamp(1.3rem,6vw,2rem);margin-bottom:1rem}.project-description{font-size:clamp(.85rem,3.5vw,1.1rem);line-height:1.5;margin-bottom:1.25rem}.project-links a{padding:8px 12px;font-size:clamp(.75rem,3vw,.9rem)}.video-circle .play-icon{width:28px;height:28px;font-size:10px}}@media (min-width: 481px) and (max-width: 768px){.project-card{flex-direction:column;text-align:center;--bubble-size: 100px;--bubble-offset: 16px;--bubble-extra-gap: 12px;width:100%;max-width:100%}.project-image img{width:clamp(300px,60vw,400px);height:clamp(300px,60vw,400px);margin-bottom:1.5rem}.project-content{margin-left:0;max-width:100%}.video-circle .play-icon{width:35px;height:35px;font-size:12px}}@media (min-width: 769px) and (max-width: 1024px){.project-card{--bubble-size: 130px;padding:clamp(2rem,4vw,3rem)}.project-image img{width:clamp(350px,40vw,450px);height:clamp(350px,40vw,450px)}.project-content{margin-left:2rem}}.projects-section{position:relative}.projects-sticky{position:sticky;top:0;height:100vh;overflow:hidden;background:transparent}.projects-track{display:flex;height:100%;width:max-content;will-change:transform;transform:translateZ(0);transition:transform .9s cubic-bezier(.22,1,.36,1)}.project{flex:0 0 100vw;height:100%;display:flex;align-items:center;justify-content:center}.project>.project-card{width:min(1250px,95vw);margin:0 auto;box-sizing:border-box}.project-nav-bubbles{position:absolute;bottom:clamp(20px,8vh,80px);left:50%;transform:translate(-50%);display:flex;gap:clamp(8px,2vw,12px);z-index:10;padding:8px 16px;background:#0000004d;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.nav-bubble{width:clamp(8px,2.5vw,12px);height:clamp(8px,2.5vw,12px);border-radius:50%;background:#ffffff4d;border:none;cursor:pointer;transition:all .3s ease;padding:0;touch-action:manipulation}.nav-bubble.active{background:#9be3c0;transform:scale(clamp(1.1,1.5,1.3))}.nav-bubble:hover{background:#9be3c0b3}@media (max-width: 768px){.project>.project-card{width:100vw;margin:0}.project-nav-bubbles{bottom:clamp(15px,5vh,40px);gap:clamp(10px,3vw,15px);padding:10px 20px}.nav-bubble{width:10px;height:10px;min-width:10px;min-height:10px}.nav-bubble.active{transform:scale(1.4)}}.projects-section:before,.projects-section:after{content:"";position:absolute;left:0;width:100%;height:80px;pointer-events:none;z-index:2}:root{--bg-1: #0b0c10;--bg-2: #0f1115;--card: #111318;--border: #222733;--ink: #e7e9ee;--ink-muted: #c7cbd4;--ink-dim: #9aa3b2}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg-1);color:var(--ink);font-family:Segoe UI,Fira Sans,Roboto,Oxygen,Ubuntu,Cantarell,Droid Sans,Helvetica Neue,Arial,sans-serif;font-size:18px;font-weight:400;letter-spacing:.01em;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.45}.contact-wrap{padding-inline:clamp(1rem,3vw,2rem);background:linear-gradient(180deg,var(--bg-1) 0%,var(--bg-2) 100%);color:var(--ink)}.contact-center{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;min-height:35vh;max-width:700px;margin:0 auto;gap:2.5rem}.contact-hero{display:flex;flex-direction:column;align-items:center;gap:1.25rem;text-align:center}.contact-title{margin:.05em 0 0;line-height:.95;font-weight:900;letter-spacing:-.02em;font-size:3rem;font-family:inherit;font-weight:800;letter-spacing:-.01em}.contact-intro{margin:0;max-width:55ch;line-height:1.6;color:var(--ink-muted);font-family:inherit;font-weight:400;letter-spacing:.01em}.cta-row{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}.btn{display:inline-flex;align-items:center;justify-content:center;padding:clamp(8px,1.5vw,12px) clamp(10px,2vw,16px);border-radius:8px;font-size:clamp(.8rem,1.8vw,1rem);color:#e6efec;background:#9ccbbf14;border:1px solid rgba(156,203,191,.35);text-decoration:none;transition:transform .12s ease,background .16s ease,border-color .16s ease;font-family:inherit;font-weight:600;letter-spacing:.02em;cursor:pointer}.btn:hover{transform:translateY(-1px);background:#9ccbbf1f;text-decoration:none}.btn-primary,.btn-ghost{background:#9ccbbf14;color:#e6efec;border:1px solid rgba(156,203,191,.35);box-shadow:none}.btn-primary:hover,.btn-ghost:hover{transform:translateY(-1px);background:#9ccbbf1f;text-decoration:none}.btn-full{width:100%}.contact-card,.card-title,.info-list{display:none!important}.contact-footer{max-width:1120px;margin:clamp(2rem,6vw,3rem) auto 0;padding-top:1rem;border-top:1px solid #1f2430;display:flex;align-items:center;justify-content:space-between;color:#aab2c2}.back-to-top{color:inherit;text-decoration:none;border-bottom:1px dashed transparent}.back-to-top:hover{border-bottom-color:currentColor}@media (max-width: 960px){.contact-center{min-height:40vh;padding-inline:.5rem}}@media (max-width: 520px){.contact-title{letter-spacing:-.01em;font-size:2.2rem}.contact-center{gap:1.5rem}.contact-connect-big{margin-bottom:-.05em}.cta-row{flex-direction:column;width:100%;align-items:stretch;gap:.65rem}.cta-row .btn{width:100%}.contact-center{gap:1.25rem}}@media (max-width: 340px){.contact-connect-big{font-size:2.6rem}}.contact-connect-big{font-size:clamp(3rem,14vw,6rem);font-weight:700;color:#8fd6b3;line-height:1;text-align:center;letter-spacing:-.03em;margin-bottom:-.15em;word-break:break-word}:root{--pulse-color: #A7CFC2;--pulse-color-rgb: 167, 207, 194}html,body,*{cursor:none!important}.custom-cursor{position:fixed;top:0;left:0;width:50px;height:50px;margin-left:-25px;margin-top:-25px;border:1px solid #fff;border-radius:50%;pointer-events:none;mix-blend-mode:difference;transition:width .2s ease,height .2s ease,background .3s ease,border .3s ease,box-shadow .3s ease;z-index:9999;will-change:transform}.custom-cursor-dot{position:fixed;top:0;left:0;width:6px;height:6px;margin-left:-3px;margin-top:-3px;background:#fff;border-radius:50%;pointer-events:none;mix-blend-mode:difference;z-index:10000;will-change:transform}.custom-cursor.is-hover{width:52px;height:52px;background:rgba(var(--pulse-color-rgb),.13);border-color:rgba(var(--pulse-color-rgb),.8);animation:cursorPulse 1.2s ease-out infinite}.custom-cursor.is-hover:after,.custom-cursor.is-hover:before{content:"";position:absolute;inset:0;border:2px solid rgba(var(--pulse-color-rgb),.9);border-radius:50%;pointer-events:none;animation:ringPulse 1.2s ease-out infinite}.custom-cursor.is-hover:before{border-color:rgba(var(--pulse-color-rgb),.6);animation-delay:.1s}.custom-cursor.is-down{width:36px;height:36px;background:#fffa;border-color:#fff;animation:none;transform:scale(.85)}.custom-cursor-dot.is-hover{opacity:1}@keyframes cursorPulse{0%{box-shadow:0 0 rgba(var(--pulse-color-rgb),.55),0 0 12px 2px rgba(var(--pulse-color-rgb),.35)}60%{box-shadow:0 0 0 22px rgba(var(--pulse-color-rgb),.18),0 0 6px 1px rgba(var(--pulse-color-rgb),.25)}to{box-shadow:0 0 0 32px rgba(var(--pulse-color-rgb),0),0 0 rgba(var(--pulse-color-rgb),0)}}@keyframes ringPulse{0%{transform:scale(1);opacity:.9}70%{transform:scale(1.7);opacity:0}to{transform:scale(1.7);opacity:0}}@media (max-width: 680px){.custom-cursor,.custom-cursor-dot{display:none!important}}.xp404{min-height:100vh;background:linear-gradient(135deg,#0b1012,#1a1f23);display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;overflow:hidden;font-family:Segoe UI,Fira Sans,Roboto,Oxygen,Ubuntu,Cantarell,Droid Sans,Helvetica Neue,Arial,sans-serif}.xp404-card{background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:3rem 2.5rem;text-align:center;max-width:600px;width:100%;box-shadow:0 20px 40px #0000004d;position:relative;z-index:2;color:#f5f5f5}.xp404-title{font-size:2.5rem;font-weight:700;margin-bottom:1rem;color:#fff;line-height:1.2}.xp404-code{display:block;font-size:6rem;font-weight:900;background:linear-gradient(135deg,#8fd6b2,#5ea88e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.xp404-tagline{font-size:1.2rem;color:#ddd;margin-bottom:2.5rem;line-height:1.6;font-weight:400}.xp404-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:2rem}.btn{padding:.75rem 1.5rem;border-radius:12px;text-decoration:none;font-weight:600;font-size:1rem;transition:background-color .3s ease,color .3s ease,border-color .3s ease;display:inline-flex;align-items:center;justify-content:center;min-width:120px;letter-spacing:.02em;border:2px solid transparent;line-height:1}.btn:hover{transform:none!important;box-shadow:none}.btn.primary,.btn.outline{background:transparent;color:#fff;border:2px solid #8fd6b2}.btn.primary:hover,.btn.outline:hover{background:#8fd6b21f;color:#8fd6b2;border-color:#8fd6b2;box-shadow:0 0 0 4px #8fd6b226,0 2px 6px #0000004d}.btn.ghost{background:transparent;color:#ddd;border:2px solid rgba(255,255,255,.2)}.btn.ghost:hover{background:#ffffff1a;color:#fff;border-color:#ffffff4d}.xp404-note{font-size:.9rem;color:#999;font-style:italic;margin-top:1rem;line-height:1.5}.contact-email-line{margin:0 0 1rem;font-size:.95rem;color:#cfd8d6;font-family:system-ui,sans-serif;letter-spacing:.3px}.contact-email-line strong{color:#8fd6b2;font-weight:600}.contact-email{-webkit-user-select:all;user-select:all;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-weight:500;background:none;padding:0;border:none;color:#fff;cursor:text}.contact-email:hover,.contact-email:focus{background:none;border:none;color:#fff;outline:none}.back-btn{position:absolute;top:.85rem;left:.85rem;font-size:.8rem;font-weight:600;letter-spacing:.5px;padding:.45rem .8rem;border:1px solid #8fd6b2;border-radius:8px;text-decoration:none;color:#8fd6b2;background:#8fd6b214;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:background-color .25s ease,color .25s ease,border-color .25s ease}.back-btn:hover,.back-btn:focus{background:#8fd6b22e;color:#a4e6c4;outline:none;border-color:#a4e6c4}.back-btn:active{background:#8fd6b247;color:#fff}@media (max-width: 768px){.xp404-card{padding:2rem 1.5rem;margin:1rem}.xp404-title{font-size:2rem}.xp404-code{font-size:4rem}.xp404-tagline{font-size:1.1rem}.xp404-actions{flex-direction:column;align-items:center}.btn{width:100%;max-width:250px}}@media (max-width: 480px){.xp404{padding:1rem}.xp404-card{padding:1.5rem 1rem}.xp404-emoji,.xp404-code{font-size:3rem}.xp404-title{font-size:1.8rem}.back-btn{top:.6rem;left:.6rem;font-size:.7rem;padding:.4rem .65rem}}@media (prefers-reduced-motion: reduce){.xp404-confetti li,.xp404-emoji,.btn{animation:none!important}}.xp404-confetti li,.xp404-emoji,.btn{animation:none!important}
