body{margin:0;font-family:Inter,sans-serif;background-color:#fff}html,body{margin:0;padding:0;overflow-x:hidden}*,*:before,*:after{box-sizing:border-box}nav{position:fixed;top:0;width:100%;background-color:#fff;box-shadow:0 1px 3px #0000001a;padding:1rem 4rem;z-index:1000;box-sizing:border-box;color:#111827}.nav-container{max-width:1125px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.logo{font-weight:900;font-size:1.8rem;opacity:0;transform:translateY(-20px);animation:slideDown .6s ease-out forwards;text-decoration:none;color:#111827}.nav-links{display:flex;gap:2rem;opacity:0;transform:translateY(-20px);animation:slideDown .6s ease-out forwards}.nav-links a{text-decoration:none;color:#111827;font-weight:500}.icons{display:flex;gap:1.175rem}.icons a{opacity:0;transform:scaleX(0);display:inline-block;animation:expandIn .3s ease-out forwards}.icons a:nth-child(1){animation-delay:0s}.icons a:nth-child(2){animation-delay:.4s}.icons a:nth-child(3){animation-delay:.8s}.icons img{width:20px;height:20px}section{padding:100px 20px;min-height:50vh}#about{display:flex;flex-direction:row;justify-content:space-between;align-items:center;height:100vh;padding:0 20px;max-width:1150px;margin:0 auto;gap:8.5rem;color:#09090b}.about-left{max-width:60%}.about-right{width:40%;height:400px;display:flex;align-items:center;justify-content:center;border-radius:0;color:#888;font-size:1.2rem;font-style:italic}.about-right img{width:175%;height:auto}.text-left{display:flex;flex-direction:column;gap:1rem}.text-left h1{margin:0;font-size:2.5rem;font-weight:600}@media (max-width: 768px){#about{flex-direction:column;justify-content:center;align-items:center;gap:2rem;padding:2rem;text-align:center}.about-left,.about-right{max-width:90%;width:100%}.about-right{display:none}.about-tags{justify-content:center;text-align:center}}.about-tags{display:flex;gap:1rem;margin:0rem 0;flex-wrap:wrap}.about-tag{background-color:#f0f0f0;padding:.4rem .8rem;border-radius:9999px;font-size:.95rem;font-weight:500;color:#333}.hamburger{display:none;flex-direction:column;cursor:pointer;gap:4px}.hamburger span{width:25px;height:3px;background:#111827}.mobile-menu{display:flex;flex-direction:column;background-color:#fff;position:absolute;top:100%;left:0;right:0;padding:0 4rem;box-shadow:0 2px 4px -2px #0000001a;box-sizing:border-box;max-height:0;overflow:hidden;transition:max-height .3s ease-out,padding .3s ease-out;pointer-events:none}.mobile-menu.active{padding:1rem 4rem;max-height:500px;pointer-events:auto}.mobile-nav-links{display:flex;flex-direction:column;gap:1rem;margin-bottom:2.5em}.mobile-nav-links a{text-decoration:none;color:#111827;font-weight:500;opacity:0;transform:translate(-20px);animation:slideRight .6s ease-out forwards}.mobile-nav-links a:nth-child(1){animation-delay:0s}.mobile-nav-links a:nth-child(2){animation-delay:.2s}.mobile-nav-links a:nth-child(3){animation-delay:.4s}.mobile-nav-links a:nth-child(4){animation-delay:.6s}.mobile-icons{display:flex;gap:1.175rem}.mobile-icons a{opacity:0;transform:scaleX(0);display:inline-block;animation:expandIn .3s ease-out forwards}.mobile-icons a:nth-child(1){animation-delay:0s}.mobile-icons a:nth-child(2){animation-delay:.4s}.mobile-icons a:nth-child(3){animation-delay:.8s}@keyframes slideRight{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideDown{to{opacity:1;transform:translateY(0)}}@keyframes expandIn{to{opacity:1;transform:scaleX(1)}}@keyframes wave{0%{transform:rotate(0)}to{transform:rotate(20deg)}}.animate-rotate{animation:wave 1s infinite alternate ease-in-out;display:inline-block;transform-origin:70% 70%}@media (max-width: 768px){.nav-links,nav .icons{display:none}.hamburger{display:flex}}#bio{display:flex;justify-content:center;width:100%;margin:0 auto;font-size:2rem;color:#121212}.bio-content{width:40%;text-align:center}@media (max-width: 768px){.bio-content{width:90%}}#projects-zoom{position:relative;height:100vh;display:flex;align-items:center;justify-content:center;background:#fff;overflow:hidden}.zoom-title{font-size:6rem;font-weight:900;color:#121212;text-align:center;margin:0}#projects{background-color:#121212;color:#fff}.projects-header{max-width:700px;margin:0 auto 3rem;text-align:center}.projects-header h2{font-size:2.5rem;font-weight:700;margin-bottom:1rem}.projects-header p{font-size:1.1rem;font-weight:300;line-height:1.5;color:#ccc}.projects-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:2rem;max-width:903px;margin:0 auto}.project-card{background-color:#18181b;border-radius:8px;padding:1rem;display:flex;flex-direction:column;gap:1rem;cursor:pointer;transition:transform .3s ease}.project-card:hover{transform:scale(1.02)}.project-card img{width:100%;height:250px;object-fit:fill;border-radius:4px}.project-card h3{font-size:1.25rem;font-weight:500;margin-bottom:.5rem;margin:0}.project-card p{margin:0 0 20px;color:#ccc;font-size:.9rem;line-height:1.5}.skills{margin-top:auto;display:flex;flex-wrap:wrap;gap:.5rem}#experience .skills{margin-top:7.5%}.skill-pill{background-color:#27272a;padding:.3rem .6rem;border-radius:5px;font-size:.8rem;font-weight:600;color:#eaeaea}.skill-pill-l{background-color:#eaeaea;padding:.3rem .6rem;border-radius:5px;font-size:.8rem;font-weight:600;color:#4a4b4f}.view-link-l{display:inline-flex;align-items:center;margin-top:0;background-color:#4a4b4f;color:#eaeaea;text-decoration:none;padding:.5rem .8rem;border-radius:5px;font-size:.8rem;transition:background-color .3s ease,color .3s ease;width:fit-content}.view-link-l img{margin-right:.4rem;height:1em;width:auto}.view-link-l:hover{background-color:#6d6e72}.view-link{display:inline-flex;align-items:center;margin-top:0;background-color:#fff;color:#18181b;text-decoration:none;padding:.5rem .8rem;border-radius:5px;font-size:.8rem;transition:background-color .3s ease,color .3s ease;width:fit-content}.view-link img{margin-right:.4rem;height:1em;width:auto}.view-link:hover{background-color:#ddd}@media (max-width: 768px){.zoom-title{font-size:3rem}.projects-header h2{font-size:2rem}.project-card{padding:1rem}}#contact{display:flex;flex-direction:column;justify-content:space-between;align-items:center;height:70vh;background-color:#121212;color:#fff;padding:6vw;text-align:center}#contact h1{font-size:2.5rem;font-weight:700;margin-bottom:.25rem}.contact-sub{font-size:1rem;font-weight:300;line-height:1.5;color:#ccc;margin-bottom:50px;margin-top:0}.copyright{margin-top:auto;margin-bottom:0rem;font-size:.8rem;max-width:700px;color:#ccc}.timeline{position:relative;width:80%;margin:4rem auto;padding:2rem 0}.timeline-line{position:absolute;left:50%;top:0;transform:translate(-50%);width:2px;height:100%;background:linear-gradient(to bottom,#bbb0,#bbb 10%,#bbb 90%,#bbb0);transform-origin:top}.timeline-item{position:relative;width:45%;padding:1.5rem;margin:2rem 0;background:#fafafa;color:#111827;box-shadow:0 1px 3px #0000001a;border-radius:8px;text-align:left;font-size:1rem;cursor:pointer;transition:transform .3s ease}.timeline-item:hover{transform:scale(1.02)}.timeline-item.no-cursor{cursor:default}.timeline-item.left{float:left;clear:both;margin-right:55%}.timeline-item.right{float:right;clear:both;margin-left:55%}.timeline-item:after{content:"";position:absolute;top:50%;width:40px;height:2px;background:#ccc;border-radius:0}.timeline-item.left:after{right:-6px;transform:translate(40px)}.timeline-item.right:after{left:-6px;transform:translate(-40px)}.timeline:after{content:"";display:table;clear:both}.timeline-header{display:flex;align-items:center;gap:1rem;margin-bottom:.75rem}.timeline-header .year{font-size:1.75rem;font-weight:700;line-height:1}.timeline-header .duration{font-size:.875rem;color:#999}.timeline-item:nth-of-type(5) .year{color:#e63946}.timeline-item:nth-of-type(6) .year{color:#f59e0b}.timeline-item:nth-of-type(4) .year{color:#10b981}.timeline-item:nth-of-type(2) .year{color:#3b82f6}.timeline-item:nth-of-type(3) .year{color:#8b5cf6}.role{font-size:1.25rem;font-weight:500;margin-bottom:.5rem}.company{font-size:1rem;font-weight:400;color:#666}.bio,.responsibilities{font-size:.9rem;line-height:1.5;color:#444}@media (max-width: 768px){.timeline{width:90%}.timeline-item{width:100%;margin:1.5rem 0;float:none}.timeline-item:after{left:-6px;display:none}.timeline-line{left:50%;height:90%;transform:translateY(3%)}.timeline-header .year{font-size:1.5rem}}
