:root{--bg-primary:#0a0a0a;--bg-secondary:#111;--text-primary:#e4e4e7;--text-secondary:#a1a1aa;--text-tertiary:#71717a;--accent:#a855f7;--accent-hover:#9333ea;--border:#27272a;--card-bg:#18181b;--nav-bg:#0a0a0afa;--nav-bg-scrolled:#0a0a0afa;--space-xs:0.25rem;--space-sm:0.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem;--font-sans:-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;--font-mono:"SF Mono","Monaco","Inconsolata","Fira Code",monospace;--max-width:700px;--max-width-wide:1200px}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body,html{overscroll-behavior:none}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0a0a0a;background:var(--bg-primary);color:#e4e4e7;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-family:var(--font-sans);font-size:16px;line-height:1.6;margin:0;padding:0;-webkit-user-select:none;user-select:none}code{background:#111;background:var(--bg-secondary);border-radius:4px;font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;font-family:var(--font-mono);font-size:.9em;padding:.2em .4em}a{color:#a855f7;color:var(--accent);text-decoration:none;transition:color .2s ease}a:hover{color:#9333ea;color:var(--accent-hover)}[data-theme=light]{--bg-primary:#eff1f5;--bg-secondary:#e6e9ef;--text-primary:#4c4f69;--text-secondary:#5c5f77;--text-tertiary:#6c6f85;--accent:#8839ef;--accent-hover:#7c3aed;--border:#dce0e8;--card-bg:#fff;--nav-bg:#eff1f5fa;--nav-bg-scrolled:#e6e9effa}h1,h2,h3,h4,h5,h6{color:#e4e4e7;color:var(--text-primary);font-weight:600;line-height:1.3}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.25rem}@media (max-width:768px){h1{font-size:2rem}h2{font-size:1.75rem}h3{font-size:1.25rem}}.App{min-height:100vh;position:relative;scroll-behavior:smooth}.container{max-width:1000px}.container,.container-wide{margin:0 auto;padding:var(--space-2xl) var(--space-lg)}.container-wide{max-width:var(--max-width-wide)}.section{margin-bottom:var(--space-3xl)}.section-title{color:var(--text-primary);font-size:2rem;margin-bottom:var(--space-xl)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}@media (max-width:768px){.container,.container-wide{padding:var(--space-xl) var(--space-md)}.section-title{font-size:1.75rem}}.nav{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--nav-bg);border-bottom:1px solid var(--border);left:0;padding:var(--space-lg) 0;position:fixed;right:0;top:0;transition:all .3s ease;width:100%;z-index:1000}.nav.scrolled{background:var(--nav-bg-scrolled)}.nav-container{gap:var(--space-xl);justify-content:space-between;margin:0 auto;max-width:var(--max-width);padding:0 var(--space-lg)}.nav-container,.theme-toggle{align-items:center;display:flex}.theme-toggle{background:#0000;border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);cursor:pointer;flex-shrink:0;height:40px;justify-content:center;transition:all .2s ease;width:40px}.theme-toggle:hover{border-color:var(--accent);color:var(--accent);transform:scale(1.05)}.nav-logo{color:var(--text-primary);font-size:1.5rem;font-weight:700;text-decoration:none;transition:color .2s ease}.nav-logo:hover{color:var(--accent)}.nav-links{display:flex;gap:var(--space-xl);list-style:none;margin:0;padding:0}.nav-links a{color:var(--text-secondary);font-size:.95rem;position:relative;text-decoration:none;transition:color .2s ease}.nav-links a:hover{color:var(--text-primary)}.nav-links a.active{color:var(--accent)}.nav-links a.active:after{background:var(--accent);bottom:-4px;content:"";height:2px;left:0;position:absolute;right:0}@media (max-width:768px){.nav-container{padding:0 var(--space-md)}.nav-links{gap:var(--space-md)}.nav-links a{font-size:.85rem}}@media (max-width:480px){.nav-logo{font-size:1.25rem}.nav-links{gap:var(--space-sm)}.nav-links a{font-size:.8rem}}.hero{align-items:center;display:flex;min-height:110vh;padding:var(--space-3xl) 0}.hero-image-container{margin-bottom:var(--space-xl)}.hero-image{border:3px solid var(--border);border-radius:50%;height:300px;object-fit:cover;transition:all .3s ease;width:300px}.hero h1{margin-bottom:var(--space-sm)}.hero-subtitle{display:block;font-size:1rem}.hero-bio,.hero-subtitle{color:var(--text-secondary);margin-bottom:var(--space-xl)}.hero-bio{line-height:1.7;max-width:600px}.hero-tech{margin-bottom:var(--space-xl);max-width:600px}.hero-tech h3{color:var(--text-secondary);font-size:1rem;font-weight:500;letter-spacing:1px;margin-bottom:var(--space-md);text-transform:uppercase}.tech-grid{grid-gap:var(--space-sm);display:grid;gap:var(--space-sm);grid-template-columns:repeat(auto-fit,minmax(130px,1fr))}.tech-item{align-items:center;background:#ffffff08;border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);display:flex;font-size:.85rem;gap:8px;padding:.5rem .75rem;transition:all .2s ease}.tech-item svg{flex-shrink:0;height:18px;width:18px}.tech-item span{white-space:nowrap}.hero-links{gap:var(--space-md)}.hero-links,.hero-links a{align-items:center;display:flex}.hero-links a{color:var(--text-secondary);transition:color .2s ease}.hero-links a:hover{color:var(--accent)}@media (max-width:768px){.hero{padding:var(--space-2xl) 0}}.modal-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000d9;bottom:0;display:flex;justify-content:center;left:0;padding:var(--space-lg);position:fixed;right:0;top:0;z-index:2000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{animation:slideUp .3s ease;background:var(--card-bg);border:1px solid var(--border);border-radius:12px;max-height:90vh;max-width:800px;overflow-y:auto;padding:var(--space-2xl);position:relative;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-close{align-items:center;background:#0000;border:none;color:var(--text-secondary);cursor:pointer;display:flex;font-size:1.5rem;justify-content:center;padding:var(--space-sm);position:absolute;right:var(--space-lg);top:var(--space-lg);transition:color .2s ease;z-index:1}.modal-close:hover{color:var(--text-primary)}.modal-content::-webkit-scrollbar{width:8px}.modal-content::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:4px}.modal-content::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.modal-content::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}@media (max-width:768px){.modal-overlay{padding:var(--space-md)}.modal-content{max-height:95vh;padding:var(--space-xl)}.modal-close{right:var(--space-md);top:var(--space-md)}}.experience-grid{display:flex;flex-direction:column;gap:var(--space-sm)}.experience-card{background:linear-gradient(135deg,#a855f705,#0000);border-left:2px solid #0000;border-radius:12px;cursor:pointer;margin-bottom:var(--space-md);padding:var(--space-xl);position:relative;transition:all .3s ease}.experience-card:before{background:linear-gradient(135deg,#a855f71a,#0000);border-radius:12px;content:"";inset:0;opacity:0;padding:1px;position:absolute;transition:opacity .3s ease}.experience-card:hover{background:linear-gradient(135deg,#a855f70d,#a855f703)}.experience-card:hover:before{opacity:1}.experience-content-wrapper{display:flex;flex-direction:column;gap:var(--space-md)}.experience-header{display:flex;flex-direction:column;gap:8px}.experience-title-row{align-items:flex-start;display:flex;gap:var(--space-md);position:relative}.experience-icon{align-items:center;display:flex;flex-shrink:0;padding-top:2px}.experience-icon-emoji{font-size:1.5rem;line-height:1}.experience-icon-img{border-radius:6px;height:36px;object-fit:contain;width:36px}.experience-title-text{flex:1 1;min-width:0}.experience-title-text h3{color:var(--text-primary);font-size:1.1rem;font-weight:500;margin:0 0 4px}.experience-company{color:var(--text-secondary);font-size:.9rem;margin:0}.badge-current{background:linear-gradient(135deg,var(--accent),var(--accent-hover));border-radius:6px;box-shadow:0 2px 8px #a855f74d;color:#fff;font-size:.7rem;font-weight:600;letter-spacing:.5px;padding:.3rem .7rem;position:absolute;right:0;text-transform:uppercase;top:0}.experience-meta{color:var(--text-tertiary);display:flex;flex-wrap:wrap;font-size:.8rem;gap:var(--space-sm);margin-bottom:8px}.experience-meta span:not(:last-child):after{content:"•";margin-left:var(--space-sm)}.experience-location{align-items:center;display:flex;gap:4px}.experience-description{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin-bottom:var(--space-md)}.experience-tech{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-sm)}.tech-tag:hover{background:#a855f726;color:var(--accent);transform:translateY(-1px)}.experience-modal{padding-right:var(--space-xl)}.modal-icon{align-items:center;display:flex;margin-bottom:var(--space-lg)}.modal-icon-emoji{font-size:4rem;line-height:1}.modal-icon-img{border-radius:12px;height:80px;object-fit:contain;width:80px}.experience-modal h2{margin-bottom:var(--space-sm)}.modal-company{color:var(--text-secondary);font-size:1.1rem;font-weight:500;margin-bottom:var(--space-md)}.modal-meta{align-items:center;border-bottom:1px solid var(--border);color:var(--text-tertiary);display:flex;flex-wrap:wrap;font-size:.9rem;gap:var(--space-md);margin-bottom:var(--space-2xl);padding-bottom:var(--space-lg)}.modal-section li:before{color:var(--accent)}.achievements-list li:before{content:"✓"}.modal-skills,.modal-tech{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.modal-tech .tech-tag{transition:all .2s ease}.modal-tech .tech-tag:hover{background:#ffffff0d;border-color:var(--accent)}.skill-tag{background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);font-size:.85rem;padding:.4rem .8rem}.modal-link{align-items:center;color:var(--accent);display:inline-flex;gap:var(--space-xs);transition:color .2s ease}.modal-link:hover{color:var(--accent-hover)}@media (max-width:768px){.experience-title-row{flex-wrap:wrap}.badge-current{margin-left:auto;position:relative;right:auto;top:auto}.experience-icon{padding-top:0}.experience-modal{padding-right:0}.modal-icon{font-size:3rem}}.projects-list{display:flex;flex-direction:column;gap:var(--space-sm)}.project-item{background:linear-gradient(135deg,#a855f705,#0000);border-left:2px solid #0000;border-radius:12px;cursor:pointer;margin-bottom:var(--space-sm);padding:var(--space-lg);position:relative;transition:all .3s ease}.project-item:before{background:linear-gradient(135deg,#a855f71a,#0000);border-radius:12px;content:"";inset:0;-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;padding:1px;position:absolute;transition:opacity .3s ease}.project-item:hover{background:linear-gradient(135deg,#a855f70d,#a855f703)}.project-item:hover:before{opacity:1}.project-item-in-progress{background:linear-gradient(135deg,#71717a05,#0000)}.project-item-in-progress:before{background:linear-gradient(135deg,#71717a1a,#0000)}.project-item-in-progress:hover{background:linear-gradient(135deg,#71717a0d,#71717a03)}.project-icon-wrapper{position:absolute;right:var(--space-lg);top:var(--space-lg);z-index:1}.project-icon-large{align-items:center;display:flex;justify-content:center}.project-icon-emoji{font-size:1.5rem;line-height:1;opacity:.7}.project-icon-img{border-radius:6px;height:32px;object-fit:contain;opacity:.7;width:32px}.project-content{display:flex;flex-direction:column;gap:6px;padding-right:48px}.project-header-row{align-items:baseline;display:flex;gap:var(--space-md);justify-content:space-between}.project-header-row h3{color:var(--text-primary);font-size:1.1rem;font-weight:500;margin:0}.project-badges{align-items:center;display:flex;flex-shrink:0;font-size:.8rem;gap:var(--space-sm)}.badge-status{background:#0000;font-size:.75rem;font-style:italic;font-weight:400;padding:0}.badge-status,.project-date{color:var(--text-tertiary);white-space:nowrap}.project-date{align-items:center;display:flex;font-size:.8rem;gap:4px}.project-description{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin:0}.project-tech-row{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-top:4px}.tech-tag{align-items:center;background:#a855f714;border:none;border-radius:20px;color:var(--text-secondary);display:inline-flex;font-size:.8rem;font-weight:500;gap:6px;padding:.4rem .85rem;transition:all .2s ease}.tech-tag-in-progress{background:#71717a14;color:var(--text-tertiary)}.tech-tag-in-progress .tech-icon-inline{opacity:.5}.tech-icon-inline{flex-shrink:0;height:14px;width:14px}.tech-name{line-height:1}.project-quick-links{display:flex;gap:var(--space-md);margin-top:var(--space-md);padding-top:var(--space-sm)}.project-quick-links a{color:var(--text-secondary);font-size:1.1rem;transition:color .2s ease}.project-quick-links a:hover{color:var(--accent)}.project-modal{padding-right:var(--space-xl)}.modal-section{margin-bottom:var(--space-2xl)}.modal-section h4{color:var(--text-primary);font-size:1rem;letter-spacing:.5px;margin-bottom:var(--space-md);text-transform:uppercase}.modal-section p{color:var(--text-secondary);line-height:1.7}.modal-section ul{list-style:none;padding:0}.modal-section li{color:var(--text-secondary);line-height:1.7;margin-bottom:var(--space-sm);padding-left:var(--space-lg);position:relative}.modal-section li:before{color:var(--text-secondary);content:"→";left:0;position:absolute}.modal-tech .tech-tag{align-items:center;background:#ffffff08;border:1px solid var(--border);border-radius:6px;display:inline-flex;font-size:.85rem;gap:6px;padding:.35rem .7rem}.modal-icon-large{align-items:center;display:flex;margin-bottom:var(--space-lg)}.modal-project-icon-emoji{font-size:5rem;line-height:1}.modal-project-icon-img{border-radius:12px;height:100px;object-fit:contain;width:100px}.project-modal h2{margin-bottom:var(--space-md)}.modal-badges{border-bottom:1px solid var(--border);gap:var(--space-md);margin-bottom:var(--space-2xl);padding-bottom:var(--space-lg)}.modal-badges,.modal-date{align-items:center;display:flex}.modal-date{color:var(--text-tertiary);font-size:.9rem;gap:var(--space-xs)}.highlights-list li:before{content:"✓"}.modal-link-button{align-items:center;background:#0000;border:none;color:var(--accent);display:inline-flex;font-size:.95rem;font-weight:400;gap:var(--space-sm);padding:0;text-decoration:none;transition:color .2s ease}.modal-link-button:hover{color:var(--accent-hover)}.modal-links{display:flex;flex-direction:column;gap:var(--space-sm)}@media (max-width:768px){.project-icon-wrapper{right:var(--space-md);top:var(--space-md)}.project-icon-emoji{font-size:1.25rem}.project-icon-img{height:28px;width:28px}.project-content{padding-right:40px}.project-header-row{align-items:flex-start;flex-direction:column;gap:var(--space-sm)}.project-quick-links{justify-content:flex-start;width:100%}.project-modal{padding-right:0}.modal-icon-large{font-size:4rem}}.contact{padding:var(--space-3xl) 0;text-align:center}.contact-content{margin:0 auto;max-width:600px}.contact-text{color:var(--text-secondary);line-height:1.7}.contact-email,.contact-text{font-size:1.1rem;margin-bottom:var(--space-xl)}.contact-email{align-items:center;display:inline-flex;gap:var(--space-sm);text-decoration:none;transition:all .2s ease}.contact-links{display:flex;gap:var(--space-lg);justify-content:center;margin-top:var(--space-xl)}.contact-links a{align-items:center;color:var(--text-secondary);display:flex;padding:var(--space-sm);transition:all .2s ease}.contact-links a:hover{color:var(--accent);transform:translateY(-2px)}@media (max-width:768px){.contact-text{font-size:1rem}.contact-email{font-size:1rem;padding:var(--space-sm) var(--space-lg)}}.animated-background{background:var(--bg-primary);height:100%;left:0;opacity:40%;overflow:hidden;position:fixed;top:0;transition:background .3s ease;width:100%;z-index:-1}.gradient-orb{animation:float-orb 20s ease-in-out infinite;border-radius:50%;filter:blur(80px);opacity:.15;position:absolute}.orb-1{animation-delay:0s;animation-duration:25s;background:radial-gradient(circle,var(--accent),#0000);height:500px;left:-10%;top:-10%;width:500px}.orb-2{animation-delay:5s;animation-duration:30s;background:radial-gradient(circle,var(--accent-hover),#0000);bottom:-10%;height:400px;right:-10%;width:400px}.orb-3{animation-delay:10s;animation-duration:20s;background:radial-gradient(circle,var(--accent),#0000);height:300px;left:50%;top:50%;width:300px}.grid-pattern{background-image:linear-gradient(#a855f708 1px,#0000 0),linear-gradient(90deg,#a855f708 1px,#0000 0);background-size:100px 100px;inset:0;mask-image:radial-gradient(ellipse 80% 50% at 50% 50%,#000 40%,#0000 100%);-webkit-mask-image:radial-gradient(ellipse 80% 50% at 50% 50%,#000 40%,#0000 100%);position:absolute}@keyframes float-orb{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.1)}66%{transform:translate(-20px,20px) scale(.9)}}
/*# sourceMappingURL=main.6abaeb80.css.map*/