*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#f8fafc;--bg-secondary:#f1f5f9;--bg-card:#fff;--bg-card-hover:#f8fafc;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--accent-blue:#2563eb;--accent-indigo:#4f46e5;--accent-cyan:#0891b2;--accent-emerald:#059669;--border:#e2e8f0;--border-light:#f1f5f9;--shadow-sm:0 1px 3px #0000000d,0 1px 2px #0000000f;--shadow-md:0 4px 16px #0000000f,0 2px 6px #0000000a;--shadow-lg:0 10px 40px #00000014,0 4px 12px #0000000f;--shadow-xl:0 20px 60px #0000001a,0 8px 24px #00000012;--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--radius-xl:28px;--font-display:"Syne",sans-serif;--font-body:"DM Sans",sans-serif;--font-mono:"JetBrains Mono",monospace}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f8fafc;background:var(--bg-primary);color:#0f172a;color:var(--text-primary);font-family:DM Sans,sans-serif;font-family:var(--font-body);line-height:1.6;overflow-x:hidden}::selection{background:#2563eb26;color:#2563eb;color:var(--accent-blue)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#f1f5f9;background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#2563eb,#4f46e5);background:linear-gradient(to bottom,var(--accent-blue),var(--accent-indigo));border-radius:3px}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}section{position:relative}.section-label{color:#2563eb;color:var(--accent-blue);font-family:JetBrains Mono,monospace;font-family:var(--font-mono);font-size:.7rem;font-weight:500;letter-spacing:.15em;margin-bottom:.75rem;text-transform:uppercase}.section-title{color:#0f172a;color:var(--text-primary);font-family:Syne,sans-serif;font-family:var(--font-display);font-size:clamp(2rem,4vw,3rem);font-weight:800;line-height:1.1}.gradient-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#2563eb,#4f46e5 50%,#0891b2);background:linear-gradient(135deg,var(--accent-blue) 0,var(--accent-indigo) 50%,var(--accent-cyan) 100%);-webkit-background-clip:text;background-clip:text}.container{margin:0 auto;max-width:1200px;padding:0 2rem}@media (max-width:768px){.container{padding:0 1.25rem}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px #2563eb26}50%{box-shadow:0 0 40px #2563eb4d}}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.navbar{left:0;padding:1rem 0;position:fixed;right:0;top:0;transition:all .3s ease;z-index:1000}.navbar.scrolled{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#f8fafceb;border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);padding:.75rem 0}.navbar-inner{gap:2rem;margin:0 auto;max-width:1200px;padding:0 2rem}.nav-logo,.navbar-inner{align-items:center;display:flex}.nav-logo{color:var(--text-primary);cursor:pointer;font-family:var(--font-mono);font-size:1.1rem;font-weight:500;gap:2px;transition:transform .2s ease}.nav-logo:hover{transform:scale(1.05)}.logo-bracket{color:var(--accent-blue);font-weight:300}.logo-name{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--accent-blue),var(--accent-indigo));-webkit-background-clip:text;background-clip:text;font-weight:700}.nav-links.desktop{align-items:center;display:flex;gap:.25rem;margin-left:auto}.nav-link{background:none;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;font-family:var(--font-body);font-size:.875rem;font-weight:500;padding:.5rem .875rem;transition:all .2s ease}.nav-link:hover{background:#2563eb0f;color:var(--accent-blue)}.cv-download-btn{align-items:center;animation:pulse-glow 3s ease-in-out infinite;background:linear-gradient(135deg,var(--accent-blue),var(--accent-indigo));border-radius:100px;box-shadow:0 4px 14px #2563eb40;color:#fff;display:flex;font-family:var(--font-body);font-size:.85rem;font-weight:600;gap:.5rem;padding:.55rem 1.25rem;text-decoration:none;transition:all .25s ease;white-space:nowrap}.cv-download-btn:hover{box-shadow:0 6px 20px #2563eb59;transform:translateY(-2px)}.cv-download-btn:active{transform:translateY(0)}.hamburger{background:none;border:none;cursor:pointer;display:none;flex-direction:column;gap:5px;margin-left:auto;padding:.5rem}.hamburger span{background:var(--text-primary);border-radius:2px;display:block;height:2px;transform-origin:center;transition:all .3s ease;width:22px}.hamburger.open span:first-child{transform:translateY(7px) rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.mobile-menu{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#f8fafcfa;border-top:1px solid var(--border);display:none;flex-direction:column;gap:.5rem;max-height:0;overflow:hidden;padding:1rem 2rem 1.5rem;transition:max-height .4s ease}.mobile-menu.open{max-height:400px}.mobile-link{background:none;border:none;border-bottom:1px solid var(--border-light);color:var(--text-secondary);cursor:pointer;font-family:var(--font-body);font-size:1rem;font-weight:500;padding:.75rem 0;text-align:left;transition:color .2s ease}.mobile-link:hover{color:var(--accent-blue)}.mobile-cv-btn{background:linear-gradient(135deg,var(--accent-blue),var(--accent-indigo));border-radius:100px;color:#fff;display:block;font-family:var(--font-body);font-size:.9rem;font-weight:600;margin-top:.5rem;padding:.75rem 1.5rem;text-align:center;text-decoration:none}@media (max-width:900px){.nav-links.desktop{display:none}.hamburger,.mobile-menu{display:flex}.cv-download-btn span{display:none}.cv-download-btn{margin-left:auto;padding:.55rem .75rem}}.hero{align-items:center;background:linear-gradient(135deg,#f8fafc,#eff6ff 40%,#eef2ff);display:flex;flex-direction:column;justify-content:center;min-height:100vh;overflow:hidden;padding-top:80px;position:relative}.particle-canvas{height:100%;width:100%}.hero-bg-shapes,.particle-canvas{inset:0;pointer-events:none;position:absolute;z-index:0}.hero-bg-shapes{overflow:hidden}.shape{border-radius:50%;filter:blur(60px);opacity:.25;position:absolute}.shape-1{animation:float 8s ease-in-out infinite;background:radial-gradient(circle,#2563eb66 0,#0000 70%);height:500px;right:-100px;top:-200px;width:500px}.shape-2{animation:float 10s ease-in-out infinite reverse;background:radial-gradient(circle,#4f46e559 0,#0000 70%);bottom:-150px;height:400px;left:-100px;width:400px}.shape-3{animation:float 12s ease-in-out infinite;background:radial-gradient(circle,#0891b24d 0,#0000 70%);height:300px;left:40%;top:50%;width:300px}.hero-inner{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 1fr;padding-bottom:5rem;padding-top:2rem;position:relative;width:100%;z-index:1}.hero-content{opacity:0;transform:translateX(-40px);transition:all .8s cubic-bezier(.16,1,.3,1)}.hero-content.visible{opacity:1;transform:translateX(0)}.hero-badge{align-items:center;background:#fff;border:1px solid var(--border);border-radius:100px;box-shadow:var(--shadow-sm);color:var(--text-secondary);display:inline-flex;font-size:.8rem;font-weight:500;gap:.5rem;margin-bottom:1.5rem;padding:.4rem 1rem}.badge-dot{animation:pulse-dot 2s ease-in-out infinite;background:#22c55e;border-radius:50%;box-shadow:0 0 0 2px #22c55e40;height:8px;width:8px}@keyframes pulse-dot{0%,to{box-shadow:0 0 0 2px #22c55e40}50%{box-shadow:0 0 0 5px #22c55e1a}}.greeting{color:var(--text-secondary);display:block;font-family:var(--font-body);font-size:1.1rem;font-weight:400;margin-bottom:.25rem}.hero-name{font-family:var(--font-display);line-height:1.05;margin-bottom:1rem}.name-main{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#0f172a,#1e3a5f 50%,#2563eb);-webkit-background-clip:text;background-clip:text;font-size:clamp(2.5rem,5vw,4rem);font-weight:800}.hero-title-line{align-items:center;color:var(--accent-blue);display:flex;font-family:var(--font-mono);font-size:clamp(1rem,2vw,1.25rem);font-weight:400;gap:2px;margin-bottom:1.25rem;min-height:2rem}.cursor{animation:blink 1s step-end infinite;color:var(--accent-indigo)}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-summary{color:var(--text-secondary);font-size:1rem;line-height:1.75;margin-bottom:1.5rem;max-width:520px}.hero-summary strong{color:var(--text-primary);font-weight:600}.hero-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem}.hero-tag{background:#2563eb12;border:1px solid #2563eb26;border-radius:6px;color:var(--accent-blue);font-family:var(--font-mono);font-size:.7rem;font-weight:500;padding:.3rem .6rem;transition:all .2s ease}.hero-tag:hover{background:var(--accent-blue);border-color:var(--accent-blue);color:#fff;transform:translateY(-2px)}.hero-ctas{gap:1rem;margin-bottom:2rem}.cta-primary,.hero-ctas{align-items:center;display:flex}.cta-primary{background:linear-gradient(135deg,var(--accent-blue),var(--accent-indigo));border-radius:100px;box-shadow:0 4px 20px #2563eb4d;color:#fff;font-family:var(--font-body);font-size:.95rem;font-weight:600;gap:.5rem;padding:.875rem 1.75rem;text-decoration:none;transition:all .25s ease}.cta-primary:hover{box-shadow:0 8px 30px #2563eb66;transform:translateY(-3px)}.cta-secondary{background:#fff;border:1.5px solid var(--border);border-radius:100px;box-shadow:var(--shadow-sm);color:var(--text-primary);cursor:pointer;font-family:var(--font-body);font-size:.95rem;font-weight:600;padding:.875rem 1.75rem;transition:all .25s ease}.cta-secondary:hover{border-color:var(--accent-blue);box-shadow:var(--shadow-md);color:var(--accent-blue);transform:translateY(-2px)}.hero-socials{display:flex;gap:.75rem}.social-link{align-items:center;background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow-sm);color:var(--text-secondary);display:flex;height:40px;justify-content:center;transition:all .2s ease;width:40px}.social-link:hover{border-color:var(--accent-blue);box-shadow:0 4px 12px #2563eb26;color:var(--accent-blue);transform:translateY(-3px)}.hero-visual{align-items:center;display:flex;justify-content:center;opacity:0;position:relative;transform:translateX(40px);transition:all .8s cubic-bezier(.16,1,.3,1) .2s}.hero-visual.visible{opacity:1;transform:translateX(0)}.photo-wrapper{align-items:center;animation:float 6s ease-in-out infinite;display:flex;justify-content:center;position:relative}.photo-glow{background:radial-gradient(circle,#2563eb33 0,#4f46e51a 50%,#0000 70%);border-radius:50%;filter:blur(20px);height:340px;position:absolute;width:340px}.photo-container{background:#0000;background:linear-gradient(135deg,#eff6ff,#eef2ff);border-radius:var(--radius-xl);box-shadow:0 0 0 1px #2563eb1a,0 20px 60px #2563eb26,0 4px 12px #0000000d;height:380px;overflow:hidden;position:relative;width:300px}.hero-photo{height:100%;mix-blend-mode:multiply;object-fit:cover;object-position:top center;width:100%}.photo-badge{align-items:center;animation:float 5s ease-in-out infinite;background:#fff;border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;padding:.6rem .9rem;position:absolute}.experience-badge{animation-delay:0s;bottom:20px;left:-30px}.transactions-badge{animation-delay:2.5s;right:-30px;top:20px}.badge-number{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--accent-blue),var(--accent-indigo));-webkit-background-clip:text;background-clip:text;font-family:var(--font-display);font-size:1.25rem;font-weight:800;line-height:1}.badge-label{color:var(--text-muted);font-family:var(--font-mono);font-size:.65rem;font-weight:500;letter-spacing:.05em;margin-top:2px;text-transform:uppercase;white-space:nowrap}.tech-orbit{inset:-60px;pointer-events:none}.orbit-center,.tech-orbit{align-items:center;display:flex;justify-content:center;position:absolute}.orbit-center{inset:0}.orbit-ring{border:1px dashed #2563eb26;border-radius:50%;position:absolute}.ring-1{animation:spin-slow 25s linear infinite;height:440px;width:440px}.ring-2{animation:spin-slow 35s linear infinite reverse;height:560px;width:560px}@keyframes spin-slow{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.orbit-item{--radius:220px;animation:spin-slow 25s linear infinite;height:28px;position:absolute;transform:rotate(var(--angle)) translateX(var(--radius)) rotate(calc(var(--angle)*-1));width:80px}.orbit-item span{align-items:center;animation:counter-spin 25s linear infinite;animation-delay:var(--delay);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffe6;border:1px solid #2563eb33;border-radius:100px;box-shadow:var(--shadow-sm);color:var(--accent-blue);display:block;display:flex;font-family:var(--font-mono);font-size:.65rem;font-weight:500;height:100%;justify-content:center;white-space:nowrap;width:100%}@keyframes counter-spin{0%{transform:rotate(0deg)}to{transform:rotate(-1turn)}}.scroll-hint{align-items:center;bottom:2rem;display:flex;flex-direction:column;gap:.5rem;left:50%;position:absolute;transform:translateX(-50%);z-index:1}.scroll-hint span{color:var(--text-muted);font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase}.scroll-mouse{border:2px solid var(--border);border-radius:11px;display:flex;height:34px;justify-content:center;padding-top:5px;width:22px}.scroll-wheel{animation:scroll-anim 1.5s ease infinite;background:var(--accent-blue);border-radius:2px;height:6px;width:3px}@keyframes scroll-anim{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(10px)}}@media (max-width:900px){.hero-inner{gap:2rem;grid-template-columns:1fr;padding-bottom:4rem;padding-top:2rem;text-align:center}.hero-visual{order:-1}.photo-container{height:280px;width:220px}.photo-glow{height:250px;width:250px}.experience-badge{bottom:10px;left:-10px}.transactions-badge{right:-10px;top:10px}.tech-orbit{display:none}.hero-ctas,.hero-tags{justify-content:center}.hero-ctas{flex-wrap:wrap}.hero-socials{justify-content:center}.hero-summary{margin:0 auto 1.5rem}.social-link{height:44px;width:44px}}@media (max-width:480px){.hero-badge{font-size:.72rem}.photo-container{height:240px;width:190px}}.about{background:var(--bg-primary);padding:6rem 0}.about-header{margin-bottom:3.5rem;opacity:0;transform:translateY(20px);transition:all .6s ease}.about-header.visible{opacity:1;transform:translateY(0)}.about-grid{grid-gap:4rem;align-items:start;display:grid;gap:4rem;grid-template-columns:1fr 1fr}.about-text{opacity:0;transform:translateX(-20px);transition:all .7s ease .1s}.about-text.visible{opacity:1;transform:translateX(0)}.about-text p{color:var(--text-secondary);font-size:.975rem;line-height:1.8;margin-bottom:1.25rem}.about-text p strong{color:var(--text-primary);font-weight:600}.about-highlights{display:flex;flex-direction:column;gap:1rem;margin-top:2rem}.highlight-item{align-items:flex-start;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);display:flex;gap:1rem;padding:1rem 1.25rem;transition:all .25s ease}.highlight-item:hover{border-color:#2563eb33;box-shadow:var(--shadow-md);transform:translateX(4px)}.hi-icon{flex-shrink:0;font-size:1.5rem;margin-top:2px}.highlight-item strong{color:var(--text-primary);display:block;font-size:.9rem;font-weight:600;margin-bottom:.2rem}.highlight-item p{color:var(--text-muted);font-size:.82rem;line-height:1.5;margin:0!important}.about-right{display:flex;flex-direction:column;gap:1.5rem}.stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);opacity:0;padding:1.25rem;text-align:center;transform:translateY(20px) scale(.95);transition:all .5s cubic-bezier(.16,1,.3,1);transition-delay:0s;transition-delay:var(--delay,0s)}.stat-card.visible{opacity:1;transform:translateY(0) scale(1)}.stat-card:hover{border-color:#2563eb33;box-shadow:var(--shadow-md);transform:translateY(-4px) scale(1.02)}.stat-icon{font-size:1.5rem;margin-bottom:.5rem}.stat-number{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--accent-blue),var(--accent-indigo));-webkit-background-clip:text;background-clip:text;font-family:var(--font-display);font-size:1.75rem;font-weight:800;line-height:1;margin-bottom:.25rem}.stat-label{color:var(--text-muted);font-family:var(--font-mono);font-size:.75rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.languages-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:1.5rem}.domain-title,.lang-title{align-items:center;color:var(--text-primary);display:flex;font-family:var(--font-display);font-size:.95rem;font-weight:700;gap:.5rem;margin-bottom:1.25rem}.lang-list{display:flex;flex-direction:column;gap:1rem}.lang-meta{align-items:baseline;display:flex;justify-content:space-between;margin-bottom:.4rem}.lang-name{color:var(--text-primary);font-size:.875rem;font-weight:600}.lang-level{color:var(--text-muted);font-family:var(--font-mono);font-size:.72rem;letter-spacing:.05em;text-transform:uppercase}.lang-bar{background:var(--bg-secondary);border-radius:3px;height:5px;overflow:hidden}.lang-fill{background:var(--accent-blue);background:var(--color,var(--accent-blue));border-radius:3px;height:100%;transition:width 1.2s cubic-bezier(.16,1,.3,1) .3s;width:0}.lang-fill.filled{width:0;width:var(--pct,0)}.domain-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:1.5rem}.domain-tags{display:flex;flex-wrap:wrap;gap:.5rem}.domain-tag{background:linear-gradient(135deg,#2563eb12,#4f46e512);border:1px solid #4f46e526;border-radius:100px;color:var(--accent-indigo);font-size:.8rem;font-weight:500;padding:.4rem .85rem;transition:all .2s ease}.domain-tag:hover{background:linear-gradient(135deg,var(--accent-blue),var(--accent-indigo));border-color:#0000;color:#fff}@media (max-width:900px){.about-grid{gap:2.5rem;grid-template-columns:1fr}}@media (max-width:480px){.stats-grid{gap:.75rem;grid-template-columns:1fr 1fr}}.skills{background:var(--bg-secondary);overflow:hidden;padding:6rem 0;position:relative}.skills-bg{background:radial-gradient(ellipse 60% 40% at 20% 20%,#2563eb0d 0,#0000 60%),radial-gradient(ellipse 50% 50% at 80% 80%,#4f46e50d 0,#0000 60%);inset:0;position:absolute}.skills-header{margin-bottom:2.5rem;opacity:0;transform:translateY(20px);transition:all .6s ease}.skills-header.visible{opacity:1;transform:translateY(0)}.skills-subtitle{color:var(--text-muted);font-family:var(--font-mono);font-size:.9rem;margin-top:.75rem}.tech-cloud{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2.5rem}.tech-pill{animation:pill-in .4s ease forwards;animation-delay:0 * .08s;animation-delay:var(--i,0) * .08s;background:var(--bg-card);border:1px solid var(--border);border-radius:100px;box-shadow:var(--shadow-sm);color:var(--text-secondary);cursor:default;font-family:var(--font-mono);font-size:.72rem;font-weight:500;opacity:0;padding:.35rem .75rem;transition:all .2s ease}.tech-pill:hover{background:var(--accent-blue);border-color:var(--accent-blue);box-shadow:0 4px 12px #2563eb33;color:#fff;transform:translateY(-2px) scale(1.05)}@keyframes pill-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.skill-categories{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.skill-category-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);cursor:pointer;opacity:0;padding:1.25rem;transform:translateY(20px);transition:all .4s cubic-bezier(.16,1,.3,1);transition-delay:0s;transition-delay:var(--delay,0s)}.skill-category-card.visible{opacity:1;transform:translateY(0)}.skill-category-card:hover{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),var(--shadow-md);transform:translateY(-3px)}.skill-category-card.active{border-color:var(--accent);box-shadow:0 0 0 2px rgba(var(--accent),.3),var(--shadow-lg);grid-column:span 1}.cat-header{gap:.75rem}.cat-header,.cat-icon{align-items:center;display:flex}.cat-icon{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:1.4rem;height:44px;justify-content:center;width:44px}.cat-label{color:var(--text-primary);flex:1 1;font-family:var(--font-display);font-size:1rem;font-weight:700}.cat-count{background:var(--bg-secondary);border-radius:100px;color:var(--text-muted);font-family:var(--font-mono);font-size:.7rem;padding:.2rem .5rem}.cat-skills{border-top:1px solid var(--border-light);display:flex;flex-direction:column;gap:.75rem;margin-top:1.25rem;padding-top:1.25rem}.skill-bar-meta{align-items:center;display:flex;justify-content:space-between;margin-bottom:.35rem}.skill-bar-name{color:var(--text-primary);font-size:.82rem;font-weight:500}.skill-bar-pct{color:var(--text-muted);font-family:var(--font-mono);font-size:.7rem;font-weight:500}.skill-bar-track{background:var(--bg-secondary);border-radius:3px;height:5px;overflow:hidden}.skill-bar-fill{background:var(--accent-blue);background:var(--color,var(--accent-blue));border-radius:3px;height:100%;transition:width 1s cubic-bezier(.16,1,.3,1) .2s;width:0}.skill-bar-fill.filled{width:0;width:var(--pct,0)}@media (max-width:768px){.skill-categories{grid-template-columns:1fr}}.experience{background:var(--bg-primary);padding:6rem 0}.exp-header-section{margin-bottom:3.5rem;opacity:0;transform:translateY(20px);transition:all .6s ease}.exp-header-section.visible{opacity:1;transform:translateY(0)}.exp-subtitle{color:var(--text-muted);font-family:var(--font-mono);font-size:.9rem;margin-top:.75rem}.timeline{padding-left:2.5rem;position:relative}.timeline-line{background:linear-gradient(to bottom,var(--accent-blue),var(--accent-indigo),#4f46e51a);border-radius:1px;bottom:0;left:8px;position:absolute;top:0;width:2px}.exp-card{margin-bottom:1.25rem;opacity:0;position:relative;transform:translateX(-20px);transition:all .5s cubic-bezier(.16,1,.3,1);transition-delay:0s;transition-delay:var(--delay,0s)}.exp-card.visible{opacity:1;transform:translateX(0)}.exp-timeline-dot{border:3px solid #fff;border-radius:50%;box-shadow:0 0 0 2px var(--accent);height:14px;left:-2.5rem;position:absolute;top:1.5rem;width:14px;z-index:1}.dot-pulse{animation:pulse-ring 2s ease-out infinite;background:var(--accent);border-radius:50%;inset:-4px;opacity:.3;position:absolute}@keyframes pulse-ring{0%{opacity:.3;transform:scale(1)}to{opacity:0;transform:scale(2)}}.exp-card-inner{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);cursor:pointer;padding:1.5rem;transition:all .25s ease}.exp-card-inner:hover{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),var(--shadow-md)}.exp-card.current .exp-card-inner{background:linear-gradient(135deg,#fff,#2563eb05);border-color:var(--accent)}.exp-header{align-items:flex-start;display:flex;gap:1rem;margin-bottom:1rem}.exp-meta{flex:1 1}.current-badge{background:linear-gradient(135deg,var(--accent-blue),var(--accent-indigo));border-radius:100px;color:#fff;display:inline-block;font-family:var(--font-mono);font-size:.65rem;font-weight:600;letter-spacing:.1em;margin-bottom:.4rem;padding:.2rem .6rem;text-transform:uppercase}.exp-role{color:var(--text-primary);font-family:var(--font-display);font-size:1.1rem;font-weight:700;margin-bottom:.2rem}.exp-company{font-size:.875rem;font-weight:600}.exp-time{flex-shrink:0;text-align:right}.exp-period{font-family:var(--font-mono);margin-bottom:.2rem}.exp-location,.exp-period{color:var(--text-muted);display:block;font-size:.75rem}.exp-toggle{align-items:center;background:none;border:none;border-radius:8px;color:var(--text-muted);cursor:pointer;display:flex;flex-shrink:0;height:32px;justify-content:center;transition:all .2s ease;width:32px}.exp-toggle:hover{background:var(--bg-secondary);color:var(--text-primary)}.exp-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.5rem}.exp-tag{background:rgba(var(--color),.08);background:color-mix(in srgb,var(--color) 8%,#fff);border:1px solid color-mix(in srgb,var(--color) 20%,#0000);border-radius:5px;color:var(--color);font-family:var(--font-mono);font-size:.68rem;font-weight:500;padding:.25rem .6rem}.exp-bullets{border-top:1px solid var(--border-light);display:flex;flex-direction:column;gap:.6rem;list-style:none;margin-top:1rem;padding-top:1rem}.exp-bullet{align-items:flex-start;color:var(--text-secondary);display:flex;font-size:.875rem;gap:.75rem;line-height:1.6}.bullet-dot{border-radius:50%;flex-shrink:0;height:6px;margin-top:.45rem;width:6px}@media (max-width:768px){.timeline{padding-left:1.75rem}.exp-timeline-dot{left:-1.75rem}.exp-header{flex-wrap:wrap}.exp-time{text-align:left}.exp-toggle{position:absolute;right:1rem;top:1rem}}.certifications{background:var(--bg-secondary);overflow:hidden;padding:6rem 0;position:relative}.cert-bg{background:radial-gradient(ellipse 50% 60% at 80% 50%,#2563eb0a 0,#0000 60%);inset:0;position:absolute}.cert-header{margin-bottom:3rem;opacity:0;transform:translateY(20px);transition:all .6s ease}.cert-header.visible{opacity:1;transform:translateY(0)}.cert-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));margin-bottom:2rem;position:relative;z-index:1}.cert-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1rem;opacity:0;overflow:hidden;padding:1.75rem 1.5rem;position:relative;transform:translateY(20px) scale(.97);transition:all .5s cubic-bezier(.16,1,.3,1);transition-delay:0s;transition-delay:var(--delay,0s)}.cert-card.visible{opacity:1;transform:translateY(0) scale(1)}.cert-card:hover{border-color:var(--color);box-shadow:0 0 0 1px var(--color),var(--shadow-lg);transform:translateY(-6px)}.cert-badge-mark{background:var(--color);border-radius:0 var(--radius-lg) 0 60px;height:60px;opacity:.06;position:absolute;right:0;top:0;width:60px}.cert-icon-wrap{align-items:center;background:color-mix(in srgb,var(--color) 10%,#fff);border:1px solid color-mix(in srgb,var(--color) 20%,#0000);border-radius:var(--radius-md);display:flex;font-size:1.5rem;height:52px;justify-content:center;width:52px}.cert-title{color:var(--text-primary);font-family:var(--font-display);font-size:.975rem;font-weight:700;line-height:1.3;margin-bottom:.3rem}.cert-issuer{color:var(--text-muted);font-size:.82rem;margin-bottom:.5rem}.cert-note{background:color-mix(in srgb,var(--color) 10%,#fff);border-radius:100px;color:var(--color);font-family:var(--font-mono);font-size:.68rem;font-weight:600;letter-spacing:.08em;padding:.2rem .6rem;text-transform:uppercase}.info-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-bottom:2.5rem;opacity:0;transform:translateY(20px);transition:all .6s ease .4s}.info-grid.visible{opacity:1;transform:translateY(0)}.info-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:1.25rem;transition:all .2s ease}.info-card:hover{border-color:#2563eb33;box-shadow:var(--shadow-md)}.info-label{color:var(--accent-blue);display:block;font-family:var(--font-mono);font-size:.68rem;font-weight:600;letter-spacing:.1em;margin-bottom:.5rem;text-transform:uppercase}.info-items{color:var(--text-secondary);font-size:.875rem;line-height:1.6}.relocation-banner{opacity:0;transform:translateY(20px);transition:all .6s ease .6s}.relocation-banner.visible{opacity:1;transform:translateY(0)}.relocation-inner{align-items:center;background:linear-gradient(135deg,var(--accent-blue) 0,var(--accent-indigo) 100%);border-radius:var(--radius-xl);box-shadow:0 10px 40px #2563eb40;color:#fff;display:flex;gap:1.5rem;padding:2rem 2.5rem}.relocation-icon{animation:float 4s ease-in-out infinite;flex-shrink:0;font-size:2.5rem}.relocation-text{flex:1 1}.relocation-text h3{color:#fff;font-family:var(--font-display);font-size:1.15rem;font-weight:700;margin-bottom:.4rem}.relocation-text p{font-size:.875rem;line-height:1.6;opacity:.85}.relocation-cta{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:1.5px solid #ffffff4d;border-radius:100px;color:#fff;flex-shrink:0;font-size:.875rem;font-weight:600;padding:.75rem 1.5rem;text-decoration:none;transition:all .25s ease;white-space:nowrap}.relocation-cta:hover{background:#ffffff40;transform:translateX(4px)}@media (max-width:768px){.relocation-inner{flex-direction:column;padding:2rem 1.5rem;text-align:center}.relocation-cta{text-align:center;width:100%}}.contact{background:var(--bg-primary);padding:6rem 0}.contact-header{margin-bottom:3.5rem;opacity:0;transform:translateY(20px);transition:all .6s ease}.contact-header.visible{opacity:1;transform:translateY(0)}.contact-subtitle{color:var(--text-secondary);font-size:1rem;line-height:1.7;margin-top:1rem;max-width:600px}.contact-grid{grid-gap:3rem;align-items:start;display:grid;gap:3rem;grid-template-columns:1fr 1fr}.contact-info{opacity:0;transform:translateX(-20px);transition:all .6s ease .1s}.contact-info.visible{opacity:1;transform:translateX(0)}.contact-links{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.contact-link-card{align-items:center;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);display:flex;gap:1rem;padding:1rem 1.25rem;text-decoration:none;transition:all .25s ease}.contact-link-card:hover{border-color:var(--color);box-shadow:0 0 0 1px var(--color),var(--shadow-md);transform:translateX(6px)}.contact-link-icon{align-items:center;background:color-mix(in srgb,var(--color) 10%,#fff);border-radius:var(--radius-sm);color:var(--color);display:flex;flex-shrink:0;height:42px;justify-content:center;width:42px}.contact-link-info{display:flex;flex:1 1;flex-direction:column}.contact-link-label{color:var(--text-muted);font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;margin-bottom:.15rem;text-transform:uppercase}.contact-link-value{color:var(--text-primary);font-size:.875rem;font-weight:500}.contact-arrow{color:var(--text-muted);opacity:0;transform:translateX(-6px);transition:all .2s ease}.contact-link-card:hover .contact-arrow{color:var(--color);opacity:1;transform:translateX(0)}.availability-card{align-items:flex-start;background:linear-gradient(135deg,#0596690d,#2563eb0d);border:1px solid #05966933;border-radius:var(--radius-md);display:flex;gap:1rem;padding:1.25rem}.avail-dot{animation:pulse-dot 2s ease-in-out infinite;background:#22c55e;border-radius:50%;box-shadow:0 0 0 3px #22c55e33;flex-shrink:0;height:10px;margin-top:4px;width:10px}.availability-card strong{color:var(--text-primary);display:block;font-size:.9rem;font-weight:600;margin-bottom:.25rem}.availability-card p{color:var(--text-muted);font-size:.82rem;line-height:1.5}.contact-form-wrap{opacity:0;transform:translateX(20px);transition:all .6s ease .2s}.contact-form-wrap.visible{opacity:1;transform:translateX(0)}.contact-form{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:2rem}.form-title{color:var(--text-primary);font-family:var(--font-display);font-size:1.1rem;font-weight:700;margin-bottom:1.5rem}.form-group{margin-bottom:1.25rem}.form-group label{color:var(--text-secondary);display:block;font-family:var(--font-mono);font-size:.82rem;font-weight:500;margin-bottom:.4rem}.form-group input,.form-group textarea{background:var(--bg-secondary);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-body);font-size:.9rem;outline:none;padding:.75rem 1rem;resize:vertical;transition:all .2s ease;width:100%}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}.form-group input:focus,.form-group textarea:focus{background:#fff;border-color:var(--accent-blue);box-shadow:0 0 0 3px #2563eb14}.form-submit{background:linear-gradient(135deg,var(--accent-blue),var(--accent-indigo));border:none;border-radius:100px;box-shadow:0 4px 14px #2563eb40;color:#fff;cursor:pointer;font-family:var(--font-body);font-size:.95rem;font-weight:600;padding:.9rem 2rem;transition:all .25s ease;width:100%}.form-submit:hover{box-shadow:0 6px 20px #2563eb59;transform:translateY(-2px)}.form-submit:disabled{box-shadow:none;cursor:not-allowed;opacity:.65;transform:none}.form-submit.sent{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 14px #05966940}.form-note{color:#dc2626;font-size:.9rem;line-height:1.4;margin-top:1rem}@media (max-width:900px){.contact-grid{gap:2rem;grid-template-columns:1fr}}.footer{background:var(--text-primary);color:#fff;padding:3rem 0 2rem}.footer-inner{align-items:flex-start;display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between;margin-bottom:2rem}.footer-logo{display:block;font-family:var(--font-mono);font-size:1.2rem;font-weight:700;margin-bottom:.6rem}.bracket{color:var(--accent-blue);font-weight:300}.footer-brand p{font-size:.85rem;line-height:1.6;opacity:.6}.footer-location{font-size:.82rem!important;margin-top:.25rem}.footer-links{align-items:center;display:flex;flex-wrap:wrap;gap:1.25rem}.footer-link{color:#fff9;font-size:.875rem;font-weight:500;text-decoration:none;transition:color .2s ease}.footer-link:hover{color:#fff}.footer-cv{background:#2563ebcc;border-radius:100px;color:#fff!important;font-size:.82rem;padding:.5rem 1.1rem;transition:all .2s ease!important}.footer-cv:hover{background:var(--accent-blue);transform:translateY(-1px)}.footer-bottom{align-items:center;border-top:1px solid #ffffff14;display:flex;flex-wrap:wrap;gap:.75rem;justify-content:space-between;padding-top:1.5rem}.footer-bottom p{font-size:.8rem;opacity:.45}.footer-tech{font-family:var(--font-mono);font-size:.72rem!important}@media (max-width:600px){.footer-bottom,.footer-inner{flex-direction:column}.footer-bottom{align-items:flex-start;gap:.5rem}}.App{background:var(--bg-primary);min-height:100vh}
/*# sourceMappingURL=main.bd0c5be8.css.map*/