.hero{display:flex;align-items:center;justify-content:flex-start;position:relative;overflow:hidden;padding-top:8rem}.hero-content{max-width:64rem;padding:0 1.5rem;opacity:0;transform:translateY(2rem);text-align:start}.hero-content.visible{opacity:1;transform:translateY(0)}.hero-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:1.5rem}.profile-photo{width:4rem;height:4rem;border-radius:50%;overflow:hidden;flex-shrink:0;border:2px solid rgba(255,255,255,.1)}.profile-photo img{width:100%;height:100%;object-fit:cover}.hero-title{font-size:1.5rem;font-weight:900;color:#fafafa;margin:0;line-height:1.1}.hero-subtitle{font-size:1rem;color:#d4d4d4;margin-bottom:1.5rem;line-height:1.4;max-width:48rem;margin-left:auto;margin-right:auto}.hero-description{max-width:48rem;margin:0 auto}.hero-text{font-size:1rem;color:#d4d4d4;line-height:1.625;margin-bottom:1rem}.hero-text-secondary{font-size:1rem;color:#d4d4d4;line-height:1.625}@media (max-width: 768px){.hero{padding:2rem 1rem;justify-content:center;text-align:start}.hero-content{padding:0;text-align:start}.hero-header{flex-direction:row;gap:1rem;align-items:center}.profile-photo{width:3.5rem;height:3.5rem}.hero-title{font-size:1.3rem;text-align:start}.hero-subtitle{font-size:1rem;text-align:start}.hero-description{text-align:start}.hero-text,.hero-text-secondary{font-size:1rem;text-align:start}}.portfolio{padding-top:4rem;padding-bottom:4rem}.section-header{text-align:center;margin-bottom:4rem}.section-title{font-size:clamp(2.5rem,6vw,4rem);font-weight:800;color:#fafafa;margin-bottom:1rem}.section-subtitle{font-size:1.25rem;color:#d4d4d4;max-width:48rem;margin:0 auto;line-height:1.6}.projects-grid{display:flex;flex-direction:column;gap:2rem;margin-top:1rem;justify-content:center;align-items:stretch}.project-card{flex:1;width:100%;background:#0a0a0a;border-radius:1rem;overflow:hidden}.project-image{position:relative;overflow:hidden;aspect-ratio:16/9;background:#0f0f0f;display:flex;align-items:center;justify-content:center}.project-image img{width:70%;height:70%;object-fit:contain}.project-content{padding:1.5rem}.project-title{font-size:1rem;font-weight:700;color:#fafafa;margin-bottom:.75rem;line-height:1.3}.project-description{color:#d4d4d4;line-height:1.6;margin-bottom:1.5rem;font-size:.95rem}.project-technologies{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}@media (max-width: 768px){.portfolio{padding:3rem 0}.projects-grid{flex-direction:column;gap:1.5rem;margin-top:2rem;align-items:center}.project-card{max-width:100%;min-width:auto}.section-header{margin-bottom:2rem}.section-title{margin-bottom:.75rem}}.experience{padding-top:4rem}.section-title{font-size:1.2rem;font-weight:700;color:#fafafa;text-align:start;margin:0;padding:0}.section-header{margin-bottom:2rem}.experience-section{display:flex;flex-direction:column}.timeline{position:relative}.timeline:before{content:"";position:absolute;left:1rem;top:0;height:calc(100% - 1rem);width:1px;background:#262626}.timeline-item{position:relative;margin-bottom:3rem;padding-left:3rem}.timeline-item:last-child{margin-bottom:0}.timeline-item:last-child .timeline-description{margin-bottom:1rem}.timeline-marker{position:absolute;left:.5rem;top:.5rem;width:1rem;height:1rem;background:#fafafa;border-radius:50%;border:2px solid #0a0a0a}.timeline-header{margin-bottom:.75rem;display:flex;flex-direction:column;gap:.5rem}.position{font-size:1rem;font-weight:800;color:#fafafa;margin:0;order:1}.company-info{display:flex;align-items:center;gap:.5rem;flex-shrink:0;order:2;flex-wrap:wrap}.company-logo{width:1.5rem;height:1.5rem;border-radius:.25rem;overflow:hidden;flex-shrink:0}.company-logo a{display:block;width:100%;height:100%;transition:transform .15s ease,opacity .15s ease}.company-logo a:hover{transform:scale(1.1);opacity:.8}.company-logo img{width:100%;height:100%;object-fit:cover;cursor:pointer}.company-name{font-size:1rem;font-weight:500;color:#d4d4d4;margin:0;display:block}.period{font-size:.875rem;color:#a3a3a3;background:#0a0a0a;padding:.25rem .75rem;border-radius:1rem;margin:0;flex-shrink:0}.timeline-description{color:#d4d4d4;line-height:1.6;margin-bottom:1rem}@media (max-width: 768px){.experience{padding:4rem 0}.experience-content{grid-template-columns:1fr;gap:3rem;margin-top:2rem}.subsection-title{margin-bottom:1.5rem}.timeline-item{padding-left:2.5rem}.timeline-header{gap:.4rem}.company-logo{width:1.25rem;height:1.25rem}.company-name,.position{font-size:.9rem}}.contact-methods{display:flex;flex-direction:row;justify-content:flex-start;align-items:center;margin:0 auto}.contact-method{display:flex;align-items:center}.contact-icon{width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;border-radius:50%;color:#d4d4d4;transition:all .15s ease}.contact-link:hover .contact-icon{background:#2563eb}.contact-link:hover .contact-icon svg{stroke:#fff}@media (max-width: 768px){.contact{padding:0}.contact-methods{padding:0 1rem}.contact-method{padding-right:1rem}.contact-icon{width:2.5rem;height:2.5rem}}*{box-sizing:border-box;padding:0;margin:0}html,body{max-width:100vw;overflow-x:hidden;transition:all 1s ease}body{color:#fafafa;background:#171717;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}.app{min-height:100vh;margin-left:33%;margin-right:33%}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.text-center{text-align:center}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-16{padding-top:4rem;padding-bottom:4rem}.h-screen{height:100vh}.flex{display:flex}.items-center{align-items:center}.justify-center{justify-content:center}.relative{position:relative}.absolute{position:absolute}.z-10{z-index:10}.max-w-5xl{max-width:64rem}.max-w-3xl{max-width:48rem}.mx-auto{margin-left:auto;margin-right:auto}.leading-tight{line-height:1.25}.leading-relaxed{line-height:1.625}@media (max-width: 768px){.container{padding:0 .75rem}.app{margin-top:25%;margin-left:32px;margin-right:32px}}
