.back-to-top{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;z-index:1000;opacity:0;visibility:hidden;background:#0f0f14e6;border:none;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;bottom:32px;right:32px;transform:translateY(20px)scale(.9);box-shadow:0 4px 20px #0006,0 0 0 1px #ffffff1a}.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)scale(1)}.back-to-top:hover{background:#9bdcff1f;transform:translateY(-4px)scale(1.05);box-shadow:0 8px 30px #0000005c,0 0 0 1px #9bdcff4d}.back-to-top:active{transform:translateY(0)scale(.95)}.progress-ring{width:100%;height:100%;position:absolute;transform:rotate(-90deg)}.progress-ring-bg{stroke:#ffffff1a}.progress-ring-fill{stroke:var(--accent-color);transition:stroke-dasharray .15s}.arrow-icon{color:#ffffffe6;z-index:1;width:22px;height:22px;transition:all .3s;position:relative}.back-to-top:hover .arrow-icon{color:#fff;transform:translateY(-2px)}@media (width<=768px){.back-to-top{width:46px;height:46px;bottom:24px;right:24px}.arrow-icon{width:20px;height:20px}}@media (width<=480px){.back-to-top{width:44px;height:44px;bottom:20px;right:20px}.arrow-icon{width:18px;height:18px}}@media (prefers-reduced-motion:reduce){.back-to-top{transition:opacity .3s;transform:none}.back-to-top.visible,.back-to-top:hover,.back-to-top:hover .arrow-icon{transform:none}}.footer{border-top:1px solid var(--border-color);background:#07090b;padding:4rem 0 2rem;position:relative}.footer:before{content:"";background:linear-gradient(90deg, transparent 0%, var(--accent-color) 50%, transparent 100%);opacity:.45;height:2px;position:absolute;top:-1px;left:0;right:0}.footer-content{justify-content:space-between;align-items:flex-start;gap:3rem;margin-bottom:3rem;display:flex}.footer-info h3{color:var(--text-primary);margin-bottom:1rem;font-size:1.5rem;font-weight:600}.footer-info p{color:var(--text-secondary);max-width:400px;line-height:1.6}.footer-links{flex-direction:column;gap:1rem;display:flex}.footer-link{color:var(--text-secondary);transition:var(--transition);border-radius:8px;align-items:center;gap:1rem;padding:.5rem;text-decoration:none;display:flex}.footer-link:hover{color:var(--accent-color);background:#9bdcff14}.footer-bottom{text-align:center;border-top:1px solid var(--border-color);color:var(--text-muted);padding-top:2rem;font-size:.875rem}@media (width<=768px){.footer-content{text-align:center;flex-direction:column;gap:2rem}.footer-links{flex-flow:wrap;justify-content:center}}.error-boundary-fallback{z-index:1;background:#050607;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:absolute;top:0;left:0}.error-message{text-align:center;border-radius:var(--border-radius);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);max-width:500px;box-shadow:var(--shadow-lg);background:#111111e6;padding:2rem}.error-icon{width:3rem;height:3rem;margin-bottom:1rem;animation:2s infinite pulse}@media (prefers-reduced-motion:reduce){.error-icon{animation:none}}.error-message h3{color:var(--text-primary);margin-bottom:1rem;font-size:1.5rem;font-weight:600}.error-message p{color:var(--text-secondary);margin-bottom:1rem;line-height:1.6}.error-message ul{text-align:left;color:var(--text-secondary);margin:1rem 0;padding-left:1.5rem}.error-message li{margin-bottom:.5rem}.error-details{text-align:left;margin-top:1.5rem}.error-details summary{color:var(--accent-color);cursor:pointer;transition:var(--transition);border-radius:4px;padding:.5rem}.error-details summary:hover{background:#9bdcff14}.error-details pre{background:var(--primary-bg);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:4px;margin-top:.5rem;padding:1rem;font-size:.875rem;overflow-x:auto}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@media (width<=768px){.error-message{max-width:90%;padding:1.5rem}.error-icon{width:2.5rem;height:2.5rem}.error-message h3{font-size:1.25rem}}.hero-section{contain:layout style paint;background-color:#050607;background-image:linear-gradient(#ffffff09 1px,#0000 1px),linear-gradient(90deg,#ffffff09 1px,#0000 1px);background-position:0 0;background-repeat:repeat;background-size:72px 72px;background-attachment:scroll;background-origin:padding-box;background-clip:border-box;justify-content:center;align-items:center;width:100%;height:100vh;display:flex;position:relative;overflow:hidden}.hero-canvas{pointer-events:none;will-change:auto;contain:strict;z-index:1!important;width:100%!important;height:100%!important;position:absolute!important;top:0!important;left:0!important}.hero-fallback-bg{z-index:0;background:linear-gradient(#0506079e,#050607f0),#050607;width:100%;height:100%;position:absolute;top:0;left:0}.hero-content{z-index:2;text-align:center;flex-direction:column;justify-content:center;align-items:center;max-width:1120px;height:100%;padding:0 2rem;display:flex;position:relative}.hero-text{margin-bottom:3rem}.hero-greeting{color:var(--text-secondary);letter-spacing:.08em;text-transform:uppercase;opacity:1;margin-bottom:.85rem;font-size:.9rem;font-weight:600;transform:translateY(0)}.hero-name{color:var(--text-primary);text-shadow:0 28px 80px #00000094;white-space:nowrap;opacity:1;margin-bottom:1.1rem;font-size:clamp(3rem,7vw,5.8rem);font-weight:760;transform:translateY(0)}.hero-subtitle{color:var(--accent-color);opacity:1;justify-content:center;align-items:center;height:2rem;min-height:2rem;margin-bottom:1.25rem;font-size:clamp(1rem,3vw,1.35rem);font-weight:650;display:flex;transform:translateY(0)}.hero-title{color:var(--accent-color);position:relative}.hero-description{color:var(--text-secondary);opacity:1;max-width:640px;margin:0 auto;font-size:1.1rem;line-height:1.6;transform:translateY(0)}.hero-cta-container{opacity:1;flex-wrap:wrap;justify-content:center;gap:16px;margin-top:2rem;display:flex;transform:translateY(0)}.hero-cta{cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:14px 28px;font-size:1rem;font-weight:600;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex;position:relative;overflow:hidden}.hero-cta-primary{background:var(--gradient-accent);color:#04161f;box-shadow:0 18px 50px #00000047, 0 8px 30px -8px var(--glow-accent);border:none}.hero-cta-primary:before{content:"";pointer-events:none;background:linear-gradient(100deg,#0000 40%,#ffffff73 50%,#0000 60%);transition:transform .6s cubic-bezier(.4,0,.2,1);position:absolute;inset:0;transform:translate(-120%)}.hero-cta-primary>*{z-index:1;position:relative}.hero-cta-primary:hover{box-shadow:0 24px 70px #00000061, 0 12px 40px -8px var(--glow-accent);transform:translateY(-3px)}.hero-cta-primary:hover:before{transform:translate(120%)}.hero-cta-secondary{color:var(--text-primary);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff0b;border:1px solid #ffffff29}.hero-cta-secondary:hover{background:#ffffff14;border-color:#9bdcff6b;transform:translateY(-3px)}.cta-icon{width:18px;height:18px;transition:transform .3s}.hero-cta:hover .cta-icon{transform:translate(4px)}@media (width<=768px){.hero-content{padding:0 1.5rem}.hero-greeting{font-size:1.2rem}.hero-name{white-space:normal;margin-bottom:.8rem;font-size:clamp(2.5rem,12vw,4rem)}.hero-subtitle{height:2rem;min-height:2rem;margin-bottom:1rem;font-size:clamp(1rem,6vw,1.4rem)}.hero-description{font-size:1rem;line-height:1.5}.hero-cta-container{gap:12px;margin-top:1.5rem}.hero-cta{padding:12px 20px;font-size:.9rem}.cta-icon{width:16px;height:16px}}@media (prefers-contrast:high){.hero-name{-webkit-text-fill-color:var(--text-primary);background:0 0}}@media (prefers-reduced-motion:reduce){.hero-greeting,.hero-name,.hero-subtitle,.hero-description{opacity:1;animation:none;transform:none}.hero-name{animation:none}.hero-cta,.cta-icon{transition:none}.hero-cta-primary:hover,.hero-cta-secondary:hover,.hero-cta:hover .cta-icon{transform:none}.hero-cta-primary:before{display:none}}@media (width<=480px) and (-webkit-device-pixel-ratio<=2){.hero-name{animation:none}}.macos-apps-section{background:#050607;min-height:auto;padding:6rem 2rem;position:relative;overflow:hidden}.macos-apps-section:before{content:"";z-index:0;pointer-events:none;background:radial-gradient(70% 50% at 50% 100%,#b8f3d00d,#0000 70%);position:absolute;inset:0}.macos-apps-container{z-index:2;max-width:1000px;margin:0 auto;position:relative}.macos-apps-header{text-align:center;margin-bottom:3rem}.macos-badge{color:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.5rem 1rem;font-size:.85rem;font-weight:500;display:inline-flex}.macos-badge svg{color:#a8a8a8}.macos-apps-title{color:var(--text-primary);margin-bottom:.75rem;font-size:clamp(2rem,5vw,3rem);font-weight:760}.macos-apps-subtitle{color:var(--text-secondary);max-width:400px;margin:0 auto;font-size:1.1rem;font-weight:400}.macos-apps-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:3rem;display:grid}.macos-app-card{background:var(--card-bg);text-align:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid #ffffff0f;border-radius:8px;padding:2rem 1.5rem;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.macos-app-card:before{content:none}.macos-app-card:hover{border-color:#ffffff1f;transform:translateY(-8px);box-shadow:0 20px 40px -10px #00000080,0 0 60px -20px #64646426}.app-icon-wrapper{background:#ffffff0d;border-radius:8px;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 1.25rem;transition:transform .3s;display:flex;overflow:hidden}.macos-app-card:hover .app-icon-wrapper{transform:scale(1.05)}.app-icon{object-fit:cover;border-radius:8px;width:100%;height:100%}.app-icon-placeholder{color:#ffffff4d}.app-name{color:#fff;letter-spacing:-.01em;margin-bottom:.5rem;font-size:1.15rem;font-weight:600}.app-description{color:var(--text-secondary);margin-bottom:1rem;font-size:.85rem;line-height:1.5}.app-links{flex-wrap:wrap;justify-content:center;gap:.5rem;display:flex}.app-link{color:#ffffff80;background:#ffffff0d;border:1px solid #ffffff14;border-radius:8px;align-items:center;gap:.4rem;padding:.4rem .8rem;font-size:.8rem;font-weight:500;text-decoration:none;transition:all .25s;display:inline-flex}.app-link:hover{color:#fff;background:#ffffff1a;border-color:#ffffff26}.app-demo-link{color:var(--accent-color);background:#9bdcff14;border-color:#9bdcff38}.app-demo-link:hover{color:var(--accent-color);background:#9bdcff24;border-color:#9bdcff61}.macos-apps-cta{text-align:center}.macos-apps-link{color:#000;background:var(--text-primary);border:none;border-radius:8px;align-items:center;gap:.75rem;padding:1rem 2rem;font-size:1rem;font-weight:600;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex;box-shadow:0 4px 15px #ffffff26,0 1px 3px #0000001a}.macos-apps-link:hover{transform:translateY(-2px);box-shadow:0 8px 25px #fff3,0 2px 8px #00000026}.macos-apps-link:active{transform:translateY(0)}@media (width<=768px){.macos-apps-section{padding:4rem 1.5rem}.macos-apps-grid{grid-template-columns:1fr;gap:1rem}.macos-app-card{padding:1.5rem 1.25rem}.app-icon-wrapper{width:64px;height:64px}.macos-apps-title{font-size:2rem}.macos-apps-link{justify-content:center;width:100%;padding:1rem 1.5rem}}@media (width<=480px){.macos-apps-header{margin-bottom:2rem}.macos-badge{padding:.4rem .8rem;font-size:.8rem}.macos-apps-subtitle{font-size:1rem}}@media (prefers-reduced-motion:reduce){.macos-app-card,.macos-apps-link,.app-icon-wrapper{transition:none}.macos-app-card:hover{transform:none}}.navbar{--nav-bg-alpha:.2;--nav-blur:10px;--nav-border-alpha:.05;z-index:1000;background:rgba(10, 10, 10, var(--nav-bg-alpha));-webkit-backdrop-filter:blur(var(--nav-blur));backdrop-filter:blur(var(--nav-blur));border-bottom:1px solid rgba(255, 255, 255, var(--nav-border-alpha));transition:transform var(--motion-dur-micro,.35s) var(--motion-ease-out,ease-out), opacity var(--motion-dur-micro,.35s) var(--motion-ease-out,ease-out);will-change:transform, opacity;position:fixed;top:0;left:0;right:0}.navbar.scrolled{--nav-bg-alpha:.7;--nav-blur:20px;--nav-border-alpha:.1}.navbar-container{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex}.logo-button{color:var(--text-primary);cursor:pointer;transition:var(--transition-fast);will-change:transform;background:0 0;border:none;border-radius:4px;padding:.5rem;font-size:1.25rem;font-weight:700}.logo-button:hover,.logo-button:focus-visible{outline:2px solid var(--accent-color);outline-offset:2px;transform:scale(1.05)}.logo-button:focus:not(:focus-visible){outline:none}.logo-button:active{outline:none;transform:scale(1)}.navbar-links.desktop-nav{align-items:center;gap:2rem;margin:0;padding:0;list-style:none;display:flex}.nav-link{color:var(--text-secondary);cursor:pointer;transition:var(--transition-fast);will-change:transform, color, background;background:0 0;border:none;border-radius:8px;padding:.5rem 1rem;font-size:.9rem;font-weight:500;position:relative}.nav-link:hover,.nav-link:focus-visible{color:var(--text-primary);outline:2px solid var(--accent-color);outline-offset:2px;background:#ffffff0f;transform:translateY(-2px)}.nav-link:focus:not(:focus-visible){outline:none}.nav-link:active{outline:none;transform:translateY(0)}.nav-link.active{color:var(--accent-color)}.nav-dropdown-wrapper{position:relative}.nav-dropdown-trigger{align-items:center;gap:.35rem;display:flex}.dropdown-chevron{opacity:.7;transition:transform .25s cubic-bezier(.4,0,.2,1)}.dropdown-chevron.rotated{transform:rotate(180deg)}.nav-dropdown-trigger:hover .dropdown-chevron,.nav-dropdown-trigger.open .dropdown-chevron{opacity:1}.nav-dropdown{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);opacity:0;visibility:hidden;z-index:100;background:#0c0f12fa;border:1px solid #ffffff14;border-radius:8px;min-width:240px;padding:.5rem;transition:all .25s cubic-bezier(.4,0,.2,1);position:absolute;top:calc(100% + .75rem);left:50%;transform:translate(-50%)translateY(-10px);box-shadow:0 20px 40px -10px #00000080,0 0 0 1px #ffffff0d}.nav-dropdown:before{content:"";background:#0c0f12fa;border-top:1px solid #ffffff14;border-left:1px solid #ffffff14;border-radius:2px 0 0;width:12px;height:12px;position:absolute;top:-6px;left:50%;transform:translate(-50%)rotate(45deg)}.nav-dropdown.open{opacity:1;visibility:visible;transform:translate(-50%)translateY(0)}.nav-dropdown-content{flex-direction:column;gap:.25rem;display:flex}.nav-dropdown-item{cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:.75rem;width:100%;padding:.875rem 1rem;transition:all .2s;display:flex}.nav-dropdown-item:hover,.nav-dropdown-item:focus-visible{background:#ffffff0f;outline:none}.nav-dropdown-item.active{background:#9bdcff1a}.dropdown-item-icon{color:#ffffff80;background:#ffffff0d;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;transition:color .2s;display:flex}.nav-dropdown-item:hover .dropdown-item-icon,.nav-dropdown-item.active .dropdown-item-icon{color:var(--accent-color)}.dropdown-item-text{flex-direction:column;gap:.15rem;display:flex}.dropdown-item-label{color:#fff;font-size:.9rem;font-weight:500}.dropdown-item-desc{color:#ffffff73;font-size:.75rem}.nav-dropdown-item:hover .dropdown-item-label,.nav-dropdown-item.active .dropdown-item-label{color:var(--accent-color)}.hamburger-btn{cursor:pointer;z-index:1002;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:44px;height:44px;transition:all .3s;display:none}.hamburger-btn:hover{background:#ffffff1a;border-color:#fff3}.hamburger-line{transform-origin:50%;background:#fff;border-radius:2px;width:22px;height:2px;transition:all .3s cubic-bezier(.4,0,.2,1)}.hamburger-btn.open .hamburger-line:first-child{transform:translateY(7px)rotate(45deg)}.hamburger-btn.open .hamburger-line:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger-btn.open .hamburger-line:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.mobile-menu-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;z-index:999;background:#0009;transition:opacity .3s;display:none;position:fixed;inset:0}.mobile-menu-overlay.open{opacity:1;pointer-events:auto}.mobile-nav{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:1001;background:#090c0ffa;border-left:1px solid #ffffff1a;width:280px;height:100vh;padding-top:100px;transition:right .4s cubic-bezier(.4,0,.2,1);display:none;position:fixed;top:0;right:-100%}.mobile-nav.open{right:0}.mobile-nav-links{flex-direction:column;gap:8px;margin:0;padding:0 24px;list-style:none;display:flex}.mobile-nav-links li{opacity:0;transition:all .3s;transition-delay:var(--delay);transform:translate(20px)}.mobile-nav.open .mobile-nav-links li{opacity:1;transform:translate(0)}.mobile-nav-link{color:#fffc;text-align:left;cursor:pointer;background:#ffffff08;border:1px solid #ffffff0f;border-radius:12px;width:100%;padding:16px 20px;font-size:1rem;font-weight:500;transition:all .3s;display:block}.mobile-nav-link:hover,.mobile-nav-link:focus{color:#fff;background:#3b82f61a;border-color:#3b82f64d;outline:none;transform:translate(8px)}.mobile-nav-link.active{color:#fff;background:#9bdcff1f;border-color:#9bdcff66}.mobile-nav-link.active:before{content:"";background:var(--accent-color);border-radius:0 2px 2px 0;width:3px;height:60%;position:absolute;top:50%;left:0;transform:translateY(-50%)}.mobile-work-section{flex-direction:column;gap:.75rem;margin:.5rem 0;display:flex}.mobile-section-label{text-transform:uppercase;letter-spacing:.15em;color:#ffffff4d;margin-bottom:-.25rem;padding:0 .75rem;font-size:.65rem;font-weight:600}.mobile-work-items{background:#ffffff08;border:1px solid #ffffff0a;border-radius:8px;flex-direction:column;gap:.5rem;margin-left:.5rem;padding:.75rem .75rem .75rem 1.25rem;display:flex;position:relative}.mobile-work-items:before{content:"";background:var(--accent-color);border-radius:0 3px 3px 0;width:3px;position:absolute;top:1rem;bottom:1rem;left:0}.mobile-work-link{align-items:center;gap:.875rem;display:flex;border-radius:10px!important;padding:.875rem 1rem!important}.mobile-work-link .mobile-work-icon{color:#ffffff80;background:#ffffff0d;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:all .25s;display:flex}.mobile-work-link:hover .mobile-work-icon,.mobile-work-link.active .mobile-work-icon{color:var(--accent-color);background:#3b82f61a}@media (width<=768px){.navbar{background:#0a0a0a4d}.navbar-container{max-width:100%;padding:1rem 1.5rem}.logo-button{padding:.5rem;font-size:1.1rem}.navbar-links.desktop-nav{display:none}.hamburger-btn{display:flex}.mobile-menu-overlay{pointer-events:none;display:block}.mobile-nav{display:block}}@media (width<=480px){.navbar{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0a0a0a66}.navbar-container{padding:.875rem 1rem}.logo-button{font-size:1rem}.mobile-nav{width:100%;right:-100%}.hamburger-btn{width:40px;height:40px}.hamburger-line{width:20px}}@media (prefers-reduced-motion:reduce){.mobile-nav{transition:none}.mobile-nav-links li{opacity:1;transition:none;transform:none}.hamburger-line,.mobile-menu-overlay,.nav-dropdown,.dropdown-chevron{transition:none}}.lazy-image-container{border-radius:1rem;width:100%;height:100%;position:relative;overflow:hidden}.lazy-image{object-fit:cover;will-change:transform, opacity;border-radius:1rem;width:100%;height:100%;transition:transform .3s,opacity .4s ease-in-out}.lazy-image.loaded{opacity:1}.lazy-image.loading{opacity:0}.image-skeleton{background:#1a1a1a;border-radius:1rem;justify-content:center;align-items:center;width:100%;display:flex;position:relative;overflow:hidden}.skeleton-shimmer{background:linear-gradient(90deg,#1a1a1a 0%,#2a2a2a 50%,#1a1a1a 100%) 0 0/200% 100%;border-radius:1rem;justify-content:center;align-items:center;width:100%;height:100%;animation:2s ease-in-out infinite shimmer;display:flex}.skeleton-content{text-align:center;width:80%;padding:2rem}.skeleton-line{background:#ffffff1a;border-radius:.5rem;height:1rem;margin:.5rem 0}.skeleton-title{width:70%;height:1.5rem;margin:0 auto 1rem}.skeleton-subtitle{width:50%;height:1rem;margin:0 auto}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.image-error{color:#666;text-align:center;background:#1a1a1a;border-radius:1rem;flex-direction:column;justify-content:center;align-items:center;width:100%;display:flex}.error-content{padding:2rem}.error-icon{opacity:.5;width:3rem;height:3rem;margin-bottom:1rem}.error-content p{color:#888;margin:0;font-size:1rem}.project-lazy-image{width:100%;height:100%}.project-image .lazy-image-container{will-change:transform;border-radius:1rem;transition:transform .3s}.project-image:hover .lazy-image-container{transform:scale(1.02)}@media (width<=768px){.skeleton-content{padding:1rem}.skeleton-title{height:1.2rem}.skeleton-subtitle{height:.8rem}.error-icon{width:2rem;height:2rem}.error-content p{font-size:.9rem}}@media (prefers-reduced-motion:reduce){.projects-section{min-height:auto}.projects-header{height:auto;padding:6rem 2rem 2rem;position:relative}.projects-grid{height:auto;overflow:visible}.project-card{height:auto;padding:4rem 2rem;position:relative}}.projects-section{background:#050607;min-height:100vh;margin:0;padding:0;position:relative}.projects-header{text-align:center;z-index:2;will-change:transform, opacity;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100vh;padding:8rem 2rem 4rem;display:flex;position:absolute;top:0;left:0}.projects-header.hidden{pointer-events:none}.projects-header .section-title{color:var(--text-primary);margin-bottom:2rem;font-size:clamp(3rem,6vw,5rem);font-weight:760}.projects-header .section-subtitle{color:var(--text-secondary);max-width:600px;font-size:clamp(1.2rem,2.5vw,1.5rem);line-height:1.6}.projects-grid{height:100vh;position:relative;overflow:hidden}.project-card{z-index:1;will-change:transform, opacity;justify-content:center;align-items:center;width:100%;height:100vh;padding:5.5rem 2rem 4rem;display:flex;position:absolute;top:0;left:0;overflow:hidden}.project-card.hidden{pointer-events:none}.project-card:before{content:none}.project-content{grid-template-columns:1fr 1fr;align-items:center;gap:clamp(3rem,6vw,6rem);width:100%;max-width:1400px;height:auto;max-height:calc(100vh - 9.5rem);margin:0 auto;display:grid}.project-card.image-right .project-content{grid-template-areas:"info visual"}.project-card.image-right .project-info{grid-area:info}.project-card.image-right .project-visual{grid-area:visual}.project-card.image-left .project-content{grid-template-areas:"visual info"}.project-card.image-left .project-info{grid-area:info}.project-card.image-left .project-visual{grid-area:visual}.project-visual{width:100%;position:relative}.project-showcase{aspect-ratio:16/10;background:#0c1014;border:1px solid #ffffff14;border-radius:8px;width:100%;transition:all .6s;position:relative;overflow:hidden;box-shadow:0 20px 60px #00000057}.project-showcase:before{content:none}.project-card:hover .project-showcase{border-color:#9bdcff3d;transform:translateY(-10px);box-shadow:0 30px 80px #0000006b}.project-image{z-index:2;justify-content:center;align-items:center;width:100%;height:100%;padding:.85rem;transition:all .6s;display:flex;position:relative}.project-image.interactive{cursor:pointer}.project-showcase:has(.project-image.interactive){cursor:pointer}.project-image.interactive:after{content:"";opacity:0;pointer-events:none;background:#ffffff0d;border-radius:12px;transition:opacity .3s;position:absolute;inset:0}.project-image.interactive:hover:after{opacity:1}.project-image img{object-fit:cover;width:100%;height:100%;box-shadow:none;border-radius:6px;transition:transform .6s}.project-card:hover .project-image img{transform:scale(1.02)}.project-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);opacity:0;z-index:3;background:#0006;border-radius:12px;justify-content:center;align-items:center;transition:all .3s;display:flex;position:absolute;inset:0}.overlay-links{justify-content:center;align-items:center;gap:1.5rem;display:flex}.overlay-link{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff1a;border:2px solid #fff3;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;text-decoration:none;transition:all .3s;display:flex}.overlay-link:hover{background:#fff3;border-color:#fff6;transform:translateY(-2px)scale(1.05);box-shadow:0 8px 20px #0000004d}@media (width>=769px){.project-image.interactive:hover .project-overlay,.project-showcase:hover .project-overlay{opacity:1!important}.project-image.interactive:hover{transform:scale(1.02)}}@media (width<=768px){.project-image.overlay-active .project-overlay{opacity:1}.overlay-link{width:48px;height:48px}.overlay-links{gap:1rem}.project-image.overlay-active .project-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000004d}.project-image.overlay-active .overlay-link{background:#ffffff26;border-color:#ffffff4d}}.project-placeholder{color:#666;text-align:center;background:#11161b;border-radius:8px;justify-content:center;align-items:center;width:100%;height:100%;font-size:1.5rem;font-weight:600;display:flex}.project-info{z-index:1;flex-direction:column;gap:1.25rem;padding:0;display:flex;position:relative}.project-number{color:#ffffff08;z-index:0;margin-bottom:-1rem;font-family:Arial,sans-serif;font-size:5.5rem;font-weight:900;line-height:1;position:absolute;top:-1.5rem;left:-1rem}.project-title{color:var(--text-primary);margin:0;font-size:clamp(2rem,3.4vw,3rem);font-weight:700;line-height:1.2}.project-description{color:var(--text-secondary);max-width:500px;margin:0;font-size:clamp(1rem,1.45vw,1.12rem);line-height:1.55}.project-tech{flex-wrap:wrap;gap:.75rem;display:flex}.tech-tag{color:var(--text-primary);background:#ffffff0b;border:1px solid #ffffff1a;border-radius:8px;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .3s}.tech-tag:hover{background:#9bdcff1a;border-color:#9bdcff4d;transform:translateY(-2px)}.project-features{margin:.25rem 0 0}.features-title{color:#fff;opacity:.9;margin:0 0 1rem;font-size:1rem;font-weight:600}.features-list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.feature-item{color:silver;padding-left:1.5rem;font-size:.86rem;line-height:1.4;position:relative}.feature-item:before{content:"";background:var(--accent-color);border-radius:999px;width:.35rem;height:.35rem;position:absolute;top:.65rem;left:.15rem}.projects-empty{text-align:center;color:#888;padding:4rem 2rem}@media (width<=1024px){.project-content{gap:6rem}.project-card{padding:6rem 2rem}}@media (width<=768px){.projects-header{min-height:70vh;padding:4rem 1.5rem 2rem}.projects-header .section-title{margin-bottom:1.5rem;font-size:clamp(2.5rem,8vw,4rem)}.projects-header .section-subtitle{font-size:clamp(1rem,3vw,1.2rem)}.project-card{height:100vh;min-height:auto;padding:1.5rem 1rem}.project-content{text-align:center;grid-template-rows:1fr 40%;justify-content:center;align-items:center;gap:.5rem;height:100%;grid-template-columns:1fr!important;grid-template-areas:"info""visual"!important}.project-visual{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.project-showcase{aspect-ratio:16/10;width:100%;max-width:90%;max-height:35vh}.project-info{flex-shrink:0;justify-content:center;align-items:center;gap:1rem;padding:0 .5rem}.project-number{display:none}.project-title{margin-bottom:.75rem;font-size:clamp(1.8rem,5vw,2.5rem)}.project-description{max-width:100%;margin-bottom:1rem;font-size:clamp(.9rem,2.5vw,1.1rem);line-height:1.5}.project-tech{flex-wrap:wrap;justify-content:center;margin-bottom:1rem}.tech-tag{padding:.4rem .8rem;font-size:.8rem}.project-features{margin:0 0 1rem}.features-title{margin:0 0 .5rem;font-size:.95rem}.features-list{text-align:left;max-width:100%;margin:0 auto;font-size:.85rem}.project-image{padding:.5rem}}@media (width<=480px){.projects-header{min-height:60vh;padding:3rem 1rem 1.5rem}.projects-header .section-title{margin-bottom:1rem;font-size:clamp(2rem,10vw,3rem)}.projects-header .section-subtitle{font-size:clamp(.9rem,4vw,1.1rem)}.project-card{height:100vh;min-height:auto;padding:1rem .75rem}.project-content{grid-template-rows:auto auto;justify-content:center;align-items:center;row-gap:2rem;height:100%;padding-top:3rem}.project-showcase{aspect-ratio:16/10;max-width:95%;max-height:30vh}.project-visual{flex-direction:column;justify-content:flex-start;align-items:center;width:100%;height:100%;display:flex}.project-info{flex-direction:column;flex-shrink:0;justify-content:flex-end;align-items:center;gap:.75rem;height:100%;padding:0 .25rem}.project-number{display:none}.project-title{margin-bottom:.5rem;font-size:clamp(1.4rem,6vw,1.8rem)}.project-description{margin-bottom:.75rem;font-size:clamp(.8rem,3vw,.95rem);line-height:1.4}.project-tech{gap:.5rem;margin-bottom:.75rem}.tech-tag{padding:.3rem .6rem;font-size:.75rem}.project-features{margin:0 0 .5rem}.features-title{margin:0 0 .25rem;font-size:.85rem}.features-list{gap:.5rem;font-size:.75rem}.project-image{padding:.25rem}}@media (prefers-reduced-motion:reduce){.project-card,.project-image img,.tech-tag{transition:none!important}.project-card:hover,.project-card:hover .project-image img,.tech-tag:hover{transform:none!important}}@media print{.projects-section{color:#000!important;background:#fff!important}.project-card{break-inside:avoid;margin-bottom:2rem;background:#fff!important;border:1px solid #ccc!important}.project-title{color:#000!important}.project-description{color:#333!important}}.scroll-progress-container{z-index:10001;pointer-events:none;background:0 0;height:3px;position:fixed;top:0;left:0;right:0}.scroll-progress-bar{background:var(--accent-color);height:100%;transition:width .1s ease-out;box-shadow:0 0 12px #9bdcff5c}@media (prefers-reduced-motion:reduce){.scroll-progress-bar{animation:none}}.skills-section{background:#060708;flex-direction:column;align-items:center;width:100%;min-height:auto;padding:120px 5%;scroll-margin-top:60px;display:flex;position:relative;overflow:hidden}.skills-section:before{content:"";z-index:0;pointer-events:none;background:radial-gradient(60% 60% at 50% 0,#9bdcff0f,#0000 70%);position:absolute;inset:0}.skills-anchor{width:1px;height:1px;scroll-margin-top:70px;position:absolute;top:0;left:0}.skills-header{text-align:center;z-index:2;margin-bottom:40px;position:relative}.skills-header .section-title{color:var(--text-primary);margin-bottom:16px;font-size:clamp(2.5rem,5vw,4rem);font-weight:760}.skills-header .section-subtitle{color:var(--text-secondary);max-width:500px;margin:0 auto;font-size:clamp(1rem,2vw,1.25rem);line-height:1.6}.skills-filter{z-index:1;flex-wrap:wrap;justify-content:center;gap:12px;margin-bottom:48px;display:flex;position:relative}.filter-btn{color:#ffffffb3;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;padding:10px 24px;font-size:.95rem;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1)}.filter-btn:hover{color:#fff;background:#ffffff1a;border-color:#fff3}.filter-btn.active{background:var(--text-primary);border-color:var(--text-primary);color:#050607;box-shadow:none}.skills-chips-grid{z-index:1;flex-wrap:wrap;justify-content:center;gap:16px;width:100%;max-width:900px;display:flex;position:relative}.skill-chip{cursor:default;background:#ffffff08;border:1px solid #ffffff14;border-radius:8px;align-items:center;gap:12px;padding:14px 24px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}@keyframes chipFadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.skill-chip:hover{border-color:var(--skill-color,#fff3);background:#ffffff14;transform:translateY(-4px);box-shadow:0 8px 25px #0000004d}.skill-chip-icon{width:28px;min-width:28px;height:28px;color:var(--skill-color,#fffc);justify-content:center;align-items:center;transition:all .3s;display:flex}.skill-chip-icon svg{width:100%;height:100%}.skill-chip:hover .skill-chip-icon{filter:drop-shadow(0 0 8px var(--skill-color));transform:scale(1.15)}.skill-chip-name{color:#ffffffe6;white-space:nowrap;font-size:.95rem;font-weight:500}.skill-chip:hover .skill-chip-name{color:#fff}@media (width<=768px){.skills-section{padding:80px 5%}.skills-anchor{scroll-margin-top:65px}.skills-header{margin-bottom:32px}.skills-filter{gap:8px;margin-bottom:32px}.filter-btn{padding:8px 18px;font-size:.85rem}.skills-chips-grid{gap:12px}.skill-chip{gap:10px;padding:12px 18px}.skill-chip-icon{width:24px;min-width:24px;height:24px}.skill-chip-name{font-size:.9rem}}@media (width<=480px){.skills-section{padding:40px 4%}.skills-anchor{top:0}.skills-header .section-title{font-size:2rem}.skills-header .section-subtitle{font-size:.95rem}.skills-filter{gap:6px}.filter-btn{padding:8px 14px;font-size:.8rem}.skills-chips-grid{gap:10px}.skill-chip{gap:8px;padding:10px 16px}.skill-chip-icon{width:20px;min-width:20px;height:20px}.skill-chip-name{font-size:.85rem}}@media (prefers-reduced-motion:reduce){.skill-chip{opacity:1;animation:none}.skill-chip:hover,.skill-chip:hover .skill-chip-icon{transform:none}}.timeline{background:var(--primary-bg);z-index:20;padding:8rem 0 12rem;position:relative}.timeline-container{max-width:800px;margin:0 auto;position:relative}.timeline-line{background:var(--accent-color);transform-origin:top;will-change:transform;width:2px;position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)scaleY(0)}.timeline-item{opacity:0;will-change:transform, opacity;width:50%;margin-bottom:4rem;position:relative;transform:translateY(50px)}.timeline-item.left{padding-right:2rem;left:0}.timeline-item.right{padding-left:2rem;left:50%}.timeline-dot{background:var(--accent-color);border:4px solid var(--primary-bg);z-index:2;border-radius:50%;width:16px;height:16px;position:absolute;top:1rem}.timeline-item.left .timeline-dot{right:-8px}.timeline-item.right .timeline-dot{left:-8px}.timeline-card{background:var(--card-bg);border:1px solid var(--border-color);transition:var(--transition);border-radius:8px;padding:2rem;position:relative}.timeline-card:hover{border-color:var(--accent-color);transform:translateY(-3px)}.timeline-date{color:var(--accent-color);align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.875rem;font-weight:600;display:flex}.timeline-title{color:var(--text-primary);margin-bottom:.5rem;font-size:1.25rem;font-weight:600}.timeline-company{color:var(--text-secondary);margin-bottom:.75rem;font-size:1rem;font-weight:500}.timeline-location{color:var(--text-muted);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.875rem;display:flex}.timeline-description{color:var(--text-secondary);line-height:1.6}@media (width<=768px){.timeline-container{padding-left:2rem}.timeline-line{left:1rem}.timeline-item{width:100%;padding-left:3rem!important;padding-right:0!important;left:0!important}.timeline-dot{left:5px!important;right:auto!important}}@media (width<=480px){.timeline-container{padding-left:1rem}.timeline-item{padding-left:2rem!important}.timeline-card{padding:1.5rem}.timeline{padding:4rem 0 8rem}}@media (prefers-reduced-motion:reduce){.timeline-line{transform:translate(-50%)scaleY(1)}.timeline-item{opacity:1;transform:none}}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/fonts/InterVariable.woff2)format("woff2")}@font-face{font-family:Inter;font-style:italic;font-weight:100 900;font-display:swap;src:url(/fonts/InterVariable-Italic.woff2)format("woff2")}:root{--primary-bg:#050607;--secondary-bg:#0b0e11;--accent-color:#9bdcff;--accent-hover:#b8f3d0;--accent-deep:#5fb3e6;--text-primary:#f6f8fb;--text-secondary:#c3c9d3;--text-muted:#8e96a3;--border-color:#20262d;--card-bg:#0d1115;--gradient-primary:var(--accent-color);--gradient-accent:linear-gradient(120deg, #9bdcff 0%, #b8f3d0 100%);--glow-accent:#9bdcff52;--font-family:"Inter", sans-serif;--transition:all .3s ease-out;--transition-fast:all .2s ease-out;--transition-slow:all .4s ease-out;--border-radius:12px;--shadow:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 20px 25px -5px #0000001a, 0 10px 10px -5px #0000000a;--navbar-height:80px;--animation-duration-fast:.2s;--animation-duration-normal:.3s;--animation-duration-slow:.5s;--animation-duration-hero:1s;--animation-duration-hero-long:1.2s;--animation-duration-hero-text:.8s;--animation-easing-power2:cubic-bezier(.25, .46, .45, .94);--animation-easing-power3:cubic-bezier(.215, .61, .355, 1);--animation-easing-back:cubic-bezier(.68, -.55, .265, 1.55);--animation-delay-stagger:.1s;--animation-delay-hero:.5s;--animation-distance-small:30px;--animation-distance-medium:50px;--animation-distance-large:60px;--animation-distance-dynamic:calc(50vh + var(--navbar-height) + 20px)}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-family);background-color:var(--primary-bg);color:var(--text-primary);text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;line-height:1.6;overflow-x:hidden}.loading{height:100vh;color:var(--text-secondary);background:var(--primary-bg);justify-content:center;align-items:center;font-size:1.2rem;display:flex}.loading:after{content:"";border:2px solid var(--accent-color);border-top:2px solid #0000;border-radius:50%;width:20px;height:20px;margin-left:10px;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.skip-link{background:var(--accent-color);color:#fff;z-index:10000;border-radius:4px;padding:8px;font-weight:600;text-decoration:none;transition:top .3s;position:absolute;top:-40px;left:6px}.skip-link:focus{top:6px}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}:focus-visible{outline:3px solid var(--accent-color);outline-offset:2px;border-radius:4px;transition:outline .2s}button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible,[role=button]:focus-visible,[tabindex]:focus-visible{outline:3px solid var(--accent-color);outline-offset:2px;box-shadow:0 0 0 6px #3b82f633}.project-image:focus-visible,.hero-section :focus-visible{outline:3px solid #fff;box-shadow:0 0 0 6px #ffffff4d}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}@media (prefers-contrast:high){:root{--text-primary:#fff;--text-secondary:#fff;--border-color:#fff;--accent-color:#0ff}}:root{--motion-ease-out:cubic-bezier(.16, 1, .3, 1);--motion-ease-inout:cubic-bezier(.65, 0, .35, 1);--motion-ease-out-gsap:expo.out;--motion-ease-inout-gsap:power2.inOut;--motion-dur-intro:1.05s;--motion-dur-enter:.7s;--motion-dur-micro:.35s;--motion-dur-stagger:60ms;--motion-opacity-boot:1;--motion-dist-boot-y:14px;--motion-dist-nav-y:-10px;--motion-dist-cta-y:12px;--motion-scale-boot:.99;--motion-scale-cta:.985;--motion-blur-boot:0px}html[data-app-state=boot] .navbar,html[data-app-state=enter] .navbar{opacity:var(--motion-opacity-boot);transform:translateY(var(--motion-dist-nav-y));will-change:transform, opacity}html[data-app-state=boot] .hero-greeting,html[data-app-state=enter] .hero-greeting,html[data-app-state=boot] .hero-name,html[data-app-state=enter] .hero-name,html[data-app-state=boot] .hero-subtitle,html[data-app-state=enter] .hero-subtitle,html[data-app-state=boot] .hero-description,html[data-app-state=enter] .hero-description{opacity:var(--motion-opacity-boot);transform:translateY(var(--motion-dist-boot-y)) scale(var(--motion-scale-boot));filter:blur(var(--motion-blur-boot));will-change:transform, opacity, filter}html[data-app-state=boot] .hero-cta-container,html[data-app-state=enter] .hero-cta-container{opacity:0;transform:translateY(var(--motion-dist-cta-y)) scale(var(--motion-scale-cta));will-change:transform, opacity}.hero-canvas{opacity:0}.hero-fallback-bg{opacity:1}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}html[data-app-state] .navbar,html[data-app-state] .hero-greeting,html[data-app-state] .hero-name,html[data-app-state] .hero-subtitle,html[data-app-state] .hero-description,html[data-app-state] .hero-cta-container{opacity:1!important;filter:none!important;will-change:auto!important;transform:none!important}.scroll-indicator{animation:none!important}}.container{max-width:1200px;margin:0 auto;padding:0 2rem}.section-title{text-align:center;color:var(--text-primary);margin-bottom:4rem;font-size:clamp(2.5rem,5vw,4rem);font-weight:760}.section-title:after{content:"";background:var(--gradient-accent);border-radius:2px;width:56px;height:3px;margin:1rem auto 0;display:block}@media (width<=768px){.container{padding:0 1rem}}.scroll-indicator{color:var(--accent-color);cursor:pointer;z-index:9999;pointer-events:auto;text-align:center;transition:var(--transition);will-change:transform;transform-origin:bottom;flex-direction:column;align-items:center;animation:2.5s cubic-bezier(.25,.46,.45,.94) infinite smoothBounce;display:flex;position:absolute;bottom:3rem;left:50%;transform:translate(-50%)}.scroll-indicator:hover{color:var(--accent-hover);filter:drop-shadow(0 4px 8px #3b82f64d);animation-play-state:paused;transform:scale(1.15)translate(-50%)translateY(-3px)}.scroll-arrow{flex-direction:column;align-items:center;gap:.5rem;display:flex}.scroll-arrow span{opacity:.8;font-size:.9rem;font-weight:500}.chevron-down{font-size:1.5rem;font-weight:700}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes smoothBounce{0%,to{animation-timing-function:cubic-bezier(.25,.46,.45,.94);transform:translateY(0)scale(1)}25%{animation-timing-function:cubic-bezier(.215,.61,.355,1);transform:translateY(-8px)scale(1.05)}50%{animation-timing-function:cubic-bezier(.55,.055,.675,.19);transform:translateY(-12px)scale(1.1)}75%{animation-timing-function:cubic-bezier(.25,.46,.45,.94);transform:translateY(-6px)scale(1.02)}}
