*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--color-primary:#87b0ae;--color-primary-hover:#87b0ae;--color-text-primary:#1d1d1f;--color-text-secondary:#86868b;--color-text-light:#f5f5f7;--color-background-light:#fff;--color-background-dark:#000;--color-background-secondary:#f5f5f7;--color-background-tertiary:#fafafa;--color-border:#e5e5e7;--color-shadow:#0000001a;--color-shadow-hover:#00000026;--font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-weight-light:300;--font-weight-regular:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--spacing-xs:0.5rem;--spacing-sm:1rem;--spacing-md:2rem;--spacing-lg:4rem;--spacing-xl:6rem;--spacing-2xl:8rem;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--transition-fast:0.2s ease-out;--transition-medium:0.3s ease-out;--transition-slow:0.5s ease-out;--shadow-sm:0 1px 3px #0000001a;--shadow-md:0 4px 12px #0000001a;--shadow-lg:0 8px 24px #0000001f;--shadow-hover:0 8px 32px #00000026}html{font-size:16px;scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;background-color:var(--color-background-light);color:#1d1d1f;color:var(--color-text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);font-weight:400;font-weight:var(--font-weight-regular);line-height:1.6}h1,h2,h3,h4,h5,h6{font-weight:600;font-weight:var(--font-weight-semibold);line-height:1.2;margin-bottom:1rem;margin-bottom:var(--spacing-sm)}h1{font-size:clamp(2.5rem,5vw,4rem)}h2{font-size:clamp(2rem,4vw,3rem)}h3{font-size:clamp(1.5rem,3vw,2rem)}h4{font-size:1.25rem}h5{font-size:1.125rem}h6{font-size:1rem}p{color:#86868b;color:var(--color-text-secondary);line-height:1.7;margin-bottom:1rem;margin-bottom:var(--spacing-sm)}.container{margin:0 auto;max-width:1200px;padding:0 2rem;padding:0 var(--spacing-md)}.nav{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#fffffff2;border-right:1px solid #e5e5e7;border-right:1px solid var(--color-border);height:100vh;left:0;overflow-x:hidden;overflow-y:auto;position:fixed;top:0;transform:translateX(0);transition:transform .3s ease-out,background .4s ease,border-color .4s ease;transition:transform var(--transition-medium),background .4s ease,border-color .4s ease;width:280px;z-index:1000}.nav.collapsed{backdrop-filter:blur(25px);-webkit-backdrop-filter:blur(25px);background:#ffffffb3;border-right:1px solid #ffffff4d;transform:translateX(-200px)}.nav-light{background:#fffffff2;border-right:1px solid #e5e5e7;border-right:1px solid var(--color-border)}.nav-light.collapsed{background:#ffffffb3;border-right:1px solid #ffffff4d}.nav-dark,.nav-dark.collapsed{background:#000;border-right:1px solid #ffffff1a}.nav-dark .nav-footer-text,.nav-dark .nav-link,.nav-dark .nav-profile-name{color:#ffffffe6}.nav-dark .nav-link:not(.active),.nav-dark .nav-profile-role{color:#fff9}.nav-dark .nav-link:hover{background:#ffffff1a;color:#ffffffe6}.nav-dark .nav-toggle{color:#fff9}.nav-dark .nav-toggle:hover{background:#ffffff1a;color:#ffffffe6}.nav-dark .nav-logo{border:2px solid #fff3}.nav-container{display:flex;flex-direction:column;height:100%;padding:2rem;padding:var(--spacing-md)}.nav-header{align-items:center;border-bottom:1px solid #e5e5e7;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;margin-bottom:4rem;margin-bottom:var(--spacing-lg);padding-bottom:2rem;padding-bottom:var(--spacing-md)}.nav-header.collapsed{border-bottom:none}.nav-profile{align-items:center;display:flex;gap:1rem;gap:var(--spacing-sm);transition:opacity .2s ease-out;transition:opacity var(--transition-fast)}.nav-logo{border:2px solid #e5e5e7;border:2px solid var(--color-border);height:40px;object-fit:cover;transition:border-color .4s ease;width:40px}.nav-profile-info{display:flex;flex-direction:column}.nav-profile-name{color:#1d1d1f;color:var(--color-text-primary);font-size:.875rem;font-weight:600;font-weight:var(--font-weight-semibold)}.nav-profile-name,.nav-profile-role{line-height:1.2;transition:color .4s ease}.nav-profile-role{font-size:.75rem}.nav-profile-role,.nav-toggle{color:#86868b;color:var(--color-text-secondary)}.nav-toggle{align-items:center;background:none;border:none;border-radius:8px;border-radius:var(--radius-sm);cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s ease-out,color .4s ease;transition:all var(--transition-fast),color .4s ease;width:32px}.nav-toggle:hover{color:#1d1d1f;color:var(--color-text-primary)}.nav-toggle-icon{height:20px;transition:transform .2s ease-out;transition:transform var(--transition-fast);width:20px}.nav.collapsed .nav-toggle-icon{transform:rotate(180deg)}.nav-links{display:flex;flex-direction:column;flex-grow:1;gap:4px;list-style:none}.nav-link{align-items:center;background:none;border:none;border-radius:8px;border-radius:var(--radius-sm);color:#86868b;color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;font-weight:var(--font-weight-medium);gap:1rem;gap:var(--spacing-sm);padding:10px 12px;position:relative;text-align:left;text-decoration:none;transition:all .2s ease-out,color .4s ease;transition:all var(--transition-fast),color .4s ease;width:100%}.nav-link:hover{background:#f5f5f7;background:var(--color-background-secondary);color:#1d1d1f;color:var(--color-text-primary)}.nav-link.active{background:#87b0ae;background:var(--color-primary);color:#fff}.nav-link-icon{flex-shrink:0;height:16px;width:16px}.nav-link-text{transition:opacity .2s ease-out;transition:opacity var(--transition-fast)}.nav.collapsed .nav-link-text,.nav.collapsed .nav-profile-info{opacity:0;pointer-events:none}.nav.collapsed .nav-profile{justify-content:center}.nav.collapsed .nav-link{justify-content:center;padding:10px}.main-content{margin-left:280px;transition:margin-left .3s ease-out;transition:margin-left var(--transition-medium)}.nav.collapsed+.main-content{margin-left:40px}.nav-overlay{background:#00000080;height:100%;left:0;opacity:0;position:fixed;top:0;transition:all .3s ease-out;transition:all var(--transition-medium);visibility:hidden;width:100%;z-index:999}.nav-overlay.active{opacity:1;visibility:visible}.mobile-nav-toggle{align-items:center;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#ffffffe6;border:1px solid #e5e5e7;border:1px solid var(--color-border);border-radius:12px;border-radius:var(--radius-md);box-shadow:0 4px 20px #0000001a;cursor:pointer;display:none;height:44px;justify-content:center;left:2rem;left:var(--spacing-md);position:fixed;top:max(env(safe-area-inset-top),2rem);top:max(env(safe-area-inset-top),var(--spacing-md));transition:all .2s ease-out;transition:all var(--transition-fast);width:44px;z-index:1001}.mobile-nav-toggle:hover{box-shadow:0 6px 25px #00000026;transform:translateY(-1px)}.mobile-nav-backdrop{-webkit-overflow-scrolling:touch;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#0006;height:100%;left:0;overscroll-behavior:none;position:fixed;top:0;width:100%;z-index:999}.mobile-nav-dock{backdrop-filter:blur(25px);-webkit-backdrop-filter:blur(25px);background:#fffffff2;border-bottom:1px solid #0000001a;border-radius:0 0 20px 20px;box-shadow:0 10px 40px #00000026;left:0;min-height:env(safe-area-inset-top);padding:env(safe-area-inset-top,20px) 20px 30px;position:fixed;right:0;top:0;transform:translateZ(0);z-index:1000}.mobile-nav-profile{align-items:center;border-bottom:1px solid #0000001a;display:flex;gap:15px;margin-bottom:20px;padding:20px 0}.mobile-nav-avatar{border:2px solid #87b0ae;border:2px solid var(--color-primary);border-radius:50%;box-shadow:0 4px 15px #87b0ae4d;height:50px;object-fit:cover;width:50px}.mobile-nav-profile-info{flex:1 1}.mobile-nav-name{color:#1d1d1f;color:var(--color-text-primary);font-size:1.1rem;font-weight:600;font-weight:var(--font-weight-semibold);line-height:1.2;margin:0 0 4px}.mobile-nav-role{color:#86868b;color:var(--color-text-secondary);font-size:.9rem;line-height:1.2;margin:0}.mobile-nav-links{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.mobile-nav-link{align-items:center;background:none;border:none;border-radius:16px;color:#1d1d1f;color:var(--color-text-primary);cursor:pointer;display:flex;font-size:1rem;font-weight:500;font-weight:var(--font-weight-medium);gap:15px;overflow:hidden;padding:16px 20px;position:relative;text-align:left;transition:all .2s ease-out;transition:all var(--transition-fast);width:100%}.mobile-nav-link:hover{background:#0000000f;transform:translateY(-1px)}.mobile-nav-link.active{background:#87b0ae;background:var(--color-primary);box-shadow:0 4px 15px #87b0ae66;color:#fff}.mobile-nav-link-icon{flex-shrink:0;height:20px;width:20px}.mobile-nav-link-text{flex:1 1;font-weight:500;font-weight:var(--font-weight-medium)}.mobile-nav-link-indicator{background:#fff;border-radius:50%;box-shadow:0 2px 8px #0003;height:6px;position:absolute;right:16px;width:6px}.mobile-nav-footer{border-top:1px solid #0000001a;padding-top:15px;text-align:center}.mobile-nav-footer p{color:#86868b;color:var(--color-text-secondary);font-size:.8rem;font-weight:400;font-weight:var(--font-weight-regular);margin:0}.nav-footer{border-top:1px solid #e5e5e7;border-top:1px solid var(--color-border);margin-top:auto;padding-top:2rem;padding-top:var(--spacing-md)}.nav-footer.collapsed{border-top:none}.nav-footer-text{color:#86868b;color:var(--color-text-secondary);font-size:.75rem;text-align:center;transition:opacity .2s ease-out,color .4s ease;transition:opacity var(--transition-fast),color .4s ease}.nav.collapsed .nav-footer-text{opacity:0}.hero{align-items:center;background:linear-gradient(135deg,#fff,#f5f5f7);background:linear-gradient(135deg,var(--color-background-light) 0,var(--color-background-secondary) 100%);display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:8rem 2rem;padding:var(--spacing-2xl) var(--spacing-md);position:relative;text-align:center}.hero-content{margin:0 auto;max-width:800px}.hero-title{color:#1d1d1f;color:var(--color-text-primary);font-size:clamp(3rem,6vw,5rem);font-weight:700;font-weight:var(--font-weight-bold);line-height:1.1;margin-bottom:2rem;margin-bottom:var(--spacing-md)}.hero-title span{display:block}.hero-subtitle{color:#86868b;color:var(--color-text-secondary);font-size:1.5rem;margin-bottom:4rem;margin-bottom:var(--spacing-lg)}.hero-cta{display:flex;flex-wrap:wrap;gap:2rem;gap:var(--spacing-md);justify-content:center}.scroll-indicator{align-items:center;bottom:4rem;bottom:var(--spacing-lg);color:#86868b;color:var(--color-text-secondary);display:flex;flex-direction:column;font-size:.875rem;gap:.5rem;gap:var(--spacing-xs);position:absolute;text-align:center;transform:translateX(-50%)}.nav-logo{border-radius:50%;height:50px;width:50px}.mouse-icon{animation:mouseBob 2s ease-in-out infinite;color:#86868b;color:var(--color-text-secondary);cursor:pointer;height:25px;width:25px}@keyframes mouseBob{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.btn{align-items:center;border:none;border-radius:16px;border-radius:var(--radius-lg);cursor:pointer;display:inline-flex;font-size:1rem;font-weight:500;font-weight:var(--font-weight-medium);justify-content:center;overflow:hidden;padding:14px 28px;position:relative;text-decoration:none;transition:all .3s ease-out;transition:all var(--transition-medium)}.btn-primary{background:#87b0ae;background:var(--color-primary);box-shadow:0 4px 12px #0000001a;box-shadow:var(--shadow-md);color:#fff}.btn-primary:hover{background:#87b0ae;background:var(--color-primary-hover);box-shadow:0 8px 32px #00000026;box-shadow:var(--shadow-hover);transform:translateY(-2px)}.btn-secondary{background:#0000;border:2px solid #e5e5e7;border:2px solid var(--color-border);color:#1d1d1f;color:var(--color-text-primary)}.btn-secondary:hover{background:#1d1d1f;background:var(--color-text-primary);box-shadow:0 4px 12px #0000001a;box-shadow:var(--shadow-md);color:#fff;transform:translateY(-2px)}.section-header{margin-bottom:6rem;margin-bottom:var(--spacing-xl);margin-left:auto;margin-right:auto;max-width:600px;text-align:center}.section-title{color:#1d1d1f;color:var(--color-text-primary);font-size:clamp(2.5rem,4vw,3.5rem);font-weight:700;font-weight:var(--font-weight-bold);margin-bottom:2rem;margin-bottom:var(--spacing-md)}.section-subtitle{color:#86868b;color:var(--color-text-secondary);font-size:1.25rem;font-weight:400;font-weight:var(--font-weight-regular)}.about{background:#fff;background:var(--color-background-light);padding:8rem 0;padding:var(--spacing-2xl) 0}.about-content{grid-gap:6rem;grid-gap:var(--spacing-xl);align-items:center;display:grid;gap:6rem;gap:var(--spacing-xl);grid-template-columns:1fr 1fr}.about-description{font-size:1.125rem;line-height:1.8}.about-description,.about-skills h3{margin-bottom:2rem;margin-bottom:var(--spacing-md)}.about-skills h3{color:#1d1d1f;color:var(--color-text-primary)}.skills-grid{grid-gap:1rem;grid-gap:var(--spacing-sm);display:grid;gap:1rem;gap:var(--spacing-sm);grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.skill-item{background:#f5f5f7;background:var(--color-background-secondary);border-radius:12px;border-radius:var(--radius-md);color:#1d1d1f;color:var(--color-text-primary);font-weight:500;font-weight:var(--font-weight-medium);padding:1rem 2rem;padding:var(--spacing-sm) var(--spacing-md);text-align:center;transition:all .3s ease-out;transition:all var(--transition-medium)}.skill-item:hover{background:#87b0ae;background:var(--color-primary);box-shadow:0 4px 12px #0000001a;box-shadow:var(--shadow-md);color:#fff;transform:translateY(-2px)}.about-image,.image-placeholder{display:flex;justify-content:center}.image-placeholder{align-items:center;background:#f5f5f7;background:var(--color-background-secondary);border-radius:24px;border-radius:var(--radius-xl);box-shadow:0 8px 24px #0000001f;box-shadow:var(--shadow-lg);color:#86868b;color:var(--color-text-secondary);font-weight:500;font-weight:var(--font-weight-medium);height:400px;transition:transform .3s ease-out;transition:transform var(--transition-medium);width:300px}.image-placeholder:hover{transform:scale(1.02)}.profile-image{border-radius:24px;border-radius:var(--radius-xl);box-shadow:0 8px 24px #0000001f;box-shadow:var(--shadow-lg);height:400px;object-fit:cover;transition:transform .3s ease-out;transition:transform var(--transition-medium);width:300px}.profile-image:hover{transform:scale(1.02)}.projects{background:#000;background:var(--color-background-dark);padding:8rem 0;padding:var(--spacing-2xl) 0}.projects,.projects .section-title{color:#f5f5f7;color:var(--color-text-light)}.projects .section-subtitle{color:#ffffffb3}.projects-grid{grid-gap:4rem;grid-gap:var(--spacing-lg);display:grid;gap:4rem;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.project-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:24px;border-radius:var(--radius-xl);overflow:hidden;transition:all .3s ease-out;transition:all var(--transition-medium)}.project-card:hover{border-color:#fff3;box-shadow:0 20px 40px #0000004d;transform:translateY(-8px)}.project-image{background:#ffffff1a;color:#ffffffb3;height:200px;overflow:hidden;position:relative}.project-image,.project-overlay{align-items:center;display:flex;justify-content:center}.project-overlay{background:#000c;bottom:0;gap:2rem;gap:var(--spacing-md);left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease-out;transition:opacity var(--transition-medium)}.project-card:hover .project-overlay{opacity:1}.project-link{border:1px solid #fff;border-radius:8px;border-radius:var(--radius-sm);color:#fff;font-weight:500;font-weight:var(--font-weight-medium);padding:.5rem 2rem;padding:var(--spacing-xs) var(--spacing-md);text-decoration:none;transition:all .2s ease-out;transition:all var(--transition-fast)}.project-link:hover{background:#fff;color:#1d1d1f;color:var(--color-text-primary)}.project-content{padding:4rem;padding:var(--spacing-lg)}.project-title{color:#f5f5f7;color:var(--color-text-light);margin-bottom:1rem;margin-bottom:var(--spacing-sm)}.project-description{color:#fffc;line-height:1.6;margin-bottom:2rem;margin-bottom:var(--spacing-md)}.project-tags{display:flex;flex-wrap:wrap;gap:.5rem;gap:var(--spacing-xs)}.tag{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;border-radius:var(--radius-sm);color:#ffffffe6;font-size:.875rem;font-weight:500;font-weight:var(--font-weight-medium);padding:4px 12px}.experience{background:linear-gradient(180deg,#fff,#fafafa);background:linear-gradient(to bottom,var(--color-background-light),#fafafa);overflow:hidden;padding:8rem 0;padding:var(--spacing-2xl) 0;position:relative}.experience:before{background:linear-gradient(180deg,#0000,#fffc);content:"";height:120px;left:0;pointer-events:none;position:absolute;right:0;top:0}.timeline-wrapper{margin:0 auto;max-width:900px;padding:4rem 0;padding:var(--spacing-lg) 0;position:relative}.timeline{position:relative;z-index:2}.timeline-line{background:linear-gradient(180deg,#87b0ae4d 0,#87b0ae99 30%,#87b0aee6 60%,#87b0ae);border-radius:2px;bottom:0;left:28px;position:absolute;top:0;transform-origin:top}.timeline-item{margin-bottom:8rem;margin-bottom:var(--spacing-2xl);opacity:0;padding-left:6rem;padding-left:var(--spacing-xl);position:relative;transform:translateY(40px)}.timeline-item:last-child{margin-bottom:0}.timeline-dot{background:#1d1d1f;border:4px solid #fff;border:4px solid var(--color-background-light);border-radius:50%;box-shadow:0 4px 12px #00000026;height:20px;left:19px;position:absolute;top:0;transition:all .4s cubic-bezier(.25,.46,.45,.94);width:20px;z-index:3}.timeline-dot:hover{box-shadow:0 6px 20px #0003;transform:scale(1.2)}.timeline-content{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#fffffff2;border:1px solid #fff3;border-radius:24px;border-radius:var(--radius-xl);box-shadow:0 8px 32px #00000014;overflow:hidden;padding:2rem;padding:var(--spacing-md);position:relative;transition:all .4s cubic-bezier(.25,.46,.45,.94)}.timeline-content:before{background:linear-gradient(90deg,#0000,#87b0ae80,#0000);content:"";height:1px;left:0;position:absolute;right:0;top:0}.timeline-content:hover{border-color:#87b0ae4d;box-shadow:0 20px 60px #0000001f;transform:translateY(-8px) scale(1.02)}.timeline-header{align-items:flex-start;display:flex;gap:2rem;gap:var(--spacing-md);margin-bottom:4rem;margin-bottom:var(--spacing-lg);position:relative}.timeline-logo{border:2px solid #fffc;border-radius:12px;border-radius:var(--radius-md);box-shadow:0 4px 16px #0000001a;flex-shrink:0;height:64px;object-fit:cover;width:64px}.timeline-header-content{flex:1 1;min-width:0}.timeline-title{color:#1d1d1f;color:var(--color-text-primary);font-size:1.375rem;font-weight:600;font-weight:var(--font-weight-semibold);line-height:1.3}.timeline-company,.timeline-title{margin-bottom:.5rem;margin-bottom:var(--spacing-xs)}.timeline-company{color:#87b0ae;color:var(--color-primary);display:block;font-size:1rem;line-height:1.4}.timeline-company,.timeline-date{font-weight:500;font-weight:var(--font-weight-medium)}.timeline-date{background:#87b0ae1a;border:1px solid #87b0ae33;border-radius:20px;display:inline-block;font-size:.875rem;padding:4px 12px}.timeline-date,.timeline-description{color:#86868b;color:var(--color-text-secondary)}.timeline-description{font-size:1rem;line-height:1.6;margin-bottom:4rem;margin-bottom:var(--spacing-lg)}.timeline-description a{border-bottom:1px solid #87b0ae4d;color:#87b0ae;color:var(--color-primary);text-decoration:none;transition:all .2s ease}.timeline-description a:hover{border-bottom-color:#87b0ae;border-bottom-color:var(--color-primary);color:#1d1d1f;color:var(--color-text-primary)}.timeline-achievements{display:flex;flex-direction:column;gap:1rem;gap:var(--spacing-sm);list-style:none;margin:0;padding:0}.timeline-achievements li{color:#86868b;color:var(--color-text-secondary);cursor:default;font-size:.95rem;line-height:1.6;padding-left:2rem;padding-left:var(--spacing-md);position:relative;transition:all .2s ease}.timeline-achievements li:before{background:#87b0ae;background:var(--color-primary);border-radius:50%;content:"";height:6px;left:0;opacity:.7;position:absolute;top:10px;transition:all .2s ease;width:6px}.timeline-achievements li:hover{color:#1d1d1f;color:var(--color-text-primary);transform:translateX(4px)}.timeline-achievements li:hover:before{opacity:1;transform:scale(1.3)}@media (max-width:768px){.timeline-wrapper{max-width:100%;padding:2rem 0;padding:var(--spacing-md) 0}.timeline-line{left:20px}.timeline-item{margin-bottom:6rem;margin-bottom:var(--spacing-xl);padding-left:4rem;padding-left:var(--spacing-lg)}.timeline-dot{height:18px;left:11px;top:18px;width:18px}.timeline-content{border-radius:16px;border-radius:var(--radius-lg);padding:2rem;padding:var(--spacing-md)}.timeline-header{align-items:center;flex-direction:column;gap:1rem;gap:var(--spacing-sm);text-align:center}.timeline-logo{height:56px;width:56px}.timeline-title{font-size:1.25rem}.timeline-company{font-size:.95rem}.timeline-date{font-size:.8rem}.timeline-achievements li{font-size:.9rem;padding-left:2rem;padding-left:var(--spacing-md)}}@media (max-width:480px){.experience{padding:6rem 0;padding:var(--spacing-xl) 0}.timeline-item{padding-left:2rem;padding-left:var(--spacing-md)}.timeline-content{padding:1rem;padding:var(--spacing-sm)}.timeline-header{gap:.5rem;gap:var(--spacing-xs)}.timeline-logo{height:48px;width:48px}.timeline-title{font-size:1.125rem}.timeline-company{font-size:.9rem}.timeline-description{font-size:.95rem}.timeline-achievements li{font-size:.85rem}}@media (hover:none) and (pointer:coarse){.timeline-content:hover{box-shadow:0 8px 32px #00000014;transform:none}.timeline-achievements li:hover{color:#86868b;color:var(--color-text-secondary);transform:none}.timeline-dot:hover{transform:none}}@media (prefers-contrast:high){.timeline-content{background:#fff;background:var(--color-background-light);border:2px solid #e5e5e7;border:2px solid var(--color-border)}.timeline-line{background:#1d1d1f;background:var(--color-text-primary);opacity:1!important}.timeline-dot{border-color:#fff;border-color:var(--color-background-light);box-shadow:0 0 0 2px #1d1d1f;box-shadow:0 0 0 2px var(--color-text-primary)}}@media (prefers-reduced-motion:reduce){.timeline-achievements li,.timeline-content,.timeline-dot,.timeline-logo{transition:none}.timeline-achievements li:hover,.timeline-content:hover{transform:none}}.contact{background:#f5f5f7;background:var(--color-background-secondary);padding:8rem 0;padding:var(--spacing-2xl) 0}.contact-content{grid-gap:6rem;grid-gap:var(--spacing-xl);display:grid;gap:6rem;gap:var(--spacing-xl);grid-template-columns:1fr 1fr;margin:0 auto;max-width:900px}.contact-info h3{color:#1d1d1f;color:var(--color-text-primary);margin-bottom:2rem;margin-bottom:var(--spacing-md)}.contact-links{margin-top:4rem;margin-top:var(--spacing-lg)}.contact-link{align-items:center;color:#86868b;color:var(--color-text-secondary);display:flex;gap:1rem;gap:var(--spacing-sm);padding:1rem 0;padding:var(--spacing-sm) 0;text-decoration:none;transition:color .2s ease-out;transition:color var(--transition-fast)}.contact-link:hover{color:#87b0ae;color:var(--color-primary)}.contact-form{background:#fff;border-radius:24px;border-radius:var(--radius-xl);box-shadow:0 8px 24px #0000001f;box-shadow:var(--shadow-lg);padding:4rem;padding:var(--spacing-lg)}.form-group{margin-bottom:2rem;margin-bottom:var(--spacing-md)}.form-group label{color:#1d1d1f;color:var(--color-text-primary);display:block;font-weight:500;font-weight:var(--font-weight-medium);margin-bottom:.5rem;margin-bottom:var(--spacing-xs)}.form-group input,.form-group textarea{background:#fff;background:var(--color-background-light);border:2px solid #e5e5e7;border:2px solid var(--color-border);border-radius:12px;border-radius:var(--radius-md);font-family:inherit;font-size:1rem;padding:12px 16px;transition:all .2s ease-out;transition:all var(--transition-fast);width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#87b0ae;border-color:var(--color-primary);box-shadow:0 0 0 3px #007aff1a;outline:none}.form-group textarea{min-height:120px;resize:vertical}.footer{background:#000;background:var(--color-background-dark);color:#f5f5f7;color:var(--color-text-light);overflow:hidden;padding:6rem 0 4rem;padding:var(--spacing-xl) 0 var(--spacing-lg) 0;position:relative}.footer-container{margin:0 auto;max-width:1200px;position:relative}.footer-separator{background:linear-gradient(90deg,#0000,#ffffff4d,#0000);height:1px;margin-bottom:4rem;margin-bottom:var(--spacing-lg);transform-origin:left}.footer-content{gap:2rem;gap:var(--spacing-md);text-align:center}.footer-content,.footer-main{align-items:center;display:flex;flex-direction:column}.footer-main{gap:4rem;gap:var(--spacing-lg);margin-bottom:2rem;margin-bottom:var(--spacing-md)}.footer-brand{text-align:center}.footer-title{color:#f5f5f7;color:var(--color-text-light);font-size:1.5rem;font-weight:600;font-weight:var(--font-weight-semibold);line-height:1.2;margin-bottom:2px}.footer-subtitle{color:#ffffffb3;font-size:1rem;font-weight:400;font-weight:var(--font-weight-regular);margin:0}.footer-social{align-items:center;display:flex;flex-direction:column;gap:2rem;gap:var(--spacing-md)}.footer-social-title{color:#fffc;font-size:.95rem;font-weight:500;font-weight:var(--font-weight-medium);margin:0}.footer-social-links{align-items:center;display:flex;flex-wrap:wrap;gap:4rem;gap:var(--spacing-lg);justify-content:center}.footer-social-link{align-items:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;border-radius:var(--radius-md);color:#ffffffb3;cursor:pointer;display:flex;flex-direction:column;gap:.5rem;gap:var(--spacing-xs);padding:1rem;padding:var(--spacing-sm);text-decoration:none;transition:all .2s ease-out;transition:all var(--transition-fast)}.footer-social-link:hover{background:#ffffff1a;border-color:#fff3;box-shadow:0 4px 20px #0003;transform:translateY(-2px)}.footer-social-label{font-size:.8rem;font-weight:500;font-weight:var(--font-weight-medium);opacity:.9;transition:opacity .2s ease-out;transition:opacity var(--transition-fast)}.footer-social-link:hover .footer-social-label{opacity:1}.footer-back-to-top{align-items:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:16px;border-radius:var(--radius-lg);color:#fffc;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;font-weight:var(--font-weight-medium);gap:.5rem;gap:var(--spacing-xs);padding:1rem 2rem;padding:var(--spacing-sm) var(--spacing-md);text-decoration:none;transition:all .2s ease-out;transition:all var(--transition-fast)}.footer-back-to-top:hover{background:#ffffff26;border-color:#ffffff4d;box-shadow:0 4px 20px #0003;color:#f5f5f7;color:var(--color-text-light);transform:translateY(-2px)}.footer-bottom{border-top:1px solid #ffffff1a;margin-top:2rem;margin-top:var(--spacing-md);padding-top:2rem;padding-top:var(--spacing-md);width:100%}.footer-made-with{align-items:center;color:#fff9;display:flex;font-size:.85rem;font-weight:400;font-weight:var(--font-weight-regular);gap:.5rem;gap:var(--spacing-xs);justify-content:center;margin:0}.footer-heart{animation:heartbeat 2s ease-in-out infinite;color:#ff6b6b}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@media (max-width:768px){.footer{padding:6rem 0 2rem;padding:var(--spacing-xl) 0 var(--spacing-md) 0}.footer-main,.footer-social-links{gap:2rem;gap:var(--spacing-md)}.footer-social-link{padding:.5rem 1rem;padding:var(--spacing-xs) var(--spacing-sm)}.footer-social-label{font-size:.75rem}.footer-back-to-top{font-size:.85rem;padding:.5rem 1rem;padding:var(--spacing-xs) var(--spacing-sm)}}@media (max-width:480px){.footer{padding:4rem 0 1rem;padding:var(--spacing-lg) 0 var(--spacing-sm) 0}.footer-title{font-size:1.25rem}.footer-subtitle{font-size:.9rem}.footer-social-links{flex-direction:row;flex-wrap:wrap;gap:1rem;gap:var(--spacing-sm)}.footer-social-link{min-width:60px;padding:.5rem;padding:var(--spacing-xs)}.footer-social-label{display:none}.footer-made-with{flex-direction:column;font-size:.8rem;gap:4px}}@media (max-width:768px){.nav{display:none}.main-content,.nav.collapsed+.main-content{margin-left:0}.mobile-nav-toggle{display:flex}.mobile-nav-dock{padding:max(env(safe-area-inset-top),20px) 20px 30px}.hero{padding:6rem 2rem;padding:var(--spacing-xl) var(--spacing-md)}.hero-cta{align-items:center;flex-direction:column}.about-content{gap:4rem;gap:var(--spacing-lg);text-align:center}.about-content,.contact-content,.projects-grid{grid-template-columns:1fr}.skills-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}}@media (max-width:480px){.container{padding:0 1rem;padding:0 var(--spacing-sm)}.hero-title{font-size:2.5rem}.section-title{font-size:2rem}.image-placeholder{height:300px;width:250px}.mobile-nav-dock{border-radius:0 0 16px 16px;padding:max(env(safe-area-inset-top),15px) 15px 25px}.mobile-nav-profile{gap:12px;padding:15px 0}.mobile-nav-avatar{height:45px;width:45px}.mobile-nav-name{font-size:1rem}.mobile-nav-role{font-size:.85rem}.mobile-nav-link{font-size:.95rem;gap:12px;padding:14px 16px}.mobile-nav-toggle{height:40px;left:16px;top:max(env(safe-area-inset-top),16px);width:40px}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.scroll-arrow{animation:none}}.icon-design{justify-content:center;overflow:hidden;position:relative}.banyan-design,.icon-design{align-items:center;display:flex;height:100%;width:100%}.banyan-design{gap:15px;justify-content:space-between;padding:20px}.tree-column{display:flex;flex-direction:column;gap:20px;position:relative}.tree-icon{color:#87b0ae;color:var(--color-primary);font-size:28px;transition:all .3s ease-out;transition:all var(--transition-medium)}.tree-icon.flipped{color:#fff9;transform:scaleY(-1)}.tree-icon.main{color:#87b0ae;color:var(--color-primary);filter:drop-shadow(0 4px 12px rgba(135,176,174,.3));font-size:36px}.ellie-design,.graduation-caps{height:100%;position:relative;width:100%}.cap-icon.main{color:#87b0ae;color:var(--color-primary);filter:drop-shadow(0 4px 12px rgba(135,176,174,.3));height:40px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:40px}.cap-icon.floating{color:#ffffffb3;position:absolute}.cap-icon.cap-1{height:24px;width:24px}.cap-icon.cap-2{height:20px;width:20px}.cap-icon.cap-3,.cap-icon.cap-4{height:28px;width:28px}.cap-icon.cap-5{height:22px;width:22px}.cap-icon.cap-6{height:30px;width:30px}.cap-icon.cap-7{height:18px;width:18px}.cap-icon.cap-8{height:26px;width:26px}.cap-icon.cap-1{animation-delay:-1s;left:20%;top:20%}.cap-icon.cap-2{animation-delay:-2s;right:20%;top:70%}.cap-icon.cap-3{animation-delay:-3s;right:10%;top:30%}.cap-icon.cap-4{animation-delay:-3s;right:60%;top:20%}.cap-icon.cap-5{animation-delay:-.5s;left:30%;top:20%}.cap-icon.cap-6{animation-delay:-2.5s;right:30%;top:15%}.cap-icon.cap-7{animation-delay:-1.5s;bottom:20%;right:40%}.cap-icon.cap-8{animation-delay:-4s;left:10%;top:60%}.cap-icon.cap-9{animation-delay:-4s;bottom:40%;left:20%}.cap-icon.cap-10{animation-delay:-4s;right:40%;top:60%}.cap-icon.cap-11{animation-delay:-4s;bottom:30%;left:10%}.cap-icon.cap-12{animation-delay:-4s;bottom:60%;right:10%}@keyframes mainCapFloat{0%,to{transform:translate(-50%,-50%) rotate(0deg)}50%{transform:translate(-50%,-60%) rotate(2deg)}}@keyframes floatAround{0%,to{opacity:.7;transform:translateY(0) rotate(0deg)}50%{opacity:1;transform:translateY(-20px) rotate(10deg)}}.flowify-design{height:100%;overflow:hidden;position:relative;width:100%}.flow-rows{display:flex;flex-direction:column;height:100%;justify-content:space-around;padding:10px}.flow-row{align-items:center;display:flex;gap:30px;overflow:hidden;white-space:nowrap}.flow-row.row-2,.flow-row.row-4{color:#87b0ae;color:var(--color-primary)}.workflow-icon{flex-shrink:0;font-size:28px;transition:all .3s ease-out;transition:all var(--transition-medium)}.workflow-icon.main{filter:drop-shadow(0 4px 12px rgba(135,176,174,.3));font-size:32px}@keyframes gentleSwayLeft{0%,to{transform:translateX(0) scale(1)}50%{transform:translateX(-30px) scale(1.05)}}@keyframes gentleSwayRight{0%,to{transform:translateX(0) scale(1)}50%{transform:translateX(30px) scale(1.05)}}.allocator-design,.gear-system{height:100%;position:relative;width:100%}.gear-icon{color:#87b0ae;color:var(--color-primary);font-size:40px;position:absolute}.gear-icon.main-gear{filter:drop-shadow(0 4px 12px rgba(135,176,174,.3));font-size:48px;left:50%;top:50%;transform:translate(-50%,-50%);z-index:2}.gear-icon.gear-1{color:#fffc;font-size:32px;left:15%;top:40%}.gear-icon.gear-2{color:#fff9;font-size:28px}.gear-icon.gear-3{color:#ffffffb3;font-size:34px}.gear-icon.gear-4{color:#ffffff80;font-size:26px}.gear-icon.gear-5{color:#fffc;font-size:30px}.book-stack,.scoreai-design{position:relative}.book-stack{height:120px;width:120px}.book-icon.main-book{color:#87b0ae;color:var(--color-primary);filter:drop-shadow(0 4px 12px rgba(135,176,174,.3));font-size:40px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.book-icon.floating-book{color:#ffffffb3;position:absolute}.book-icon.book-1{font-size:32px;left:60%;top:30%}.book-icon.book-2{bottom:40%;font-size:28px;left:30%}@keyframes bookFloat{0%,to{transform:translate(-50%,-50%) rotate(-2deg)}50%{transform:translate(-50%,-60%) rotate(2deg)}}@keyframes bookStack{0%,to{opacity:.7;transform:translateY(0) rotate(0deg)}50%{opacity:1;transform:translateY(-15px) rotate(5deg)}}.captcha-design,.scan-container{position:relative}.scan-container{align-items:center;display:flex;height:100px;justify-content:center;width:100px}.scan-icon.main-eye{color:#87b0ae;color:var(--color-primary);filter:drop-shadow(0 4px 12px rgba(135,176,174,.3));font-size:40px}.scan-line{background:linear-gradient(90deg,#0000,#87b0ae,#0000);background:linear-gradient(90deg,#0000,var(--color-primary),#0000);height:2px;left:0;position:absolute;right:0;top:0}.corner-brackets{inset:-10px;position:absolute}.bracket{border:2px solid #ffffff80;height:15px;position:absolute;width:15px}.bracket.top-left{border-bottom:none;border-right:none;left:0;top:0}.bracket.top-right{border-bottom:none;border-left:none;right:0;top:0}.bracket.bottom-left{border-right:none;border-top:none;bottom:0;left:0}.bracket.bottom-right{border-left:none;border-top:none;bottom:0;right:0}@keyframes eyeBlink{0%,90%,to{transform:scaleY(1)}95%{transform:scaleY(.1)}}@keyframes scanMove{0%{opacity:0;top:-10px}50%{opacity:1}to{opacity:0;top:100px}}@keyframes bracketGlow{0%,to{border-color:#ffffff80;opacity:.5}50%{border-color:#87b0ae;border-color:var(--color-primary);opacity:1}}.project-card:hover .book-icon.main-book,.project-card:hover .cap-icon.main,.project-card:hover .gear-icon.main-gear,.project-card:hover .scan-icon.main-eye,.project-card:hover .tree-icon.main,.project-card:hover .workflow-icon.main{color:#ffffffe6;filter:drop-shadow(0 6px 20px rgba(135,176,174,.4))}
/*# sourceMappingURL=main.b029b8f4.css.map*/