@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&display=swap";:root{--bg: #0a0a0f;--bg-elevated: #12121a;--text: #f4f4f5;--text-muted: #a1a1aa;--accent: #10b981;--accent-light: #34d399;--accent-rgb: 16, 185, 129;--section-padding: 3.5rem 2rem}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:DM Sans,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}.section-title{font-size:2rem;font-weight:700;letter-spacing:-.02em;margin:0 0 1rem;color:var(--text)}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-light)}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;background:#0a0a0fe6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.06)}.navbar-left{display:flex;align-items:center;gap:1rem}.navbar-icon{display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:color .2s ease}.navbar-icon:hover{color:var(--accent)}.navbar-brand{font-weight:700;font-size:1.25rem;color:var(--accent);text-decoration:none;letter-spacing:-.02em}.navbar-brand:hover{color:var(--accent-light)}.navbar-menu{display:flex;gap:.5rem;list-style:none;margin:0;padding:0}.navbar-menu li button{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.95rem;font-weight:500;padding:.5rem 1rem;border-radius:8px;transition:all .2s ease}.navbar-menu li button:hover{color:var(--text);background:#ffffff0d}.navbar-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.5rem}.navbar-toggle span{width:24px;height:2px;background:var(--text);border-radius:2px;transition:transform .3s ease,opacity .3s ease}.navbar-toggle span:nth-child(1).open{transform:rotate(45deg) translate(5px,5px)}.navbar-toggle span:nth-child(2).open{opacity:0}.navbar-toggle span:nth-child(3).open{transform:rotate(-45deg) translate(5px,-5px)}@media(max-width:768px){.navbar-toggle{display:flex}.navbar-menu{position:absolute;top:100%;left:0;right:0;flex-direction:column;background:#0a0a0ffa;padding:1rem;border-bottom:1px solid rgba(255,255,255,.06);transform:translateY(-100%);opacity:0;pointer-events:none;transition:all .3s ease}.navbar-menu.open{transform:translateY(0);opacity:1;pointer-events:auto}.navbar-menu li button{width:100%;text-align:left;padding:.75rem 1rem}}.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:6rem 2rem 4rem}.hero-container{max-width:960px;margin:0 auto;display:flex;flex-direction:row;align-items:center;gap:3rem;text-align:left}.hero-photo{flex-shrink:0;width:200px;height:200px;border-radius:50%;overflow:hidden;border:3px solid rgba(var(--accent-rgb),.3);box-shadow:0 12px 40px #0000004d}.hero-image{width:100%;height:100%;object-fit:cover;object-position:50% 40%;display:block}.hero-content{width:100%}.hero-greeting{font-size:1rem;color:var(--accent);font-weight:500;margin-bottom:.5rem;letter-spacing:.1em;text-transform:uppercase}.hero-name{font-size:clamp(2.25rem,6vw,3.5rem);font-weight:800;letter-spacing:-.03em;line-height:1.15;margin:0 0 .35rem;background:linear-gradient(135deg,var(--text) 0%,var(--text-muted) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-title{font-size:1.25rem;color:var(--accent);font-weight:600;margin-bottom:.5rem}.hero-tagline{font-size:1rem;color:var(--text-muted);margin-bottom:1rem;opacity:.95}.hero-bio{font-size:1rem;line-height:1.7;color:var(--text-muted);margin-bottom:1.5rem}.hero-cta{display:flex;gap:.875rem;flex-wrap:wrap;justify-content:flex-start}.btn{display:inline-block;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;text-decoration:none;border-radius:10px;transition:all .2s ease;cursor:pointer}.btn-primary{background:var(--accent);color:var(--bg)}.btn-primary:hover{background:var(--accent-light);transform:translateY(-2px)}.btn-secondary{background:transparent;color:var(--text);border:2px solid rgba(255,255,255,.15)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.btn-outline{background:transparent;color:var(--accent);border:2px solid var(--accent)}.btn-outline:hover{background:rgba(var(--accent-rgb),.15);transform:translateY(-2px)}@media(max-width:768px){.hero-container{flex-direction:column;text-align:center}.hero-photo{width:180px;height:180px;margin:0 auto}.hero-cta{justify-content:center}}.journey{padding:var(--section-padding);background:#ffffff05}.journey-container{max-width:1100px;margin:0 auto}.journey-scroll{overflow-x:auto;overflow-y:visible;padding-bottom:1rem;margin:0 -.5rem;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.journey-scroll::-webkit-scrollbar{height:6px}.journey-scroll::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.journey-scroll::-webkit-scrollbar-thumb{background:rgba(var(--accent-rgb),.4);border-radius:3px}.journey-scroll::-webkit-scrollbar-thumb:hover{background:rgba(var(--accent-rgb),.6)}.journey-timeline{position:relative;display:flex;flex-direction:row;justify-content:space-between;gap:2rem;padding:0 1rem;min-width:min-content}.journey-line{position:absolute;top:2.5rem;left:2rem;right:2rem;min-width:calc(100% - 4rem);height:3px;background:linear-gradient(90deg,rgba(var(--accent-rgb),.2),rgba(var(--accent-rgb),.5),rgba(var(--accent-rgb),.2));border-radius:3px;z-index:0}.journey-step{flex:0 0 auto;min-width:220px;display:flex;flex-direction:column;align-items:center;position:relative;z-index:1}.journey-node{display:flex;flex-direction:column;align-items:center;margin-bottom:1.25rem}.journey-node-inner{position:relative;display:flex;flex-direction:column;align-items:center;gap:.5rem}.journey-year{font-size:1.25rem;font-weight:700;color:var(--accent);padding:.5rem 1rem;background:var(--bg);border:2px solid rgba(var(--accent-rgb),.4);border-radius:12px;white-space:nowrap;box-shadow:0 4px 12px #0000004d}.journey-node-dot{width:16px;height:16px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(var(--accent-rgb),.25);flex-shrink:0}.journey-card{position:relative;width:100%;max-width:240px;padding:1.25rem 1.25rem 2rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:16px;text-align:center;transition:all .25s ease}.journey-card:hover{background:#ffffff0f;border-color:rgba(var(--accent-rgb),.3);transform:translateY(-4px);box-shadow:0 12px 24px #0003}.journey-title{font-size:1rem;font-weight:600;color:var(--text);margin:0 0 .4rem}.journey-description{font-size:.85rem;color:var(--text-muted);margin:0;line-height:1.5}.journey-number{position:absolute;bottom:.5rem;right:.75rem;font-size:.7rem;font-weight:600;color:rgba(var(--accent-rgb),.4)}@media(max-width:900px){.journey-timeline{flex-direction:column;align-items:stretch;gap:0}.journey-line{top:0;bottom:0;left:1.5rem;right:auto;width:3px;height:100%}.journey-step{flex-direction:row;align-items:flex-start;gap:1.5rem;padding:1.5rem 0;border:none}.journey-step:not(:last-child){padding-bottom:0}.journey-node{margin-bottom:0;flex-shrink:0}.journey-node-inner{flex-direction:row;gap:1rem}.journey-node-dot{order:-1}.journey-card{max-width:none;flex:1;text-align:left}}@media(max-width:600px){.journey-line{left:1rem}.journey-step{gap:1rem;padding:1.25rem 0}.journey-year{font-size:1rem;padding:.35rem .75rem}.journey-node-dot{width:12px;height:12px}}.experience{padding:var(--section-padding);background:#ffffff05}.experience-container{max-width:820px;margin:0 auto}.section-subtitle{color:var(--text-muted);font-size:1rem;margin-top:-.5rem;margin-bottom:2rem}.experience-timeline{display:flex;flex-direction:column;gap:1.5rem}.experience-card{background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:16px;overflow:hidden;transition:all .25s ease;border-left:3px solid transparent}.experience-card:hover{background:#ffffff0d;border-color:#ffffff1a;border-left-color:var(--accent);transform:translateY(-3px);box-shadow:0 12px 32px #00000026}.experience-banner{position:relative;aspect-ratio:3 / 1;overflow:hidden}.experience-banner-img{width:100%;height:auto;object-fit:contain;transition:transform .4s ease}.experience-card:hover .experience-banner-img{transform:scale(1.04)}.experience-banner-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 50%,rgba(10,10,15,.4) 100%);pointer-events:none}.experience-body{padding:1.5rem 1.75rem}.experience-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.5rem}.experience-role{font-size:1.125rem;font-weight:600;color:var(--accent);margin:0 0 .2rem}.experience-company{font-size:1rem;font-weight:600;color:var(--text);margin:0;opacity:.95}.experience-period{font-size:.85rem;font-weight:600;color:var(--accent);background:rgba(var(--accent-rgb),.12);border:1px solid rgba(var(--accent-rgb),.25);padding:.4rem .85rem;border-radius:8px;white-space:nowrap}.experience-location{display:inline-flex;align-items:center;gap:.35rem;font-size:.875rem;color:var(--text-muted);margin:0 0 .75rem}.experience-location svg{flex-shrink:0;opacity:.8}.experience-description{font-size:.95rem;line-height:1.65;color:var(--text-muted);margin:0}.projects{padding:var(--section-padding)}.projects-container{max-width:1000px;margin:0 auto}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.75rem}.project-card{background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:16px;overflow:hidden;transition:all .2s ease}.project-card:hover{background:#ffffff0d;border-color:#ffffff1a;transform:translateY(-4px)}.project-banner{aspect-ratio:2 / 1;overflow:hidden}.project-banner-img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.project-card:hover .project-banner-img{transform:scale(1.05)}.project-content{padding:1.5rem 1.75rem}.project-title{font-size:1.25rem;font-weight:600;color:var(--accent);margin:0 0 .5rem}.project-description{font-size:.95rem;line-height:1.6;color:var(--text-muted);margin:0 0 1rem}.project-links{display:flex;gap:.75rem;flex-wrap:wrap}.project-link{font-size:.9rem;font-weight:500;color:var(--text);text-decoration:none;padding:.5rem 1rem;border-radius:8px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);transition:all .2s ease}.project-link:hover{color:var(--accent);background:rgba(var(--accent-rgb),.12);border-color:var(--accent)}.project-link-primary{background:var(--accent);color:var(--bg);border-color:var(--accent)}.project-link-primary:hover{background:var(--accent-light);color:var(--bg);border-color:var(--accent-light)}.skills{padding:var(--section-padding)}.skills-container{max-width:960px;margin:0 auto}.skills-subtitle{color:var(--text-muted);font-size:1rem;margin:-.5rem 0 2rem}.skills-categories{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem}.skill-category{padding:1.5rem 1.5rem 1.75rem;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:16px;transition:all .25s ease}.skill-category:hover{background:#ffffff0a;border-color:rgba(var(--accent-rgb),.2);box-shadow:0 8px 24px #00000026}.skill-category-header{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1rem}.skill-category-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--accent);background:rgba(var(--accent-rgb),.12);border-radius:12px;flex-shrink:0}.skill-category-icon svg{width:20px;height:20px}.skill-category-title{font-size:1rem;font-weight:600;color:var(--text);margin:0 0 .15rem;letter-spacing:.02em}.skill-category-desc{font-size:.8rem;color:var(--text-muted);margin:0}.skills-grid{display:flex;flex-wrap:wrap;gap:.5rem}.skill-tag{display:inline-block;padding:.45rem .9rem;font-size:.875rem;font-weight:500;color:var(--text-muted);background:#ffffff0a;border:1px solid rgba(255,255,255,.06);border-radius:8px;transition:all .2s ease}.skill-tag:hover{color:var(--accent);background:rgba(var(--accent-rgb),.12);border-color:rgba(var(--accent-rgb),.3);transform:translateY(-1px)}@media(max-width:640px){.skills-categories{grid-template-columns:1fr}}.contact{padding:3.5rem 2rem 5rem;background:#ffffff05}.contact-container{max-width:600px;margin:0 auto;text-align:center}.contact-text{color:var(--text-muted);font-size:1.125rem;margin-bottom:1rem}.contact-resume{display:inline-block;margin-bottom:1.5rem;padding:.6rem 1.25rem;font-size:.95rem;font-weight:600;color:var(--accent);border:2px solid var(--accent);border-radius:10px;text-decoration:none;transition:all .2s ease}.contact-resume:hover{background:rgba(var(--accent-rgb),.15)}.contact-links{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.contact-link{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:12px;color:var(--text);text-decoration:none;font-weight:500;transition:all .2s ease}.contact-link:hover{background:rgba(var(--accent-rgb),.15);border-color:var(--accent);color:var(--accent)}.contact-icon{font-size:1rem;opacity:.8}.footer{padding:2rem 2rem 2.5rem;background:#0000004d;border-top:1px solid rgba(255,255,255,.06)}.footer-container{max-width:960px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:1.25rem;text-align:center}.footer-links{display:flex;gap:1.5rem}.footer-link{background:none;border:none;color:var(--text-muted);font-size:.95rem;font-weight:500;cursor:pointer;padding:.25rem 0;transition:color .2s ease}.footer-link:hover{color:var(--accent)}.footer-social{display:flex;gap:1rem}.footer-social a{display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:color .2s ease}.footer-social a:hover{color:var(--accent)}.footer-copyright{font-size:.875rem;color:var(--text-muted);margin:0;opacity:.8}.animate-section{opacity:0;transform:translateY(24px);transition:opacity .5s ease,transform .5s ease}.animate-section.visible{opacity:1;transform:translateY(0)}.scroll-to-top{position:fixed;bottom:2rem;right:2rem;z-index:999;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--accent);color:var(--bg);border:none;border-radius:12px;cursor:pointer;box-shadow:0 4px 16px rgba(var(--accent-rgb),.4);transition:all .25s ease}.scroll-to-top:hover{background:var(--accent-light);transform:translateY(-3px);box-shadow:0 6px 24px rgba(var(--accent-rgb),.5)}.scroll-to-top svg{width:24px;height:24px}main{position:relative}
