.logo{position:fixed;top:calc(var(--spacing-lg) + var(--spacing-md));left:calc(var(--spacing-lg) + var(--spacing-sm));z-index:10001;width:50px;height:50px;cursor:pointer;transition:transform .3s ease;background:transparent;border:none;padding:0;display:flex;align-items:center;justify-content:center}.logo:hover{transform:scale(1.1)}.logo-letter{font-size:1.5rem;font-weight:var(--font-weight-bold);color:var(--text-color);font-family:var(--font-primary);letter-spacing:-.02em;transition:color .5s cubic-bezier(.4,0,.2,1)}@media (max-width: 768px){.logo{top:calc(var(--spacing-md) * 2);left:calc(var(--spacing-sm) * 2);width:45px;height:45px}}@media (prefers-reduced-motion: reduce){.logo,.logo:hover{transition:none!important;transform:none!important}}.theme-toggle{position:fixed;top:calc(var(--spacing-lg) + var(--spacing-md));right:calc(var(--spacing-lg) + var(--spacing-sm) + 48px + var(--spacing-sm));z-index:10000;width:44px;height:44px;background:transparent;border:none;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.theme-toggle:hover{transform:scale(1.1)}.theme-toggle:active{transform:scale(.95)}.theme-toggle.animating{pointer-events:none}.theme-toggle-icon{position:relative;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.theme-icon{width:20px;height:20px;color:#fff;transition:all .3s cubic-bezier(.34,1.56,.64,1);stroke-width:2}[data-theme=light] .theme-icon{color:#0d0745}.sun-icon{animation:rotate 20s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.moon-icon{animation:pulse 3s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.theme-toggle.animating .theme-icon{animation:iconSwitch .3s cubic-bezier(.34,1.56,.64,1)}@keyframes iconSwitch{0%{transform:rotate(0) scale(1);opacity:1}50%{transform:rotate(180deg) scale(.5);opacity:0}to{transform:rotate(360deg) scale(1);opacity:1}}@media (max-width: 768px){.theme-toggle{top:calc(var(--spacing-md) * 2);right:calc(var(--spacing-sm) * 2 + 40px + var(--spacing-xs));width:44px;height:44px}.theme-icon{width:22px;height:22px}}@media (max-width: 480px){.theme-toggle{width:40px;height:40px}.theme-icon{width:20px;height:20px}}.hamburger{position:fixed;top:calc(var(--spacing-lg) + var(--spacing-md));right:calc(var(--spacing-lg) + var(--spacing-sm));z-index:10000;width:48px;height:48px;display:flex;justify-content:center;align-items:center;background:transparent;border:none;cursor:pointer;padding:0;transition:transform .3s ease}.hamburger:hover{transform:scale(1.05)}.hamburger-svg{display:block;width:48px;height:48px}.circle{fill:none;stroke:var(--text-color);stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;opacity:1;transition:all .6s cubic-bezier(.16,1,.3,1),stroke .5s cubic-bezier(.4,0,.2,1);transform-origin:center}.circle-2,.circle-4,.circle-6,.circle-8,.circle-center{transform:translate(0)}.rect{fill:none;stroke:var(--text-color);stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;opacity:0;transition:all .2s cubic-bezier(.16,1,.3,1),stroke .5s cubic-bezier(.4,0,.2,1);transform-origin:center}.rect-top{transform:scaleY(0);transform-origin:center bottom}.rect-right{transform:scaleX(0);transform-origin:left center}.rect-bottom{transform:scaleY(0);transform-origin:center top}.rect-left{transform:scaleX(0);transform-origin:right center}.rect-center{transform:scale(0);transform-origin:center}.hamburger:hover .circle-2,.hamburger:hover .circle-4,.hamburger:hover .circle-6,.hamburger:hover .circle-8,.hamburger:hover .circle-center{opacity:0}.hamburger:hover .circle-2{transform:translateY(-6px)}.hamburger:hover .circle-4{transform:translate(6px)}.hamburger:hover .circle-6{transform:translateY(6px)}.hamburger:hover .circle-8{transform:translate(-6px)}.hamburger:hover .rect{opacity:1}.hamburger:hover .rect-top{transform:scaleY(1)}.hamburger:hover .rect-right{transform:scaleX(1)}.hamburger:hover .rect-bottom{transform:scaleY(1)}.hamburger:hover .rect-left{transform:scaleX(1)}.hamburger:hover .rect-center{transform:scale(1)}.hamburger.open .circle{opacity:0;transform:scale(0)}.hamburger.open .rect{opacity:1;transform:scale(1);stroke:#0d0745}[data-theme=dark] .hamburger.open .rect{stroke:#fff}.menu-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#fafafaf2;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);z-index:9998;display:flex;align-items:center;justify-content:center;opacity:0;border:1px solid var(--color-border)}[data-theme=dark] .menu-overlay{background-color:#0a0a15f2;border:1px solid rgba(255,255,255,.1)}.menu-nav{width:100%;max-width:800px;padding:var(--spacing-md)}.menu-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.menu-list-item{margin:0}.menu-item{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.5rem);font-weight:var(--font-weight-bold);color:var(--color-text);text-align:left;width:100%;padding:var(--spacing-sm) 0;background:none;border:none;cursor:pointer;position:relative;overflow:hidden;letter-spacing:-.02em;transition:color .3s ease,transform .3s ease}.menu-item:before{content:"";position:absolute;left:0;bottom:0;width:0;height:3px;background-color:var(--color-text-primary);transition:width .4s ease}.menu-item:hover:before,.menu-item:focus-visible:before{width:100%}.menu-item:hover,.menu-item:focus-visible{font-weight:var(--font-weight-semibold);transform:translate(10px)}.menu-item.active{font-weight:var(--font-weight-semibold)}.menu-item.active:before{width:100%}@media (max-width: 768px){.hamburger{top:calc(var(--spacing-md) * 2);right:calc(var(--spacing-sm) * 2);width:40px;height:40px}.hamburger-svg{width:40px;height:40px}.menu-item{font-size:clamp(2rem,10vw,3.5rem);padding:var(--spacing-xs) 0}.menu-nav{padding:var(--spacing-sm) var(--spacing-md)}}body.menu-open .theme-toggle:not(.menu-theme-toggle),body.menu-open .audio-toggle{opacity:0;pointer-events:none}@media (prefers-reduced-motion: reduce){.hamburger,.circle,.rect,.menu-item,.menu-item:before{transition:none!important}.hamburger:hover .circle,.hamburger.open .circle,.hamburger:hover .rect,.hamburger.open .rect{transform:none!important}}.menu-theme-toggle.theme-toggle{position:fixed;top:calc(var(--spacing-lg) + var(--spacing-md));right:calc(var(--spacing-lg) + var(--spacing-sm) + 48px + var(--spacing-sm));z-index:10000}@media (max-width: 768px){.menu-theme-toggle.theme-toggle{top:calc(var(--spacing-md) * 2);right:calc(var(--spacing-sm) * 2 + 40px + var(--spacing-xs))}}.audio-toggle{position:fixed;bottom:calc(var(--spacing-lg) + var(--spacing-md));right:calc(var(--spacing-lg) + var(--spacing-sm));z-index:9999;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.1);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);color:var(--text-color);opacity:.6}.audio-toggle:hover{opacity:1;transform:scale(1.1);background:rgba(255,255,255,.15)}.audio-toggle:active{transform:scale(.95)}.audio-toggle.enabled{opacity:1;background:rgba(14,165,233,.2);border-color:#0ea5e966;color:#0ea5e9}.audio-toggle.enabled:hover{background:rgba(14,165,233,.3)}[data-theme=light] .audio-toggle{background:rgba(0,0,0,.08);border-color:#00000026;color:#374151;opacity:.7}[data-theme=light] .audio-toggle:hover{background:rgba(0,0,0,.12);opacity:1}[data-theme=light] .audio-toggle.enabled{background:rgba(14,165,233,.15);border-color:#0ea5e966;color:#0284c7;opacity:1}[data-theme=light] .audio-toggle.enabled:hover{background:rgba(14,165,233,.25)}[data-theme=dark] .audio-toggle{background:rgba(255,255,255,.12);border-color:#ffffff40;opacity:.8}[data-theme=dark] .audio-toggle:hover{background:rgba(255,255,255,.2);opacity:1}[data-theme=dark] .audio-toggle.enabled{background:rgba(170,119,255,.3);border-color:#a7f9;color:#c9f;opacity:1}[data-theme=dark] .audio-toggle.enabled:hover{background:rgba(170,119,255,.4)}.audio-icon{width:20px;height:20px;transition:transform .2s ease}.audio-toggle:hover .audio-icon{transform:scale(1.05)}.audio-toggle.enabled:after{content:"";position:absolute;width:100%;height:100%;border-radius:50%;border:2px solid currentColor;animation:audioPulse 2s ease-out infinite;opacity:0}@keyframes audioPulse{0%{transform:scale(1);opacity:.5}to{transform:scale(1.5);opacity:0}}@media (max-width: 768px){.audio-toggle{display:none}}@media (prefers-reduced-motion: reduce){.audio-toggle,.audio-icon{transition:none!important}.audio-toggle.enabled:after{animation:none}}.noise{position:fixed;z-index:999;top:-300%;left:-150%;height:600%;width:600%;animation:grain 7s steps(10) infinite;background-image:url(/assets/noise-1a0d33e2.png);background-size:200px;background-repeat:repeat;opacity:.015;pointer-events:none;mix-blend-mode:multiply;transition:opacity .5s cubic-bezier(.4,0,.2,1)}@keyframes grain{0%,to{transform:translate(0)}10%{transform:translate(-5%,-10%)}20%{transform:translate(-15%,5%)}30%{transform:translate(7%,-25%)}40%{transform:translate(-5%,25%)}50%{transform:translate(-15%,10%)}60%{transform:translate(15%)}70%{transform:translateY(15%)}80%{transform:translate(3%,30%)}90%{transform:translate(-10%,10%)}}@media (prefers-reduced-motion: reduce){.noise{animation:none!important;opacity:.08}}.metaball-background{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:0;pointer-events:none;overflow:hidden}.metaball-background canvas{position:fixed!important;top:0!important;left:0!important;width:100vw!important;height:100vh!important;z-index:0!important;display:block!important;pointer-events:none}.app,.main-content{position:relative;z-index:1}@media (max-width: 768px){.metaball-background{display:none!important}}@media (max-width: 900px) and (orientation: portrait){.metaball-background{display:none!important}}@media (prefers-reduced-motion: reduce){.metaball-background{display:none}}.mobile-balls{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:-1;overflow:hidden}.mobile-ball{position:absolute;border-radius:50%;transform:translate(-50%,-50%);transition:left .8s ease-out,top .8s ease-out;will-change:left,top}.mobile-balls.light .mobile-ball--blue{background:radial-gradient(circle at 30% 30%,rgba(220,242,255,.95) 0%,rgba(196,228,255,.85) 40%,rgba(172,214,255,.7) 70%,rgba(148,200,255,.5) 100%);box-shadow:inset -20px -20px 40px #94c8ff4d,inset 10px 10px 30px #fffc,0 10px 40px #acd6ff4d}.mobile-balls.light .mobile-ball--pink{background:radial-gradient(circle at 30% 30%,rgba(255,229,238,.95) 0%,rgba(255,210,225,.85) 40%,rgba(255,190,210,.7) 70%,rgba(255,170,195,.5) 100%);box-shadow:inset -20px -20px 40px #ffaac34d,inset 10px 10px 30px #fffc,0 10px 40px #ffbed24d}.mobile-balls.light .mobile-ball--purple{background:radial-gradient(circle at 30% 30%,rgba(240,230,255,.95) 0%,rgba(225,210,255,.85) 40%,rgba(210,190,255,.7) 70%,rgba(195,170,255,.5) 100%);box-shadow:inset -20px -20px 40px #c3aaff4d,inset 10px 10px 30px #fffc,0 10px 40px #d2beff4d}.mobile-balls.light .mobile-ball--mint{background:radial-gradient(circle at 30% 30%,rgba(224,255,237,.95) 0%,rgba(200,245,220,.85) 40%,rgba(176,235,200,.7) 70%,rgba(152,225,180,.5) 100%);box-shadow:inset -20px -20px 40px #98e1b44d,inset 10px 10px 30px #fffc,0 10px 40px #b0ebc84d}.mobile-balls.dark .mobile-ball--blue{background:radial-gradient(circle at 35% 35%,rgba(80,100,160,.7) 0%,rgba(50,70,130,.6) 30%,rgba(30,45,100,.5) 60%,rgba(15,25,70,.35) 100%);box-shadow:inset -15px -15px 35px #0a0f3299,inset 8px 8px 25px #7896dc33,0 0 60px #5064a040,0 0 100px #32468226}.mobile-balls.dark .mobile-ball--pink{background:radial-gradient(circle at 35% 35%,rgba(140,80,110,.7) 0%,rgba(110,50,85,.6) 30%,rgba(80,30,60,.5) 60%,rgba(50,15,40,.35) 100%);box-shadow:inset -15px -15px 35px #230a1e99,inset 8px 8px 25px #c88caa33,0 0 60px #8c506e40,0 0 100px #6e325526}.mobile-balls.dark .mobile-ball--purple{background:radial-gradient(circle at 35% 35%,rgba(100,70,150,.7) 0%,rgba(70,45,120,.6) 30%,rgba(50,30,100,.5) 60%,rgba(30,18,70,.35) 100%);box-shadow:inset -15px -15px 35px #140a2d99,inset 8px 8px 25px #a082dc33,0 0 60px #64469640,0 0 100px #462d7826}.mobile-balls.dark .mobile-ball--mint{background:radial-gradient(circle at 35% 35%,rgba(60,120,100,.7) 0%,rgba(40,95,75,.6) 30%,rgba(25,70,55,.5) 60%,rgba(12,45,35,.35) 100%);box-shadow:inset -15px -15px 35px #081e1999,inset 8px 8px 25px #78b4a033,0 0 60px #3c786440,0 0 100px #285f4b26}@keyframes float{0%,to{transform:translate(-50%,-50%) translateY(0)}50%{transform:translate(-50%,-50%) translateY(-10px)}}.mobile-ball:nth-child(1){animation:float 6s ease-in-out infinite}.mobile-ball:nth-child(2){animation:float 7s ease-in-out infinite;animation-delay:-1s}.mobile-ball:nth-child(3){animation:float 5s ease-in-out infinite;animation-delay:-2s}.mobile-ball:nth-child(4){animation:float 8s ease-in-out infinite;animation-delay:-3s}@media (prefers-reduced-motion: reduce){.mobile-ball{animation:none;transition:none}}.hero-section{position:relative;z-index:10;display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--spacing-lg) var(--spacing-md)}.hero-content{width:100%;margin:0 auto;position:relative;z-index:10;text-align:center;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:var(--spacing-lg)}.hero-lines{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs)}.hero-name-wrapper{display:flex;flex-direction:row;flex-wrap:wrap;align-items:center;justify-content:center;gap:.5rem}.hero-line{font-family:var(--font-display);font-weight:var(--font-weight-bold);line-height:1.1;letter-spacing:-.03em;color:var(--color-text);margin:0;overflow:visible;position:relative;z-index:10;perspective:1000px}.hero-line .char-wrapper{display:inline-block;overflow:visible}.hero-line .char{display:inline-block;transform-origin:center bottom;will-change:transform,opacity;transform-style:preserve-3d;backface-visibility:hidden;-webkit-backface-visibility:hidden}.hero-line-1{font-size:clamp(2.5rem,6.5vw,5.5rem);font-weight:var(--font-weight-bold);color:#0d0745;max-width:90%;line-height:1.15;display:inline}[data-theme=dark] .hero-line-1{color:#fff}.hero-line-1b{font-size:clamp(2.5rem,6.5vw,5.5rem);font-weight:var(--font-weight-bold);color:#0d0745;line-height:1.15;margin-top:0;display:inline}[data-theme=dark] .hero-line-1b{color:#fff}.hero-line-2{font-size:clamp(1.25rem,3vw,2rem);font-weight:var(--font-weight-medium);background:linear-gradient(135deg,var(--color-accent-primary) 0%,var(--color-accent-secondary) 50%,var(--color-accent-tertiary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-top:var(--spacing-xs)}.hero-line-3{font-size:clamp(1.25rem,3vw,2rem);font-weight:var(--font-weight-normal);color:var(--color-text);opacity:.9}.hero-ctas{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-sm);flex-wrap:wrap;justify-content:center}.hero-cta{display:flex;align-items:center;gap:var(--spacing-xs);text-decoration:none;font-size:clamp(1rem,2vw,1.25rem);color:var(--color-text);transition:all .3s ease;cursor:pointer;padding:.5rem 0;background:none;border:none;font-family:inherit;position:relative}.hero-cta-arrow{width:24px;height:24px;color:var(--color-text-tertiary);transition:all .3s ease;display:inline-block;flex-shrink:0}.hero-cta:after{content:"";position:absolute;left:0;bottom:0;width:100%;height:2px;background:var(--color-text-primary);transform:scaleX(0);transform-origin:left;transition:transform .25s ease-out}.hero-cta:hover:after{transform:scaleX(1)}.hero-cta:hover .hero-cta-arrow{transform:translate(1.5px)}@media (max-width: 768px){.hero-section{padding:var(--spacing-md) var(--spacing-sm)}.hero-name-wrapper{flex-direction:column;gap:var(--spacing-xs)}.hero-line-1,.hero-line-1b{font-size:clamp(2rem,10vw,3.5rem);display:block;max-width:100%}.hero-line-2,.hero-line-3{font-size:clamp(1rem,4vw,1.5rem)}.hero-ctas{flex-direction:column;gap:var(--spacing-sm)}.hero-cta{font-size:clamp(.9rem,4vw,1.1rem)}}@media (max-width: 480px){.hero-line-1,.hero-line-1b{font-size:clamp(1.75rem,11vw,2.5rem)}.hero-line-2,.hero-line-3{font-size:clamp(.9rem,5vw,1.25rem)}}.hero-desktop-notice{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:rgba(0,0,0,.05);border:1px solid rgba(0,0,0,.1);border-radius:8px;color:var(--color-text-primary);font-size:clamp(.875rem,2vw,1rem);font-weight:var(--font-weight-medium);margin-top:var(--spacing-sm);max-width:400px;text-align:center;justify-content:center;animation:fadeSlideUp .5s ease-out .8s backwards}[data-theme=dark] .hero-desktop-notice{background:rgba(255,255,255,.08);border-color:#ffffff26;color:#ffffffd9}.hero-desktop-notice svg{flex-shrink:0;opacity:.8}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion: reduce){.hero-line,.hero-ctas{opacity:1!important}.hero-cta-arrow{transition:none!important}.hero-cta:hover .hero-cta-arrow{transform:none!important}.hero-desktop-notice{animation:none!important}}.about-section{position:relative;z-index:1;padding:calc(var(--spacing-xl) + var(--spacing-lg)) var(--spacing-md) var(--spacing-xl);min-height:100vh;display:flex;align-items:center;justify-content:center}.about-content{display:grid;grid-template-columns:35% 65%;gap:var(--spacing-lg);max-width:1200px;width:100%;align-items:start}.about-left{display:flex;flex-direction:column;gap:var(--spacing-md);align-items:center;position:sticky;top:calc(var(--spacing-xl) + var(--spacing-lg))}.about-photo-wrapper{position:relative;width:250px;height:250px;border-radius:50%;overflow:hidden;border:3px solid var(--color-border);transition:all .4s ease;background:var(--color-bg-secondary)}.about-photo-wrapper:hover{box-shadow:0 0 30px #00000026;transform:scale(1.03)}.about-photo{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.about-cta{display:flex;align-items:center;gap:var(--spacing-xs);padding:.75rem 1.5rem;background:transparent;border:2px solid var(--color-border-strong);border-radius:50px;color:var(--color-text-primary);font-size:clamp(.9rem,2vw,1rem);font-weight:var(--font-weight-medium);text-decoration:none;transition:all .3s ease;font-family:var(--font-body);letter-spacing:-.01em;position:relative;overflow:hidden}@media (hover: none) and (pointer: coarse){.about-cta{cursor:pointer}}.about-cta-icon{font-size:1.25rem;transition:transform .3s ease;display:inline-block}.about-cta-text{transition:color .3s ease}.about-cta-arrow{font-size:1.25rem;opacity:0;width:0;transform:translate(-10px);transition:all .4s cubic-bezier(.16,1,.3,1);display:inline-block}.about-cta:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.about-cta:hover .about-cta-icon{transform:translateY(3px)}.about-cta:hover .about-cta-arrow{opacity:1;width:1.25em;transform:translate(0)}[data-theme=dark] .about-cta{border-color:#ffffff4d;color:#ffffffe6}[data-theme=dark] .about-cta:hover{border-color:#ffffff80;background:rgba(255,255,255,.05);box-shadow:0 4px 12px #0000004d}.about-right{display:flex;flex-direction:column;gap:var(--spacing-md);padding-right:var(--spacing-lg)}.about-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:var(--font-weight-bold);color:#0d0745;margin:0;font-family:var(--font-display);letter-spacing:-.02em}[data-theme=dark] .about-title{color:#fff}.about-bio{margin-bottom:var(--spacing-sm)}.about-bio p{font-size:clamp(1.125rem,2.5vw,1.375rem);line-height:1.6;color:var(--color-text-secondary);margin:0;font-family:var(--font-body);letter-spacing:-.01em}.bio-highlight{color:var(--color-text-primary);font-weight:var(--font-weight-semibold)}.expertise-section{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.expertise-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.expertise-title{font-size:clamp(1.125rem,2.5vw,1.375rem);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;font-family:var(--font-display);letter-spacing:-.015em}.expertise-skills{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.skill-badge{display:inline-block;padding:.4rem .9rem;background:rgba(14,165,233,.08);border:1px solid rgba(14,165,233,.25);border-radius:20px;font-size:clamp(.8rem,1.5vw,.9rem);color:var(--color-text-primary);font-weight:var(--font-weight-medium);transition:all .3s ease;font-family:var(--font-body);letter-spacing:-.01em}.skill-badge:hover{transform:translateY(-2px);box-shadow:0 2px 8px #0000001a}[data-theme=light] .skill-badge{background:rgba(13,7,69,.08);border:1px solid rgba(13,7,69,.2);color:#0d0745}@media (max-width: 1024px){.about-content{grid-template-columns:1fr;gap:var(--spacing-md);max-width:600px}.about-left{position:relative;top:0;gap:var(--spacing-sm)}.about-photo-wrapper{width:200px;height:200px}.about-cta{width:100%;max-width:280px;justify-content:center;padding:.75rem 1.25rem;font-size:clamp(.95rem,2.5vw,1.05rem)}.about-right{gap:var(--spacing-xs);padding-right:0}.about-title{font-size:clamp(1.75rem,6vw,2.25rem)}.about-bio p{font-size:clamp(1rem,3.5vw,1.125rem)}.expertise-title{font-size:clamp(1.05rem,3.5vw,1.25rem)}.skill-badge{font-size:clamp(.75rem,2.5vw,.85rem);padding:.35rem .75rem}}@media (max-width: 768px){.about-section{padding:150px var(--spacing-sm) var(--spacing-lg)}.about-content{grid-template-columns:1fr;gap:var(--spacing-md);padding:var(--spacing-lg) 0!important}.about-left{position:relative;top:0;gap:var(--spacing-sm)}.about-photo-wrapper{width:180px;height:180px}.about-cta{width:100%;max-width:280px;justify-content:center;padding:.75rem 1.25rem;font-size:clamp(.95rem,2.5vw,1.05rem)}.about-right{gap:var(--spacing-xs);padding:0}.about-title{font-size:clamp(1.5rem,7vw,2rem)}.about-bio p{font-size:clamp(.9rem,3.5vw,1rem)}.expertise-title{font-size:clamp(.95rem,3.5vw,1.125rem)}.skill-badge{font-size:clamp(.65rem,2.5vw,.75rem);padding:.3rem .65rem}}@media (max-width: 480px){.about-section{padding:160px var(--spacing-sm) var(--spacing-lg)}.about-photo-wrapper{width:150px;height:150px}.about-title{font-size:clamp(1.4rem,8vw,1.75rem)}.expertise-section{gap:var(--spacing-sm)}}@media (prefers-reduced-motion: reduce){.about-photo-wrapper,.about-cta,.about-cta-icon,.about-cta-arrow,.skill-badge{transition:none!important}.about-photo-wrapper:hover,.about-cta:hover,.skill-badge:hover{transform:none!important}.about-title,.about-bio,.expertise-item{opacity:1!important}}.about-cta:focus-visible,.skill-badge:focus-visible{outline:2px solid var(--color-text-primary);outline-offset:4px}.work-section{position:relative;z-index:0;padding:0!important;min-height:100vh;display:flex;align-items:center;justify-content:start}.work-content-wrapper{display:grid;grid-template-columns:50% 50%;gap:var(--spacing-sm);width:100%;align-items:start}.work-image-preview{position:sticky;bottom:0;width:100%;display:flex;flex-direction:column;gap:var(--spacing-sm);align-self:end;justify-content:flex-end;min-height:100vh}.work-image-container{width:95%;height:500px;aspect-ratio:16/9;border-radius:0 48px 0 0;overflow:hidden;position:relative}.work-image-wrapper{position:absolute;top:0;left:0;width:100%;height:100%;transition:opacity .5s cubic-bezier(.4,0,.2,1);will-change:opacity}.work-image-inner{width:100%;height:100%;overflow:hidden;border-radius:0 48px 0 0;position:relative}.work-image-wrapper[style*="opacity: 1"] .work-image-inner{animation:zoomIn .4s cubic-bezier(.4,0,.2,1) forwards}.work-image-wrapper[style*="opacity: 0"] .work-image-inner{animation:zoomOut .65s cubic-bezier(.4,0,.2,1) forwards}@keyframes zoomIn{0%{transform:scale(1)}to{transform:scale(1.1)}}@keyframes zoomOut{0%{transform:scale(1.1)}to{transform:scale(1)}}.work-preview-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;-o-object-position:center top;object-position:center top;display:block}.work-image-overlay{position:absolute;bottom:0;left:0;width:100%;height:70%;background:linear-gradient(to top,rgba(0,0,0,.95) 0%,rgba(0,0,0,.85) 30%,rgba(0,0,0,.6) 50%,rgba(0,0,0,.3) 70%,transparent 100%);pointer-events:none;z-index:1}.work-project-info-overlay{position:absolute;bottom:0;left:0;right:0;padding:var(--spacing-lg);z-index:2;animation:fadeSlideUp .5s cubic-bezier(.25,.46,.45,.94) .2s backwards;pointer-events:none}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.work-project-info{display:flex;flex-direction:column;gap:var(--spacing-sm);animation:fadeSlideDown .4s cubic-bezier(.25,.46,.45,.94) forwards;padding:0 0 0 var(--spacing-md)}@keyframes fadeSlideDown{0%{opacity:0;transform:translateY(-15px)}to{opacity:1;transform:translateY(0)}}.work-project-name{font-size:clamp(1.5rem,3vw,2rem);font-weight:var(--font-weight-bold);color:#fff;margin:0 0 var(--spacing-xs) 0;text-shadow:0 3px 12px rgba(0,0,0,.8),0 1px 3px rgba(0,0,0,.9)}.work-project-description{font-size:clamp(.9rem,1.8vw,1rem);color:#fffffff2;line-height:1.5;margin:0 0 var(--spacing-sm) 0;text-shadow:0 2px 8px rgba(0,0,0,.8),0 1px 3px rgba(0,0,0,.9);font-weight:400}.work-project-techs{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.tech-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .9rem;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);border-radius:20px;font-size:.75rem;color:#fff;font-weight:500;text-shadow:0 1px 3px rgba(0,0,0,.8)}.tech-icon{width:1em;height:1em;flex-shrink:0}.work-content{display:flex;flex-direction:column;gap:var(--spacing-sm);padding-right:calc(var(--spacing-lg) * 2.5);align-self:end;justify-content:flex-end;min-height:100vh}.work-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding-right:var(--spacing-md)}.work-header-left{display:flex;align-items:baseline;gap:var(--spacing-sm)}.work-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:var(--font-weight-bold);color:#0d0745;margin:0;letter-spacing:-.02em}[data-theme=dark] .work-title{color:#fff}.work-count{font-size:clamp(1rem,2vw,1.25rem);color:#fff;font-weight:var(--font-weight-bold)}[data-theme=light] .work-count{color:#0d0745}.work-filters{display:flex;gap:.5rem}.work-filter-btn{padding:.4rem 1rem;font-size:.875rem;font-weight:500;color:#606887;background:transparent;border:1px solid rgba(96,104,135,.25);border-radius:100px;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);white-space:nowrap}.work-filter-btn:hover{color:#0d0745;border-color:#60688780;background:rgba(96,104,135,.08)}.work-filter-btn.active{color:#0d0745;border-color:#0d074566;background:rgba(13,7,69,.08)}[data-theme=dark] .work-filter-btn{color:#fff9;border-color:#ffffff26}[data-theme=dark] .work-filter-btn:hover{color:#ffffffe6;border-color:#ffffff4d;background:rgba(255,255,255,.08)}[data-theme=dark] .work-filter-btn.active{color:#fff;border-color:#fff6;background:rgba(255,255,255,.08)}.work-list{display:flex;flex-direction:column;gap:0;width:100%;height:380px;min-height:380px;overflow-y:auto;padding-right:var(--spacing-md);margin-right:calc(-1 * var(--spacing-md))}.work-list::-webkit-scrollbar{width:6px}.work-list::-webkit-scrollbar-track{background:rgba(13,7,69,.1);border-radius:10px}.work-list::-webkit-scrollbar-thumb{background:rgba(13,7,69,.3);border-radius:10px}.work-list::-webkit-scrollbar-thumb:hover{background:rgba(13,7,69,.5)}[data-theme=dark] .work-list::-webkit-scrollbar-track{background:rgba(204,170,255,.15)}[data-theme=dark] .work-list::-webkit-scrollbar-thumb{background:rgba(170,119,255,.6)}[data-theme=dark] .work-list::-webkit-scrollbar-thumb:hover{background:rgba(170,119,255,.8)}.work-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) 0;border-bottom:1px solid rgba(96,104,135,.15);background:transparent;cursor:pointer;transition:none;text-align:left;width:100%;position:relative}.work-item:first-child{border-top:1px solid rgba(96,104,135,.15)}[data-theme=dark] .work-item{border-bottom:1px solid rgba(255,255,255,.1)}[data-theme=dark] .work-item:first-child{border-top:1px solid rgba(255,255,255,.1)}.work-item-arrow{display:inline-block;font-size:2rem;font-weight:700;color:var(--color-text);margin-right:0;width:0;opacity:0;transform:translate(-20px);overflow:hidden;transition:width .4s cubic-bezier(.16,1,.3,1),opacity .4s cubic-bezier(.16,1,.3,1),transform .4s cubic-bezier(.16,1,.3,1),margin-right .4s cubic-bezier(.16,1,.3,1)}.work-item:hover .work-item-arrow{opacity:1;width:1.5em;transform:translate(0)}.work-item-content{display:flex;align-items:center;justify-content:space-between;width:100%;gap:var(--spacing-md)}.work-item-left{display:flex;align-items:center;overflow:visible}.work-item-name{font-size:clamp(1.125rem,2vw,1.5rem);font-weight:var(--font-weight-bold);color:var(--color-text);letter-spacing:-.02em;display:inline-block}.work-item-right{display:flex;align-items:center;gap:var(--spacing-sm);flex-shrink:0}.work-item-type{font-size:clamp(.875rem,1.5vw,1rem);color:#606887;opacity:.5;display:block;text-align:right;white-space:nowrap}[data-theme=dark] .work-item-type{color:#fff9;opacity:1}.work-item.selected{background:rgba(13,7,69,.08);border-color:#0d074533;border-left:3px solid #0d0745;padding-left:calc(var(--spacing-xs) - 3px)}.work-item.selected .work-item-name{color:#0d0745;font-weight:var(--font-weight-bold)}.work-item.selected .work-item-type{color:#0d0745b3;opacity:1}.work-item.selected .work-item-arrow{opacity:1;width:1.5em;margin-right:1.33rem;transform:translate(0);color:#0d0745}.work-item-view{display:none}[data-theme=dark] .work-item.selected{background:rgba(255,255,255,.08);border-color:#fff3;border-left:3px solid #ffffff}[data-theme=dark] .work-item.selected .work-item-name{color:#fff}[data-theme=dark] .work-item.selected .work-item-type{color:#fffc}[data-theme=dark] .work-item.selected .work-item-arrow{color:#fff}@media (max-width: 1024px){.work-section{min-height:unset;height:100dvh;max-height:-webkit-fill-available;display:flex;align-items:stretch;padding:var(--spacing-xl) 0 var(--spacing-lg) 0!important;overflow:hidden}.work-content-wrapper{display:flex;flex-direction:column;gap:0;width:100%;height:100%;overflow:hidden;padding-top:calc(var(--safe-area-top, 0px) + var(--spacing-xl))}.work-image-preview{min-height:unset;position:relative;width:100%;flex-shrink:0;z-index:5;padding:0;margin:0;order:2}.work-image-container{width:auto;margin:0;padding:0;aspect-ratio:16/9;max-height:45vh;border-radius:0 20px 5px 0;margin-right:var(--spacing-sm);cursor:pointer;transition:transform .3s ease;box-shadow:none;overflow:hidden}.work-image-container:active{transform:scale(.98)}.work-content{min-height:unset;width:100%;display:contents;order:1}.work-header{display:contents}.work-header-left{order:1;width:100%;flex-shrink:0;padding:calc(var(--spacing-lg) + var(--spacing-md)) var(--spacing-md) var(--spacing-sm) var(--spacing-lg)}.work-filters{order:3;width:100%;gap:.375rem;padding:var(--spacing-sm) var(--spacing-sm) var(--spacing-md) var(--spacing-sm)}.work-filter-btn{padding:.5rem 1.1rem;font-size:1rem}.work-list{order:4;width:100%;height:auto;min-height:unset;flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:.25rem var(--spacing-sm) var(--spacing-md)}.work-item{cursor:pointer;transition:all .3s ease}.work-item:active{transform:translate(4px) scale(.98);background:rgba(13,7,69,.06)}.work-item-arrow{display:none}.work-item-content{gap:var(--spacing-sm)}.work-item-left{padding-left:var(--spacing-sm)}.work-item-right{gap:var(--spacing-xs);padding-right:var(--spacing-xs)}.work-project-name{font-size:clamp(1.125rem,2.5vw,1.5rem)}.work-project-description{font-size:.8125rem;line-height:1.4}.tech-badge{font-size:.625rem;padding:.3rem .65rem;gap:.3rem}.tech-icon{width:.9em;height:.9em}.work-project-techs{gap:.375rem}.work-image-overlay{height:70%;background:linear-gradient(to top,rgba(0,0,0,.95) 0%,rgba(0,0,0,.85) 30%,rgba(0,0,0,.5) 60%,transparent 100%)}.work-project-name{text-shadow:0 2px 8px rgba(0,0,0,1),0 4px 16px rgba(0,0,0,.9),0 1px 2px rgba(0,0,0,1)}.work-project-description{text-shadow:0 2px 6px rgba(0,0,0,1),0 1px 2px rgba(0,0,0,1)}.work-project-info-overlay{padding-right:var(--spacing-md);padding-bottom:var(--spacing-md)}}@media (max-width: 768px){.work-section{padding:0!important}.work-image-container{aspect-ratio:16/9;max-height:40vh;border-radius:0 18px 4px 0}.work-item{padding:var(--spacing-sm) 0}.work-item-content{flex-direction:row;justify-content:space-between;align-items:center;gap:.5rem}.work-header{padding:var(--spacing-lg) var(--spacing-sm) var(--spacing-md) var(--spacing-lg)}.work-filter-btn{padding:.45rem 1rem;font-size:.8rem}.work-item-type{text-align:left;font-size:.75rem}.work-item-name{font-size:clamp(1rem,4vw,1.25rem)}.work-project-name{font-size:clamp(1rem,2.2vw,1.25rem)}.work-project-description{font-size:.75rem;line-height:1.35}.tech-badge{font-size:.5625rem;padding:.25rem .5rem;gap:.25rem}.tech-icon{width:.85em;height:.85em}.work-project-techs{gap:.3rem}}@media (max-width: 480px){.work-image-container{width:auto;margin-right:var(--spacing-xs);aspect-ratio:16/9;max-height:35vh;border-radius:0 15px 3px 0}.work-item-name{font-size:clamp(.9rem,4vw,1.1rem)}.work-project-name{font-size:.9375rem}}@media (prefers-reduced-motion: reduce){.work-item,.work-item-arrow,.work-preview-image{transition:none!important;transform:none!important}.work-item:hover,.work-item:hover .work-item-arrow{transform:none!important}}.contact-section{position:relative;z-index:1;padding:calc(var(--spacing-xl) + var(--spacing-lg)) var(--spacing-md) var(--spacing-xl);min-height:100vh;display:flex;align-items:flex-start;justify-content:flex-start;padding-top:calc(var(--spacing-xl) * 1.5)}.contact-wrapper{max-width:1400px;width:100%;margin:0 auto;padding:0 var(--spacing-lg)}.contact-title{font-size:clamp(2.5rem,5vw,4rem);font-weight:var(--font-weight-bold);color:#0d0745;margin:0 0 var(--spacing-md) 0;font-family:var(--font-display);letter-spacing:.1em;text-transform:uppercase}[data-theme=dark] .contact-title{color:#fff}.contact-divider{width:100%;height:1px;background:var(--color-text-primary);margin-bottom:var(--spacing-xl)}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-xl)}.contact-column{display:flex;flex-direction:column;gap:var(--spacing-md)}.contact-column-label{font-size:clamp(.875rem,1.5vw,1rem);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);font-family:var(--font-display);letter-spacing:.1em;text-transform:uppercase;margin:0}.contact-links{display:flex;flex-direction:column;gap:var(--spacing-sm)}.contact-link{display:inline-flex;align-items:center;gap:var(--spacing-xs);text-decoration:none;color:var(--color-text-primary);font-size:clamp(1.125rem,2.5vw,1.5rem);font-family:var(--font-body);font-weight:var(--font-weight-normal);letter-spacing:-.015em;position:relative;width:-moz-fit-content;width:fit-content;cursor:pointer;padding-bottom:.25rem}.contact-icon{font-size:clamp(1.25rem,2.5vw,1.5rem);color:var(--color-text-secondary);transition:all .3s ease}.contact-arrow{font-size:clamp(1.25rem,2.5vw,1.5rem);color:var(--color-text-tertiary);transition:all .3s ease;display:inline-block}.contact-link-text{position:relative;transition:color .3s ease}.contact-link-text:after{content:"";position:absolute;left:0;bottom:-4px;width:100%;height:2px;background:var(--color-text-primary);transform:scaleX(0);transform-origin:left;transition:transform .25s ease-out}.contact-link:hover .contact-link-text:after{transform:scaleX(1)}.contact-link:hover .contact-icon{transform:scale(1.1)}.contact-link:hover .contact-arrow{transform:translate(3px,-3px)}@media (max-width: 1024px){.contact-wrapper{padding:0 var(--spacing-md)}.contact-grid{gap:var(--spacing-lg)}}@media (max-width: 768px){.contact-section{padding:calc(var(--spacing-lg) + var(--spacing-md)) var(--spacing-sm) var(--spacing-lg)}.contact-wrapper{padding:0}.contact-title{font-size:clamp(2rem,8vw,3rem);margin-bottom:var(--spacing-sm)}.contact-divider{margin-bottom:var(--spacing-lg)}.contact-grid{grid-template-columns:1fr;gap:var(--spacing-lg)}.contact-column{gap:var(--spacing-sm)}.contact-link{font-size:clamp(1rem,4vw,1.25rem)}.contact-icon,.contact-arrow{font-size:clamp(1.125rem,4vw,1.35rem)}}@media (max-width: 480px){.contact-title{font-size:clamp(1.75rem,10vw,2.5rem)}.contact-link{font-size:clamp(.95rem,5vw,1.125rem)}.contact-column-label{font-size:clamp(.8rem,3vw,.9rem)}.contact-icon,.contact-arrow{font-size:clamp(1rem,4vw,1.2rem)}}@media (prefers-reduced-motion: reduce){.contact-icon,.contact-arrow,.contact-link-text,.contact-link-text:after{transition:none!important}.contact-link:hover .contact-icon,.contact-link:hover .contact-arrow{transform:none!important}.contact-title,.contact-divider,.contact-link{opacity:1!important}}.contact-link:focus-visible{outline:2px solid var(--color-text-primary);outline-offset:4px;border-radius:4px}@media (prefers-contrast: high){.contact-divider{height:2px}.contact-link-text:after{height:3px}}.project-detail-section{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:1;padding:0;background:transparent;overflow:hidden}.project-detail-scroll-wrapper{position:absolute;top:0;left:0;width:100%;height:100%;overflow-y:auto;overflow-x:hidden;z-index:1}.project-detail-bg{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:0;background:#0a0a15}[data-theme=light] .project-detail-bg{background:#fafbfc}.pd-blob{position:absolute;border-radius:50%;filter:blur(100px);opacity:.3}.pd-blob-1{width:500px;height:500px;background:linear-gradient(135deg,#8b5cf6 0%,#6366f1 100%);top:-150px;right:-100px}.pd-blob-2{width:400px;height:400px;background:linear-gradient(135deg,#a855f7 0%,#7c3aed 100%);bottom:10%;left:-150px}.pd-blob-3{width:350px;height:350px;background:linear-gradient(135deg,#c084fc 0%,#9333ea 100%);top:50%;right:5%}.pd-blob-4{width:300px;height:300px;background:linear-gradient(135deg,#818cf8 0%,#6366f1 100%);bottom:-100px;left:30%}[data-theme=light] .pd-blob{opacity:.4}[data-theme=light] .pd-blob-1{background:linear-gradient(135deg,#d4eeff 0%,#a5d8ff 100%)}[data-theme=light] .pd-blob-2{background:linear-gradient(135deg,#ffe0ec 0%,#ffc9c9 100%)}[data-theme=light] .pd-blob-3{background:linear-gradient(135deg,#dcffe8 0%,#b2f2bb 100%)}[data-theme=light] .pd-blob-4{background:linear-gradient(135deg,#ede0ff 0%,#d0bfff 100%)}.project-detail-back{position:fixed;top:var(--spacing-lg);left:var(--spacing-lg);display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);border-radius:100px;color:#fffffff2;font-size:.875rem;font-weight:500;cursor:pointer;z-index:100;transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.project-detail-back:hover{background:rgba(255,255,255,.15);transform:translate(-4px)}.project-detail-back svg{transition:transform .3s ease}.project-detail-back:hover svg{transform:translate(-3px)}[data-theme=light] .project-detail-back{background:rgba(13,7,69,.08);border:1px solid rgba(13,7,69,.15);color:#0d0745e6}[data-theme=light] .project-detail-back:hover{background:rgba(13,7,69,.12)}.project-detail-content{position:relative;z-index:1;max-width:1200px;margin:0 auto;padding:0 calc(var(--spacing-lg) + var(--spacing-sm) + 60px) var(--spacing-xl)}.pd-hero{margin-bottom:4rem}.pd-hero-image-wrapper{display:block;position:relative;width:100%;aspect-ratio:16/9;border-radius:0 0 20px 20px;overflow:hidden;margin-bottom:2.5rem;box-shadow:0 25px 80px #0006;cursor:pointer;transition:transform .3s ease,box-shadow .3s ease}a.pd-hero-image-wrapper{text-decoration:none}.pd-hero-image-wrapper:hover{transform:scale(1.01);box-shadow:0 30px 90px #00000080}.pd-hero-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;-o-object-position:center top;object-position:center top}.pd-hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.35);opacity:0;transition:opacity .3s ease;pointer-events:none}.pd-hero-image-wrapper:hover .pd-hero-overlay{opacity:1}[data-theme=light] .pd-hero-overlay{background:rgba(0,0,0,.15)}.pd-hero-cursor-label{position:absolute;width:100px;height:100px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.1);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:2px solid rgba(255,255,255,.6);color:#fff;border-radius:50%;pointer-events:none;opacity:0;transform:translate(-50%,-50%) scale(.8);transition:opacity .3s ease,transform .3s cubic-bezier(.16,1,.3,1);z-index:10}.pd-hero-cursor-label svg{width:32px;height:32px}.pd-hero-image-wrapper:hover .pd-hero-cursor-label{opacity:1;transform:translate(-50%,-50%) scale(1)}[data-theme=light] .pd-hero-cursor-label{background:rgba(255,255,255,.2);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-color:#fff9;color:#fff}@media (hover: none) and (pointer: coarse){.pd-hero-cursor-label{display:none}}.pd-hero-gradient{position:absolute;bottom:0;left:0;right:0;height:40%;background:linear-gradient(to top,rgba(10,10,21,.8),transparent);pointer-events:none}[data-theme=light] .pd-hero-gradient{background:linear-gradient(to top,rgba(250,251,252,.6),transparent)}[data-theme=light] .pd-hero-image-wrapper{box-shadow:0 25px 80px #00000026}[data-theme=light] .pd-hero-image-wrapper:hover{box-shadow:0 30px 90px #0003}.pd-hero-info{padding:0 .5rem}.pd-meta-row{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.pd-meta{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.pd-category,.pd-year,.pd-role{font-size:.9rem;font-weight:500;color:#fff9;letter-spacing:.02em}[data-theme=light] .pd-category,[data-theme=light] .pd-year,[data-theme=light] .pd-role{color:#0d07458c}.pd-divider{color:#fff3}[data-theme=light] .pd-divider{color:#0d074526}.pd-title-row{display:flex;align-items:baseline;gap:1.25rem;flex-wrap:wrap;margin-bottom:1rem}.pd-title{font-size:clamp(2rem,6vw,3.5rem);font-weight:700;color:#fff;letter-spacing:-.03em;line-height:1.1;margin:0}[data-theme=light] .pd-title{color:#0d0745}.pd-title-link{display:inline-flex;align-items:center;gap:.375rem;font-size:.875rem;font-weight:500;color:#a78bfa;text-decoration:none;transition:color .2s ease;white-space:nowrap}.pd-title-link-text{position:relative}.pd-title-link-text:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1px;background:currentColor;transition:width .3s cubic-bezier(.16,1,.3,1)}.pd-title-link:hover{color:#c4b5fd}.pd-title-link:hover .pd-title-link-text:after{width:100%}.pd-title-link svg{transition:transform .2s ease}.pd-title-link:hover svg{transform:translate(2px,-2px)}[data-theme=light] .pd-title-link{color:#7c3aed}[data-theme=light] .pd-title-link:hover{color:#6d28d9}.pd-description{font-size:clamp(1rem,1.8vw,1.1rem);color:#fffc;line-height:1.6;margin:0;max-width:700px}[data-theme=light] .pd-description{color:#0d0745b3}.pd-techs{display:flex;flex-wrap:wrap;gap:.5rem}.pd-tech-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:100px;font-size:.875rem;font-weight:500;color:#fffc;transition:all .2s ease}.pd-tech-badge:hover{background:rgba(255,255,255,.1);border-color:#ffffff2e}[data-theme=light] .pd-tech-badge{background:rgba(13,7,69,.05);border:1px solid rgba(13,7,69,.1);color:#0d0745bf}[data-theme=light] .pd-tech-badge:hover{background:rgba(13,7,69,.08);border-color:#0d074526}.pd-tech-icon{width:1.1em;height:1.1em;flex-shrink:0}.pd-story{padding:0 .5rem;width:100%}.pd-section-block{margin-bottom:2.5rem}.pd-section-label{display:flex;align-items:center;gap:1rem;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#ffffff80;margin-bottom:1rem}.pd-section-label:after{content:"";flex:1;height:1px;background:linear-gradient(to right,rgba(255,255,255,.2),transparent)}[data-theme=light] .pd-section-label{color:#0d074573}[data-theme=light] .pd-section-label:after{background:linear-gradient(to right,rgba(13,7,69,.15),transparent)}.pd-section-text{font-size:clamp(1rem,1.5vw,1.1rem);line-height:1.75;color:#fffc;margin:0;font-weight:400;letter-spacing:-.01em}[data-theme=light] .pd-section-text{color:#0d0745b3}.pd-features{margin-bottom:3rem}.pd-feature-rows{display:flex;flex-direction:column;gap:4rem;margin-top:1.5rem}.pd-feature-row{display:grid;grid-template-columns:2.5fr 1fr;gap:2.5rem;align-items:start}.pd-feature-row:nth-child(2n){direction:rtl}.pd-feature-row:nth-child(2n)>*{direction:ltr}.pd-feature-image{border-radius:20px;overflow:hidden;box-shadow:0 4px 24px #0000001f,0 12px 48px #00000014}[data-theme=light] .pd-feature-image{box-shadow:0 4px 24px #00000014,0 12px 48px #0000000d}.pd-feature-image img{width:100%;height:auto;display:block}.pd-feature-content{display:flex;flex-direction:column;gap:1rem;padding-top:.5rem}.pd-feature-header{display:flex;flex-direction:column-reverse;gap:.5rem}.pd-feature-number{font-size:.75rem;font-weight:600;letter-spacing:.1em;font-family:monospace;color:#8b5cf6b3}[data-theme=light] .pd-feature-number{color:#7c3aeda6}.pd-feature-title{margin:0;font-size:1.5rem;font-weight:600;color:#fffffff2;letter-spacing:-.02em;line-height:1.3;padding-bottom:.75rem;position:relative}.pd-feature-title:after{content:"";position:absolute;bottom:0;left:0;width:40px;height:3px;background:linear-gradient(90deg,#a78bfa 0%,#7c3aed 100%);border-radius:2px}[data-theme=light] .pd-feature-title{color:#0d0745e6}[data-theme=light] .pd-feature-title:after{background:linear-gradient(90deg,#8b5cf6 0%,#6d28d9 100%)}.pd-feature-desc{margin:0;font-size:1rem;font-weight:400;color:#fffc;line-height:1.7}[data-theme=light] .pd-feature-desc{color:#0d0745b3}@media (max-width: 900px){.pd-feature-rows{gap:3rem}.pd-feature-row{grid-template-columns:1.8fr 1fr;gap:2rem}.pd-feature-title{font-size:1.25rem}.pd-feature-desc{font-size:.9375rem}}@media (max-width: 680px){.pd-feature-rows{gap:3rem}.pd-feature-row{grid-template-columns:1fr;gap:1.25rem}.pd-feature-row:nth-child(2n){direction:ltr}.pd-feature-image{border-radius:12px;border:1px solid rgba(255,255,255,.1)}[data-theme=light] .pd-feature-image{border-color:#0d074514}.pd-feature-content{padding:0 .25rem;gap:.5rem}.pd-feature-header{flex-direction:row;justify-content:space-between;align-items:flex-start;gap:1rem}.pd-feature-number{font-size:.7rem;order:2;padding-top:.25rem}.pd-feature-title{font-size:1.125rem;padding-bottom:.625rem;order:1}.pd-feature-title:after{width:28px;height:2px}.pd-feature-desc{font-size:.9375rem}}@media (max-width: 480px){.pd-feature-rows{gap:2.5rem}.pd-feature-row{gap:1rem}.pd-feature-image{border-radius:10px}.pd-feature-title{font-size:1rem}.pd-feature-desc{font-size:.875rem}}.pd-footer{margin-top:3rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:1.5rem}[data-theme=light] .pd-footer{border-top:1px solid rgba(13,7,69,.08)}.pd-cta-button{display:inline-flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;background:rgba(139,92,246,.1);border:1px solid rgba(139,92,246,.25);border-radius:10px;text-decoration:none;transition:all .25s ease;width:-moz-fit-content;width:fit-content}.pd-cta-button:hover{background:rgba(139,92,246,.18);border-color:#8b5cf666;transform:translate(4px)}.pd-cta-content{display:flex;align-items:center;gap:.5rem}.pd-cta-label{display:none}.pd-cta-title{font-size:.9rem;font-weight:500;color:#a78bfa;letter-spacing:-.01em}.pd-cta-icon{display:flex;align-items:center;justify-content:center;color:#a78bfa;transition:transform .25s ease}.pd-cta-icon svg{width:16px;height:16px}.pd-cta-button:hover .pd-cta-icon{transform:translate(2px,-2px)}[data-theme=light] .pd-cta-button{background:rgba(124,58,237,.08);border-color:#7c3aed33}[data-theme=light] .pd-cta-button:hover{background:rgba(124,58,237,.15);border-color:#7c3aed59}[data-theme=light] .pd-cta-title,[data-theme=light] .pd-cta-icon{color:#7c3aed}.pd-next-card{display:grid;grid-template-columns:1fr 200px;gap:2rem;align-items:center;width:100%;padding:1.5rem;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:16px;cursor:pointer;text-align:left;transition:all .3s ease}.pd-next-card:hover{background:rgba(255,255,255,.05);border-color:#ffffff1f;transform:translateY(-2px)}[data-theme=light] .pd-next-card{background:rgba(13,7,69,.02);border-color:#0d074514}[data-theme=light] .pd-next-card:hover{background:rgba(13,7,69,.04);border-color:#0d07451f}.pd-next-info{display:flex;flex-direction:column;gap:.5rem}.pd-next-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:#8b5cf6cc}[data-theme=light] .pd-next-label{color:#7c3aedb3}.pd-next-name{font-size:1.75rem;font-weight:700;color:#fffffff2;letter-spacing:-.03em;line-height:1.2;transition:color .3s ease}[data-theme=light] .pd-next-name{color:#0d0745e6}.pd-next-card:hover .pd-next-name{color:#a78bfa}[data-theme=light] .pd-next-card:hover .pd-next-name{color:#7c3aed}.pd-next-desc{font-size:.9rem;line-height:1.5;color:#ffffff80;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}[data-theme=light] .pd-next-desc{color:#0d074580}.pd-next-preview{position:relative;width:200px;height:120px;border-radius:12px;overflow:hidden;flex-shrink:0}.pd-next-preview img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .4s ease}.pd-next-card:hover .pd-next-preview img{transform:scale(1.05)}@media (max-width: 768px){.pd-footer{margin-top:2rem;padding-top:1.5rem;gap:1rem}.pd-cta-button{padding:1.25rem 1.5rem}.pd-cta-title{font-size:1.1rem}.pd-cta-icon{width:40px;height:40px}.pd-cta-icon svg{width:20px;height:20px}.pd-next-card{grid-template-columns:1fr;gap:1rem;padding:1.25rem}.pd-next-name{font-size:1.35rem}.pd-next-preview{width:100%;height:140px;order:-1}.pd-next-desc{-webkit-line-clamp:2}}.pd-gallery{padding:2rem .5rem;border-top:1px solid rgba(255,255,255,.1)}[data-theme=light] .pd-gallery{border-top:1px solid rgba(13,7,69,.1)}.pd-gallery-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#ffffff80;margin-bottom:1.5rem}[data-theme=light] .pd-gallery-label{color:#0d074566}.pd-gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.pd-gallery-item{aspect-ratio:16/9;border-radius:12px;overflow:hidden;cursor:pointer;transition:transform .3s ease}.pd-gallery-item:hover{transform:scale(1.02)}.pd-gallery-item img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}@media (max-width: 1024px){.project-detail-back{top:var(--spacing-md);left:var(--spacing-md);padding:.6rem 1rem;font-size:.8rem}.project-detail-content{padding:180px var(--spacing-xl) var(--spacing-lg)}.pd-hero-image-wrapper{border-radius:24px;margin-bottom:2rem}.pd-hero-info,.pd-story{padding:0 var(--spacing-sm)}.pd-section-block{margin-bottom:2rem}.pd-gallery{padding:2rem var(--spacing-sm)}.pd-blob-1{width:350px;height:350px}.pd-blob-2{width:280px;height:280px}.pd-blob-3{width:220px;height:220px}.pd-blob-4{width:180px;height:180px}}@media (max-width: 768px){.project-detail-back{top:var(--spacing-sm);left:var(--spacing-sm)}.project-detail-content{padding:140px var(--spacing-lg) var(--spacing-lg)}.pd-hero-image-wrapper{border-radius:20px;margin-bottom:2rem}.pd-hero-info{padding:0 var(--spacing-sm)}.pd-meta-row{flex-direction:column;align-items:flex-start;gap:.75rem}.pd-meta{gap:.5rem}.pd-category,.pd-year,.pd-role{font-size:.85rem}.pd-tech-badge{padding:.4rem .8rem;font-size:.8rem}.pd-title{font-size:clamp(1.75rem,8vw,2.5rem)}.pd-description{font-size:.9375rem}.pd-story{padding:0 var(--spacing-sm)}.pd-section-label{font-size:.75rem;gap:.75rem}.pd-section-text{font-size:.9375rem;line-height:1.7}.pd-visit-link{font-size:.875rem}.pd-gallery{padding:2rem var(--spacing-sm)}.pd-blob-1{width:250px;height:250px;top:-80px;right:-80px}.pd-blob-2{width:200px;height:200px}.pd-blob-3{width:150px;height:150px}.pd-blob-4{width:120px;height:120px}}@media (max-width: 480px){.project-detail-content{padding:160px var(--spacing-md) var(--spacing-lg)}.pd-hero-image-wrapper{border-radius:16px}.pd-hero-info{padding:0}.pd-title{font-size:clamp(1.5rem,9vw,2rem)}.pd-description{font-size:.875rem}.pd-category,.pd-year,.pd-role{font-size:.8rem}.pd-techs{gap:.375rem}.pd-tech-badge{padding:.35rem .7rem;font-size:.75rem}.pd-story{padding:0}.pd-section-label{font-size:.7rem;gap:.625rem}.pd-section-text{font-size:.875rem;line-height:1.65}.pd-gallery{padding:2rem 0}}@media (prefers-reduced-motion: reduce){.project-detail-back:hover{transform:none}.project-detail-back:hover svg{transform:none}.pd-visit-link:hover .pd-visit-arrow{transform:none}.pd-visit-text:after{transition:none}.pd-hero-image-wrapper:hover{transform:none}.pd-hero-overlay,.pd-hero-cursor-label{transition:none}.pd-title-link:hover svg{transform:none}}.project-detail-back:focus-visible,.pd-visit-link:focus-visible{outline:2px solid #a78bfa;outline-offset:4px}[data-theme=light] .project-detail-back:focus-visible,[data-theme=light] .pd-visit-link:focus-visible{outline-color:#7c3aed}:root{--color-bg: #fafbfc;--color-bg-secondary: #f5f7fa;--color-surface: rgba(255, 255, 255, .85);--text-color: #0D0745;--text-secondary-color: #4a4a6a;--background-color: #FAFBFC;--color-text-primary: var(--text-color);--color-text-secondary: var(--text-secondary-color);--color-text-tertiary: var(--text-secondary-color);--color-accent-primary: #0ea5e9;--color-accent-secondary: #8b5cf6;--color-accent-tertiary: #ec4899;--color-accent-success: #10b981;--color-accent: var(--color-accent-primary);--color-text: var(--color-text-primary);--color-accent-glow: rgba(14, 165, 233, .2);--color-border: rgba(13, 7, 69, .08);--color-border-strong: rgba(13, 7, 69, .15);--font-display: "Space Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-primary: var(--font-body);--font-weight-light: 300;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--spacing-xs: .5rem;--spacing-sm: 1rem;--spacing-md: 2rem;--spacing-lg: 4rem;--spacing-xl: 6rem;--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px);--safe-area-left: env(safe-area-inset-left, 0px);--safe-area-right: env(safe-area-inset-right, 0px);--spacing-fluid-xs: clamp(.5rem, 2vw, .75rem);--spacing-fluid-sm: clamp(1rem, 3vw, 1.5rem);--spacing-fluid-md: clamp(1.5rem, 4vw, 2.5rem);--spacing-fluid-lg: clamp(2rem, 6vw, 4rem);--mobile-header-safe: calc(var(--safe-area-top) + 56px);--mobile-content-safe: calc(var(--safe-area-left) + var(--spacing-sm));--transition-fast: .2s;--transition-medium: .4s;--transition-slow: .6s;--cursor-size: 12px;--cursor-size-hover: 40px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;overflow:hidden;position:relative;background-color:var(--background-color);transition:background-color .5s cubic-bezier(.4,0,.2,1)}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}body{margin:0;padding:0;font-family:var(--font-body);font-weight:var(--font-weight-normal);background-color:transparent;color:var(--text-color);line-height:1.6;letter-spacing:-.015em;overflow:hidden;position:relative;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:color .5s cubic-bezier(.4,0,.2,1);text-rendering:optimizeLegibility}@media (hover: none) and (pointer: coarse){body{cursor:auto}}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:var(--font-weight-semibold);line-height:1.2;margin:0;letter-spacing:-.02em}h1{font-size:clamp(2rem,6vw,4rem);font-weight:var(--font-weight-bold);letter-spacing:-.03em}h2{font-size:clamp(1.5rem,4vw,2.5rem);font-weight:var(--font-weight-semibold);letter-spacing:-.025em}h3{font-size:clamp(1.25rem,3vw,2rem);font-weight:var(--font-weight-semibold);letter-spacing:-.02em}p{font-family:var(--font-body);margin:0;font-size:clamp(1rem,2vw,1.125rem);font-weight:var(--font-weight-normal);line-height:1.6;letter-spacing:-.01em}a{color:inherit;text-decoration:none;position:relative}a:focus-visible{outline:2px solid var(--color-text-primary);outline-offset:4px}button{font-family:inherit;font-size:inherit;background:none;border:none;color:inherit;cursor:pointer;padding:0}button:focus-visible{outline:2px solid var(--color-text-primary);outline-offset:4px}::-moz-selection{background-color:#78ffd1;color:#606887}::selection{background-color:#78ffd1;color:#606887}::-webkit-scrollbar{width:0;height:0}body{scrollbar-width:none;-ms-overflow-style:none}.section{position:fixed;top:0;left:0;width:100vw;height:100vh;display:none;align-items:center;justify-content:center;padding:var(--spacing-lg) var(--spacing-md);opacity:0}.section.active{display:flex;opacity:1}@media (max-width: 768px){.section{padding:var(--spacing-md) var(--spacing-sm)}}.container{width:100%;max-width:1400px;margin:0 auto;padding:0 var(--spacing-md)}@media (max-width: 768px){.container{padding:0 var(--spacing-sm)}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.hidden{display:none!important}.loading{opacity:0;pointer-events:none}.gpu-accelerated{transform:translateZ(0);will-change:transform}.transitioning{pointer-events:none}img{max-width:100%;height:auto;display:block}.app{position:relative;z-index:1;width:100%;min-height:100vh;background-color:transparent;color:var(--color-text);overflow:hidden}.main-content{position:relative;z-index:1;width:100%}html{scroll-behavior:smooth}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}}.app.loading{opacity:0}.app.transitioning{pointer-events:none}.main-content>div{width:100%}.main-content section{will-change:opacity,transform;transform:translateZ(0);backface-visibility:hidden}body{position:relative;overflow:hidden}.transitioning{overflow:hidden}
