@font-face{font-family:One Day;src:url(/fonts/one-day.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{overflow:hidden;overflow-x:clip;height:auto;scrollbar-width:none}html::-webkit-scrollbar{display:none;width:0;height:0}html.lenis,html.lenis body{height:auto}html.lenis{overflow:hidden}html.lenis.lenis-smooth{scroll-behavior:auto!important}body{width:100%;max-width:100%;overflow:hidden;overflow-x:clip;background:#02030a;color:#fff;font-family:Inter,system-ui,sans-serif}html.is-scroll-locked body{touch-action:none}#app{width:100%;max-width:100%;overflow-x:visible}canvas{display:block;position:fixed;inset:0;z-index:0;pointer-events:none;touch-action:none}button,a,input,textarea,select,[role=button]{touch-action:manipulation}#scroll-content{position:relative;z-index:10;display:flex;flex-direction:column;gap:clamp(5rem,14vh,10rem);width:100%;max-width:100%;overflow-x:visible;padding-bottom:env(safe-area-inset-bottom,0px)}@media(max-width:767px){#scroll-content{gap:clamp(3.5rem,10vh,6rem)}}.vignette{position:fixed;inset:0;z-index:2;pointer-events:none;background:radial-gradient(ellipse at center,transparent 40%,rgba(2,3,10,.85) 100%)}#loader{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#02030a;pointer-events:auto;touch-action:none;transition:opacity .4s ease,background .5s ease}#loader.loader--birthing{pointer-events:none;background:transparent}#loader.loader--birthing .loader-vignette,#loader.loader--birthing .loader-stars{opacity:0;transition:opacity .45s ease}.loader-vignette{position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 88% 78% at 50% 50%,transparent 28%,rgba(2,3,10,.42) 62%,rgba(2,3,10,.82) 100%)}.loader-stars{position:absolute;inset:-20%;pointer-events:none;opacity:.55;background-image:radial-gradient(1px 1px at 12% 18%,rgba(255,255,255,.75) 50%,transparent 100%),radial-gradient(1px 1px at 28% 72%,rgba(255,255,255,.45) 50%,transparent 100%),radial-gradient(1.5px 1.5px at 64% 24%,rgba(0,229,255,.7) 50%,transparent 100%),radial-gradient(1px 1px at 82% 58%,rgba(255,255,255,.5) 50%,transparent 100%),radial-gradient(1px 1px at 44% 88%,rgba(255,255,255,.35) 50%,transparent 100%),radial-gradient(1.5px 1.5px at 90% 14%,rgba(123,97,255,.55) 50%,transparent 100%),radial-gradient(1px 1px at 8% 52%,rgba(255,255,255,.4) 50%,transparent 100%),radial-gradient(1px 1px at 52% 8%,rgba(255,255,255,.55) 50%,transparent 100%);animation:loader-stars-drift 18s linear infinite}.loader-core{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center;padding:0 1.5rem}.loader-intro{display:flex;flex-direction:column;align-items:center;gap:.6rem;width:100%;text-align:center;margin:0 0 1.75rem}.loader-intro .hero-name{font-family:One Day,Inter,system-ui,sans-serif;font-weight:400;text-transform:uppercase;margin:0;padding:0;width:100%;max-width:min(92vw,540px);text-align:center;font-size:clamp(1.75rem,4.5vw,3rem);letter-spacing:.06em;line-height:1;white-space:nowrap;background:linear-gradient(120deg,#fff,#00e5fff2 48%,#7b61ff);-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 0 8px rgba(0,229,255,.1))}.loader-intro .hero-title{margin:0;width:100%;max-width:min(92vw,540px);text-align:center;font-size:clamp(.72rem,1.5vw,.95rem);font-weight:500;letter-spacing:.14em;text-transform:uppercase;line-height:1.3;color:#00e5ffd1;text-shadow:0 2px 10px rgba(2,3,10,.95),0 0 24px rgba(0,229,255,.2)}#lring{position:relative;width:117.6px;height:117.6px;display:flex;align-items:center;justify-content:center}.loader-ring-spin{position:absolute;inset:0;transform-origin:center center;will-change:transform,opacity}.loader-ring-canvas{position:absolute;inset:0;display:block;pointer-events:none}#lpct{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:.78rem;font-weight:600;letter-spacing:.1em;color:#ffffffeb;text-shadow:0 0 16px rgba(0,229,255,.35);background:none;border:none;box-shadow:none}#llabel{margin-top:1.35rem;min-height:1.2em;font-size:.58rem;letter-spacing:.24em;text-transform:uppercase;color:#ffffff61}@keyframes loader-stars-drift{0%{transform:translateZ(0) rotate(0)}to{transform:translate3d(-2%,-1.5%,0) rotate(2deg)}}@media(max-width:767px){.loader-intro{gap:.45rem;margin-bottom:1.35rem}.loader-intro .hero-name{letter-spacing:.04em;font-size:clamp(1.2rem,7.5vw,2rem);white-space:normal;line-height:1.05}.loader-intro .hero-title{font-size:clamp(.64rem,3vw,.8rem);letter-spacing:.1em;line-height:1.35}#lring{width:107.8px;height:107.8px}#llabel{letter-spacing:.18em}}#nav{position:fixed;top:0;left:0;right:0;z-index:50;padding:max(1.4rem,env(safe-area-inset-top,0px)) max(2.5rem,env(safe-area-inset-right,0px)) 1.4rem max(2.5rem,env(safe-area-inset-left,0px));display:flex;align-items:center;justify-content:space-between;opacity:0;pointer-events:none;transition:opacity .45s cubic-bezier(.22,1,.36,1)}.nlogo{display:flex;align-items:center;min-height:44px;min-width:44px;justify-content:center;padding:0;border:none;background:none;cursor:pointer;font-family:inherit;pointer-events:all;transition:filter .35s cubic-bezier(.22,1,.36,1),transform .35s cubic-bezier(.22,1,.36,1)}.nlogo:hover{filter:drop-shadow(0 0 12px rgba(0,229,255,.5));transform:translateY(-1px)}.nlogo:focus-visible{outline:none;box-shadow:0 0 0 2px #00e5ff73;border-radius:6px}.nlogo__mark{display:block;height:clamp(40px,5.5vw,52px);width:auto;object-fit:contain}.ncta{min-height:44px;min-width:44px;display:inline-flex;align-items:center;justify-content:center;padding:.65rem 1.25rem;border:1px solid rgba(0,229,255,.35);border-radius:999px;font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;color:#00e5ff;cursor:pointer;background:#00e5ff0f;font-family:inherit;transition:all .35s cubic-bezier(.22,1,.36,1);pointer-events:all}.ncta:hover{background:#00e5ff26;box-shadow:0 0 24px #00e5ff40}#spbar{position:fixed;left:2rem;top:50%;transform:translateY(-50%);z-index:50;width:2px;height:140px;background:#ffffff0f;border-radius:1px;opacity:0;transition:opacity .45s cubic-bezier(.22,1,.36,1)}#spfill{width:100%;background:linear-gradient(to top,#00e5ff,#7b61ff);border-radius:1px;position:absolute;bottom:0;height:0%;box-shadow:0 0 8px #00e5ff80}.progress-label{position:fixed;left:2.8rem;top:50%;transform:translateY(-50%);z-index:50;font-size:.55rem;letter-spacing:.28em;text-transform:uppercase;color:#ffffff40;writing-mode:vertical-rl;opacity:0;transition:opacity .45s cubic-bezier(.22,1,.36,1)}.scroll-hint{position:fixed;inset-inline:0;bottom:max(clamp(1.5rem,4dvh,2.5rem),env(safe-area-inset-bottom,0px));z-index:45;display:flex;flex-direction:column;align-items:center;gap:.42rem;width:100%;margin:0;padding-inline:1.25rem;text-align:center;pointer-events:none;opacity:0}.scroll-hint__text{margin:0;font-size:.58rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:#ffffff6b;text-shadow:0 1px 8px rgba(2,3,10,.9)}.scroll-hint__arrow{display:flex;align-items:center;justify-content:center;color:#00e5ff9e;filter:drop-shadow(0 1px 6px rgba(2,3,10,.85));animation:scroll-hint-bounce 1.85s cubic-bezier(.22,1,.36,1) infinite}.scroll-hint__arrow svg{display:block;width:14px;height:14px}@keyframes scroll-hint-bounce{0%,to{transform:translateY(0);opacity:.42}50%{transform:translateY(5px);opacity:.9}}@media(prefers-reduced-motion:reduce){.scroll-hint__arrow{animation:none;opacity:.55}}@media(max-width:767px){#nav{padding:max(.85rem,env(safe-area-inset-top,0px)) max(1.1rem,env(safe-area-inset-right,0px)) .85rem max(1.1rem,env(safe-area-inset-left,0px));background:#02030a52;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))){#nav{background:#02030ae0}}.nlogo__mark{height:44px}.ncta{font-size:.62rem;padding:.7rem 1.15rem}#spbar{left:max(1rem,env(safe-area-inset-left,0px));height:90px}.progress-label{display:none}.scroll-hint{padding-inline:1rem}.scroll-hint__text{font-size:.62rem;letter-spacing:.22em}.scroll-hint__arrow svg{width:13px;height:13px}}.page-section{position:relative;z-index:10;pointer-events:none}.page-section a,.page-section button,.page-section input,.page-section textarea,.page-section select,.page-section [data-lenis-prevent],.page-section .skill-categories-wrap,.page-section .contact-form,.page-section .contact-links{pointer-events:auto}.page-section--hero{min-height:100vh;min-height:100dvh;text-align:center}.page-section--journey{min-height:40vh;visibility:hidden;pointer-events:none}.page-section--scene{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;padding:8vh 6vw;max-width:560px;text-align:left}.page-section--content{padding:clamp(4rem,10vh,6rem) 6vw;display:flex;flex-direction:column;align-items:center;justify-content:flex-start}.page-section--content .content-inner{width:min(680px,92vw);pointer-events:auto}.page-section--content .scene-tag{justify-content:center}.page-section--content .card-grid{width:100%}.page-section--content .glass-card{text-align:left;opacity:1}.page-section--content .scene-title{max-width:min(680px,92vw)}.page-section--projects{min-height:560dvh;padding:0;max-width:100%;overflow:visible;margin-bottom:clamp(8rem,22vh,14rem)}#hero{position:relative;text-align:center;pointer-events:none}#hero .hero-intro{position:absolute;inset-inline:0;top:clamp(13vh,14dvh,21vh);display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:.6rem;width:100%;max-width:none;margin-inline:auto;text-align:center;transform-origin:center top;will-change:opacity,transform}#hero .hero-name{font-family:One Day,Inter,system-ui,sans-serif;font-weight:400;text-transform:uppercase;margin:0;padding:0;width:100%;max-width:min(92vw,540px);text-align:center;font-size:clamp(1.75rem,4.5vw,3rem);letter-spacing:.06em;line-height:1;white-space:nowrap;background:linear-gradient(120deg,#fff,#00e5fff2 48%,#7b61ff);-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 0 8px rgba(0,229,255,.1))}#hero .hero-title{margin:0;width:100%;max-width:min(92vw,540px);text-align:center;font-size:clamp(.72rem,1.5vw,.95rem);font-weight:500;letter-spacing:.14em;text-transform:uppercase;line-height:1.3;color:#00e5ffd1;text-shadow:0 2px 10px rgba(2,3,10,.95),0 0 24px rgba(0,229,255,.2)}#hero .hero-tagline{margin:.5rem 0 0;width:100%;max-width:min(92vw,480px);text-align:center;font-size:clamp(.8rem,1.6vw,1rem);font-weight:400;letter-spacing:.02em;line-height:1.5;color:#ffffff73;text-shadow:0 2px 10px rgba(2,3,10,.9)}#hero .hero-below{position:absolute;inset-inline:0;bottom:max(clamp(4rem,10dvh,7rem),env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:0;width:100%;max-width:none;text-align:center;transform-origin:center bottom;will-change:opacity,transform}#hero .hero-cta{position:relative;left:auto;top:auto;transform:none;min-height:44px;min-width:44px;display:inline-flex;align-items:center;justify-content:center;padding:.8rem 2rem;border:1.5px solid rgba(0,229,255,.75);border-radius:999px;font-size:.68rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:#fffffff2;cursor:pointer;background:#02030aa6;font-family:inherit;pointer-events:all;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);text-shadow:0 1px 2px rgba(2,3,10,.85);box-shadow:0 8px 28px #02030a8c,0 0 24px #00e5ff1f;transition:all .4s cubic-bezier(.22,1,.36,1);will-change:opacity,transform}#hero .hero-cta:hover{background:#00e5ff29;border-color:#00e5ffe6;box-shadow:0 8px 32px #02030a80,0 0 36px #00e5ff47}.scene-panel{align-items:flex-start;justify-content:flex-end;padding:8vh 6vw;max-width:560px;text-align:left}.scene-panel .scene-tag{font-size:.58rem;letter-spacing:.28em;text-transform:uppercase;color:#9d8cff;margin-bottom:.8rem;display:flex;align-items:center;gap:.5rem}.scene-panel .scene-tag:before{content:"";width:20px;height:1px;background:#9d8cff}.scene-panel .scene-title{font-family:One Day,Inter,system-ui,sans-serif;font-weight:400;text-transform:uppercase;font-size:clamp(1.6rem,3.4vw,2.6rem);letter-spacing:.05em;line-height:1.1;margin-bottom:.8rem;text-shadow:0 0 18px rgba(123,97,255,.14)}.scene-panel .scene-body{font-size:.85rem;line-height:1.75;color:#ffffff6b}.scene-panel .scene-body+.scene-body{margin-top:.9rem}#contact.scene-panel,.scene-panel--contact{max-width:none;width:100%;justify-content:flex-start}#about,#experience{text-align:center;position:relative;z-index:12}.page-section--scene.scene-panel--techstack{justify-content:flex-start;padding-top:max(6vh,4.5rem);overflow:visible;position:relative;z-index:11}.page-section--scene.scene-panel--wave{align-items:stretch;justify-content:flex-start;padding:0;text-align:center;max-width:none;overflow:visible;min-height:560dvh}#techstack{max-width:none;width:100%;pointer-events:none;overflow:visible}.skill-categories-wrap{position:relative;pointer-events:auto;flex-shrink:0;width:100%;max-width:450px}.skill-categories{display:flex;flex-direction:column;gap:.85rem;margin-top:.75rem;overflow:visible;flex-shrink:0}.skill-category{opacity:0;transform:translateY(12px);will-change:opacity,transform}.skill-category__label{font-family:Inter,system-ui,sans-serif;font-size:.56rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:#00e5ffb3;margin-bottom:.45rem;display:inline-block}.skill-category__label:after{content:"";display:block;width:1.75rem;height:1px;margin-top:.3rem;background:#00e5ff47}.skill-category__items{display:flex;flex-wrap:wrap;gap:.35rem}.skill-tag{padding:.3rem .6rem;border-radius:4px;border:1px solid rgba(255,255,255,.1);background:#02030a99;font-size:.62rem;font-weight:500;letter-spacing:.04em;color:#ffffffc7;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);transition:border-color .3s ease,color .3s ease}.skill-tag:hover{border-color:#00e5ff4d;color:#fffffff2}.tech-grid{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:.35rem}.tech-pill{padding:.42rem .75rem;border-radius:999px;border:1px solid rgba(0,229,255,.28);background:#02030a8c;font-size:.62rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#ffffffc7;text-shadow:0 1px 6px rgba(2,3,10,.85);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.card-grid{display:flex;flex-direction:column;gap:1rem;width:100%;margin-top:1rem}.glass-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);backdrop-filter:blur(18px);border-radius:16px;padding:1.2rem 1.4rem;opacity:0;transition:transform .6s cubic-bezier(.22,1,.36,1)}.glass-card .card-year{font-size:.58rem;letter-spacing:.2em;color:#9d8cff;text-transform:uppercase}.glass-card h3{font-size:1.1rem;margin:.4rem 0 .2rem}.glass-card .card-company{font-size:.75rem;color:#00e5ff;margin-bottom:.5rem}.glass-card .card-body{font-size:.8rem;line-height:1.65;color:#fff6}#projects,.scene-panel--projects{z-index:12;width:100%;align-items:stretch;justify-content:flex-start;max-width:none;padding:0;text-align:center;overflow:visible;pointer-events:none;isolation:isolate}#projects .projects-header,.scene-panel--projects .projects-header{position:relative;z-index:3;align-self:stretch;width:100%;padding:.65rem 6vw .75rem;text-align:center;pointer-events:none;background:transparent}#projects .projects-header.gallery-header--pinned,.scene-panel--projects .projects-header.gallery-header--pinned{position:fixed;left:0;right:0;width:100%;top:max(4.5rem,env(safe-area-inset-top,0px) + 3.25rem);z-index:12}#projects .scene-tag--projects,.scene-panel--projects .scene-tag--projects{margin-bottom:.35rem;text-shadow:none;justify-content:center}#projects .scene-tag--projects:before,.scene-panel--projects .scene-tag--projects:before{display:none}#projects .scene-title--projects,.scene-panel--projects .scene-title--projects{font-family:One Day,Inter,system-ui,sans-serif;font-weight:400;text-transform:uppercase;font-size:clamp(1.6rem,3.4vw,2.6rem);letter-spacing:.05em;line-height:1.1;margin:0;text-shadow:0 0 18px rgba(123,97,255,.14)}#wave,.scene-panel--wave{align-items:stretch;justify-content:flex-start;padding:0;margin-bottom:clamp(8rem,22vh,14rem);text-align:center;max-width:none;pointer-events:none;isolation:isolate}#wave .wave-header,.scene-panel--wave .wave-header{position:relative;z-index:3;align-self:stretch;width:100%;padding:.65rem 6vw .75rem;text-align:center;pointer-events:none;background:transparent}#wave .wave-header.gallery-header--pinned,.scene-panel--wave .wave-header.gallery-header--pinned{position:fixed;left:0;right:0;width:100%;top:max(4.5rem,env(safe-area-inset-top,0px) + 3.25rem);z-index:12}#wave .scene-tag--wave,.scene-panel--wave .scene-tag--wave{margin-bottom:.35rem;text-shadow:none;justify-content:center}#wave .scene-tag--wave:before,.scene-panel--wave .scene-tag--wave:before{display:none}#wave .scene-title--wave,.scene-panel--wave .scene-title--wave{font-family:One Day,Inter,system-ui,sans-serif;font-weight:400;text-transform:uppercase;font-size:clamp(1.6rem,3.4vw,2.6rem);letter-spacing:.05em;line-height:1.1;margin:0;text-shadow:0 0 18px rgba(123,97,255,.14)}@media(max-width:767px){.page-section:not(.page-section--projects):not(.page-section--scene.scene-panel--wave){max-width:100%;overflow-x:clip}#hero .hero-intro{top:14dvh;gap:.45rem;padding-inline:max(1rem,env(safe-area-inset-left,0px)) max(1rem,env(safe-area-inset-right,0px))}#hero .hero-name{letter-spacing:.04em;font-size:clamp(1.2rem,7.5vw,2rem);white-space:normal;line-height:1.05}#hero .hero-title{font-size:clamp(.64rem,3vw,.8rem);letter-spacing:.1em;line-height:1.35}#hero .hero-below{bottom:max(clamp(3.5rem,9dvh,5rem),env(safe-area-inset-bottom,0px) + .5rem)}#hero .hero-cta{padding:.85rem 1.65rem;font-size:.64rem;letter-spacing:.14em}.scene-panel{padding:max(6dvh,4.5rem) max(1.25rem,env(safe-area-inset-right,0px)) max(5dvh,3rem) max(1.25rem,env(safe-area-inset-left,0px));max-width:100%}.scene-panel .scene-tag{font-size:.64rem}.scene-panel .scene-title{font-size:clamp(1.45rem,7vw,2.1rem)}#about,#experience{padding:clamp(3.5rem,8dvh,5rem) max(1.25rem,env(safe-area-inset-left,0px))}#about .content-inner,#experience .content-inner{width:min(680px,94vw)}#techstack{max-width:none;width:100%;min-width:0;padding-inline:max(1.25rem,env(safe-area-inset-left,0px)) max(1.25rem,env(safe-area-inset-right,0px))}#techstack .skill-categories-wrap{pointer-events:none}.skill-categories-wrap,.skill-category__items{min-width:0;max-width:100%}.skill-category__label{font-size:.52rem}.skill-tag{font-size:.58rem;padding:.28rem .55rem}.tech-pill{font-size:.68rem;padding:.5rem .85rem}.glass-card{padding:1.1rem 1.15rem}#projects,.scene-panel--projects{margin-bottom:clamp(5rem,14vh,9rem);min-height:520dvh}#projects .projects-header.gallery-header--pinned,.scene-panel--projects .projects-header.gallery-header--pinned{top:max(4rem,env(safe-area-inset-top,0px) + 3.5rem);padding:.55rem max(1.25rem,env(safe-area-inset-left,0px)) .65rem}#wave,.scene-panel--wave{margin-bottom:clamp(5rem,14vh,9rem);min-height:520dvh}#wave .wave-header.gallery-header--pinned,.scene-panel--wave .wave-header.gallery-header--pinned{top:max(4rem,env(safe-area-inset-top,0px) + 3.5rem);padding:.55rem max(1.25rem,env(safe-area-inset-left,0px)) .65rem}}#contact,.scene-panel--contact{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;width:100%;max-width:none;padding:clamp(2.75rem,6.5vh,4rem) 3vw clamp(.5rem,1vh,.85rem);text-align:left;background:linear-gradient(180deg,transparent 0%,rgba(2,3,10,.22) 30%,rgba(2,3,10,.58) 55%,rgba(2,3,10,.9) 78%,#02030a 100%)}#contact:before,.scene-panel--contact:before{content:"";position:absolute;left:50%;bottom:-28vh;width:min(140vw,1100px);height:52vh;margin-left:calc(min(140vw,1100px)/-2);border-radius:50%;background:radial-gradient(ellipse 100% 70% at 50% 0%,rgba(0,229,255,.024) 0%,rgba(0,229,255,.006) 42%,transparent 72%);pointer-events:none;z-index:0}@media(max-width:767px){#contact,.scene-panel--contact{overflow-x:clip}#contact:before,.scene-panel--contact:before{width:100vw;margin-left:-50vw}}#wave+#contact{padding-top:clamp(3rem,8vh,5.5rem)}.contact-inner{position:relative;z-index:1;width:min(100%,1040px);margin:0 auto;padding:0;display:grid;grid-template-columns:minmax(240px,.92fr) minmax(300px,1.08fr);gap:clamp(1rem,2.5vw,2rem);align-items:start;pointer-events:none}.contact-visual{display:flex;align-items:flex-start;min-height:0;pointer-events:none}.contact-portrait{width:100%;height:auto;min-height:0;max-height:min(50vh,380px);aspect-ratio:4/5;object-fit:cover;object-position:center top;border-radius:24px;border:1px solid rgba(255,255,255,.12);box-shadow:0 28px 64px #02030aa6,0 0 0 1px #ffffff0f,inset 0 1px #ffffff14}.contact-content{display:flex;flex-direction:column;justify-content:flex-start;min-width:0}.contact-hero{display:flex;flex-direction:column;align-items:flex-start;text-align:left;margin-bottom:clamp(.75rem,1.8vh,1.15rem)}.contact-badge{display:inline-flex;align-items:center;gap:.45rem;padding:.42rem .9rem;margin-bottom:.85rem;border-radius:999px;font-size:.62rem;font-weight:600;letter-spacing:.06em;color:#ffffffb8;border:1px solid rgba(255,255,255,.1);background:#ffffff0a}.contact-title{font-family:One Day,Inter,system-ui,sans-serif;font-weight:400;text-transform:uppercase;margin:0 0 .55rem;font-size:clamp(1.85rem,3.6vw,2.75rem);letter-spacing:.05em;line-height:1.08;color:#fff;text-shadow:none}.contact-lead{margin:0 0 1rem;max-width:34rem;font-size:clamp(.82rem,1vw,.92rem);line-height:1.65;color:#ffffff73}.contact-form{display:flex;flex-direction:column;gap:.72rem;pointer-events:all;text-align:left}.contact-form label{display:flex;flex-direction:column;gap:.38rem}.contact-form label span{font-size:.72rem;font-weight:500;color:#ffffffad;letter-spacing:.01em;text-transform:none}.contact-form__row{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}.contact-form input,.contact-form textarea,.contact-form select{width:100%;background-color:#ffffff14;border:1px solid rgba(255,255,255,.2);border-radius:14px;padding:.82rem .95rem;color:#fffffff5;font-family:inherit;font-size:.86rem;transition:border-color .25s ease,background-color .25s ease,box-shadow .25s ease}.contact-form input::placeholder,.contact-form textarea::placeholder,.contact-form select::placeholder{color:#ffffff6b}.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{outline:none;border-color:#7b61ffa6;background-color:#ffffff1c;box-shadow:0 0 0 3px #7b61ff33}.contact-form select{appearance:none;cursor:pointer;padding-right:2.4rem;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='rgba(255,255,255,0.72)' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .95rem center;background-size:12px 8px}.contact-form select:invalid{color:#ffffff6b}.contact-form select:focus{background-color:#ffffff1c}.contact-form select option{color:#02030a;background:#fff}.contact-form select option[value=""]{color:#02030a8c}.contact-form textarea{min-height:5rem;resize:vertical}.contact-form__honeypot{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.contact-form__status{min-height:1.25rem;margin:0;font-size:.78rem;line-height:1.45;color:#ffffff9e}.contact-form__status[data-state=success]{color:#6ee7b7f2}.contact-form__status[data-state=error]{color:#fca5a5f2}.contact-form__status[data-state=loading]{color:#7b61ffd9}.submit-btn{width:100%;margin-top:0;padding:.85rem 1.25rem;border:1px solid rgba(255,255,255,.24);border-radius:14px;background:linear-gradient(180deg,rgba(255,255,255,.14) 0%,transparent 38%),linear-gradient(135deg,#00e5ff47,#02030ae6 58%);color:#fff;font-size:.84rem;font-weight:600;letter-spacing:.02em;text-transform:none;cursor:pointer;font-family:inherit;transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease}.submit-btn:hover{transform:translateY(-1px);border-color:#00e5ff80;box-shadow:0 12px 32px #00e5ff33}.submit-btn:disabled{opacity:.65;cursor:wait;transform:none;box-shadow:none}.contact-links{position:static;display:flex;flex-wrap:wrap;justify-content:flex-start;gap:.7rem;margin-top:.1rem;padding:0;pointer-events:auto;opacity:1}.contact-links__icon{display:grid;place-items:center;width:2.85rem;height:2.85rem;border-radius:12px;color:#ffffffe0;border:1px solid rgba(255,255,255,.16);background:#ffffff12;text-decoration:none;flex-shrink:0;transition:color .25s ease,border-color .25s ease,background .25s ease,transform .25s ease}.contact-links__icon svg{width:1.2rem;height:1.2rem;display:block;fill:currentColor}.contact-links__icon:hover{color:#fff;border-color:#7b61ff66;background:#7b61ff1f;transform:translateY(-2px)}.contact-links__icon:focus-visible{outline:none;border-color:#00e5ff8c;box-shadow:0 0 0 3px #00e5ff26}.contact-footer{grid-column:1/-1;position:relative;z-index:1;width:100%;margin:clamp(.35rem,.8vh,.55rem) 0 0;padding:clamp(1rem,2vh,1.35rem) 0 clamp(.85rem,1.6vh,1.15rem);border-top:1px solid rgba(255,255,255,.08);text-align:center;pointer-events:none}.contact-copyright{margin:0;font-size:.68rem;letter-spacing:.03em;line-height:1.45;color:#ffffff57}.contact-copyright--site{margin-top:.35rem;font-size:.62rem;letter-spacing:.06em;color:#ffffff3d}@media(max-width:900px){.contact-inner{grid-template-columns:1fr;width:min(100%,560px)}.contact-visual{min-height:auto}.contact-portrait{height:auto;min-height:clamp(180px,22dvh,240px);max-height:24dvh;aspect-ratio:16/10}.contact-content{justify-content:flex-start}.contact-hero{align-items:center;text-align:center}.contact-lead{text-align:center}.contact-links{justify-content:center}}@media(max-width:767px){#contact.page-section--content{padding:max(3.5dvh,env(safe-area-inset-top,0px) + 2rem) max(1.1rem,env(safe-area-inset-right,0px)) max(2dvh,env(safe-area-inset-bottom,0px) + .5rem) max(1.1rem,env(safe-area-inset-left,0px))}.contact-visual{width:100%;max-width:min(100%,22rem);margin-inline:auto}.contact-portrait{width:100%;height:auto;min-height:0;max-height:none;aspect-ratio:1/1;object-fit:cover;object-position:center center}.contact-form__row{grid-template-columns:1fr}.contact-form input,.contact-form textarea,.contact-form select{font-size:16px}.submit-btn{width:100%;min-height:48px}}.skill-labels-layer{position:fixed;inset:0;z-index:15;pointer-events:none;overflow:hidden}.skill-label{font-family:Inter,system-ui,sans-serif;letter-spacing:.22em;text-transform:uppercase;white-space:nowrap;pointer-events:auto;cursor:default;transition:color .3s cubic-bezier(.22,1,.36,1),transform .3s cubic-bezier(.22,1,.36,1),text-shadow .3s cubic-bezier(.22,1,.36,1)}.skill-label--center{font-size:.95rem;font-weight:600;color:#ffffffe0;letter-spacing:.12em;text-shadow:0 0 30px rgba(0,229,255,.35)}.skill-label--sub{font-size:.52rem;color:#ffffff59;letter-spacing:.28em}.skill-label--orbit{font-size:clamp(.62rem,2.4vw,.72rem);color:#00e5ffbf;padding:.2rem .1rem;pointer-events:none}.skill-label--orbit:after{content:attr(data-proficiency);display:block;font-size:.48rem;letter-spacing:.18em;color:#9d8cff;margin-top:.25rem;opacity:0;transition:opacity .25s}.skill-label--orbit.is-hovered{color:#fff;transform:scale(1.12);text-shadow:0 0 18px rgba(0,229,255,.65)}.skill-label--orbit.is-hovered:after{opacity:1}@media(max-width:767px){.skill-labels-layer{overflow:hidden}.skill-label--orbit{font-size:clamp(.66rem,2.8vw,.76rem);letter-spacing:.16em;text-shadow:0 1px 8px rgba(2,3,10,.95)}}.custom-scrollbar{position:fixed;top:50%;right:max(.65rem,env(safe-area-inset-right,0px));z-index:48;transform:translateY(-50%);width:10px;height:min(42vh,220px);padding:2px 0;opacity:0;pointer-events:none;transition:opacity .45s cubic-bezier(.22,1,.36,1)}.custom-scrollbar__track{position:relative;width:100%;height:100%;border-radius:999px;background:#ffffff0f;cursor:pointer;touch-action:none}.custom-scrollbar__thumb{position:absolute;top:0;left:0;width:100%;min-height:44px;border-radius:999px;background:linear-gradient(to bottom,#00e5ffd9,#7b61ffbf);box-shadow:0 0 10px #00e5ff59;cursor:grab;touch-action:none;will-change:transform,height}.custom-scrollbar__thumb:active{cursor:grabbing}@media(max-width:767px){.custom-scrollbar{display:none}}html:not(.is-scroll-locked) .custom-scrollbar.is-visible{opacity:1;pointer-events:auto}
