:root{--bg-primary:#f8f9ff;--bg-card:#fff;--bg-card-hover:#f0f0ff;--text-primary:#1a1a1a;--text-secondary:#555;--text-muted:#888;--border-color:#646cff26;--shadow-card:0 4px 20px #00000014;--navbar-bg:#f8f9ffd9;--hero-text:#fff}[data-theme=dark]{--bg-primary:#0f0f1a;--bg-card:#1a1a2e;--bg-card-hover:#22223a;--text-primary:#e8e8f0;--text-secondary:#aaa;--text-muted:#666;--border-color:#646cff40;--shadow-card:0 4px 20px #0006;--navbar-bg:#0f0f1ad9;--hero-text:#fff}*,:before,:after{box-sizing:border-box}body{margin:0;padding:0}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}.fade-in{opacity:0;transition:opacity .8s ease-out,transform .8s ease-out;transform:translateY(30px)}.fade-in.visible{opacity:1;transform:translateY(0)}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}.fade-in,.skill-badge--animated{opacity:1;transform:none}}html{scroll-behavior:smooth;overflow-x:hidden}body{background-color:var(--bg-primary);font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Arial,sans-serif;transition:background-color .3s,color .3s;overflow-x:hidden}#root{max-width:100%;margin:0;padding:0}main{max-width:1280px;margin:0 auto;padding:2rem}.navbar{z-index:100;background:var(--navbar-bg);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;height:56px;padding:0 2rem;transition:background .3s;display:flex;position:sticky;top:0;box-shadow:0 2px 12px #0000000f}.navbar-brand{color:#646cff;letter-spacing:-.01em;font-size:1.1rem;font-weight:700;text-decoration:none}.navbar-brand:hover{color:#535bf2}.navbar-brand:focus-visible{outline-offset:3px;border-radius:4px;outline:2px solid #646cff}.navbar-controls{align-items:center;gap:.5rem;display:flex}.navbar-links{gap:.25rem;margin:0;padding:0;list-style:none;display:flex}.navbar-links li a{color:var(--text-secondary);border-radius:8px;padding:.4rem .85rem;font-size:.95rem;font-weight:500;text-decoration:none;transition:background .18s,color .18s;display:inline-block}.navbar-links li a:hover{color:#646cff;background:#646cff1a}.navbar-links li a:focus-visible{outline-offset:3px;border-radius:4px;outline:2px solid #646cff}.navbar-theme-toggle{cursor:pointer;width:36px;height:36px;color:var(--text-secondary);background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;padding:6px;transition:background .18s,color .18s;display:inline-flex}.navbar-theme-toggle:hover{color:#646cff;background:#646cff1a}.navbar-theme-toggle:focus-visible{outline-offset:3px;border-radius:4px;outline:2px solid #646cff}.navbar-theme-toggle svg{fill:currentColor;width:18px;height:18px}.navbar-hamburger{cursor:pointer;background:0 0;border:none;border-radius:6px;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;padding:6px;transition:background .18s;display:none}.navbar-hamburger:hover{background:#646cff1a;border-color:#0000}.navbar-hamburger:focus-visible{outline-offset:3px;border-radius:4px;outline:2px solid #646cff}.navbar-hamburger span{background:var(--text-secondary);border-radius:2px;height:2px;transition:transform .25s,opacity .25s;display:block}.navbar-hamburger.open span:first-child{transform:translateY(7px)rotate(45deg)}.navbar-hamburger.open span:nth-child(2){opacity:0}.navbar-hamburger.open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}@media (max-width:640px){.navbar{flex-wrap:wrap;height:auto;padding:.6rem 1rem}.navbar-hamburger{display:flex}.navbar-links{flex-direction:column;gap:0;width:100%;padding:.5rem 0 .75rem;display:none}.navbar-links.open{display:flex}.navbar-links li a{border-radius:6px;padding:.6rem .5rem;display:block}.navbar-controls{gap:.25rem}}.hero-header{color:#fff;background:linear-gradient(135deg,#646cff 0%,#0ea5e9 100%);width:100vw;margin-left:calc(50% - 50vw);padding:5rem 2rem;position:relative;overflow:hidden}.hero-content{z-index:1;justify-content:space-between;align-items:center;gap:3rem;max-width:1100px;margin:0 auto;display:flex;position:relative}.hero-blob{pointer-events:none;z-index:0;opacity:.55;filter:blur(70px);border-radius:50%;position:absolute}.hero-blob--1{background:#a78bfaa6;width:340px;height:340px;animation:8s ease-in-out infinite alternate float1;top:-80px;left:-60px}.hero-blob--2{background:#38bdf88c;width:280px;height:280px;animation:10s ease-in-out -3s infinite alternate float2;bottom:-60px;right:5%}.hero-blob--3{background:#646cff99;width:220px;height:220px;animation:7s ease-in-out -1.5s infinite alternate float3;top:30%;right:20%}.hero-blob--4{background:#0ea5e980;width:180px;height:180px;animation:9s ease-in-out -4s infinite alternate float3;bottom:10%;left:30%}@keyframes float1{0%{transform:translateY(0)translate(0)}to{transform:translateY(-12px)translate(8px)}}@keyframes float2{0%{transform:translateY(0)translate(0)}to{transform:translateY(10px)translate(-10px)}}@keyframes float3{0%{transform:translateY(0)translate(0)}to{transform:translateY(-8px)translate(-12px)}}.hero-text{flex-direction:column;flex:1;gap:1.25rem;display:flex}.hero-text h1{letter-spacing:-.02em;margin:0;font-size:3rem;font-weight:800;line-height:1.15}.hero-subtitle{opacity:.95;flex-wrap:wrap;align-items:center;gap:.3rem;min-height:2rem;margin:0;font-size:1.4rem;display:flex}.hero-typewriter{color:#e0e7ff;align-items:center;font-weight:700;display:inline-flex}.hero-cursor{margin-left:1px;font-weight:300;animation:.9s step-start infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-cta{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(6px);background:#ffffff2e;border:2px solid #ffffff8c;border-radius:999px;align-self:flex-start;align-items:center;gap:.4rem;padding:.7rem 1.6rem;font-size:1rem;font-weight:600;transition:background .2s,transform .2s,box-shadow .2s;display:inline-flex}.hero-cta:hover{background:#ffffff4d;transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.hero-cta:focus-visible{outline-offset:3px;outline:2px solid #fff}.hero-avatar{color:#fff;letter-spacing:-.03em;-webkit-user-select:none;user-select:none;background:linear-gradient(135deg,#a78bfa 0%,#818cf8 50%,#38bdf8 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:160px;height:160px;font-size:3rem;font-weight:800;display:flex;box-shadow:0 0 0 4px #ffffff4d,0 12px 32px #0003}@media (max-width:768px){.hero-header{padding:3rem 1.5rem}.hero-content{text-align:center;flex-direction:column-reverse;align-items:center;gap:2rem}.hero-text{align-items:center}.hero-text h1{font-size:2rem}.hero-subtitle{justify-content:center;font-size:1.1rem}.hero-avatar{width:110px;height:110px;font-size:2.1rem}.hero-blob--1{width:200px;height:200px}.hero-blob--2{width:160px;height:160px}.hero-blob--3{width:130px;height:130px}.hero-blob--4{width:110px;height:110px}}@media (max-width:480px){.hero-header{padding:2rem 1rem}.hero-text h1{font-size:1.6rem}.hero-subtitle{font-size:1rem}.hero-avatar{width:90px;height:90px;font-size:1.7rem}}.about{border:1px solid var(--border-color);box-shadow:var(--shadow-card);background:linear-gradient(135deg,#646cff1a,#0ea5e90f);border-radius:18px;max-width:1100px;margin:2rem auto;padding:2.5rem 2rem}.about h2{color:var(--text-primary);text-align:center;margin-bottom:1.2rem;font-size:2.4rem}.about p{color:var(--text-secondary);max-width:820px;margin:.8rem auto;font-size:1.1rem;line-height:1.75}.about p+p{margin-top:1rem}@media (max-width:768px){.about{padding:1.8rem 1.2rem}.about h2{font-size:2rem}.about p{max-width:100%;font-size:1rem}}.projects-section{border:1px solid var(--border-color);box-shadow:var(--shadow-card);background:linear-gradient(135deg,#646cff1a,#0ea5e90f);border-radius:18px;max-width:1100px;margin:2rem auto;padding:2.5rem 2rem}.projects-section h2{color:var(--text-primary);text-align:center;margin-bottom:1.8rem;font-size:2.4rem}.projects-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;display:grid}.project-card{background:var(--bg-card);border:1px solid var(--border-color);box-shadow:var(--shadow-card);border-radius:14px;flex-direction:column;justify-content:space-between;transition:transform .25s,box-shadow .25s,background .3s;display:flex;overflow:hidden}.project-card:hover{background:var(--bg-card-hover);transform:scale(1.02);box-shadow:0 16px 36px #646cff2e}.project-card-body{padding:1.5rem 1.5rem 1rem}.project-title{color:var(--text-primary);margin-bottom:.6rem;font-size:1.25rem}.project-description{color:var(--text-secondary);margin:0;font-size:.95rem;line-height:1.65}.project-card-footer{border-top:1px solid var(--border-color);flex-direction:column;gap:.75rem;padding:1rem 1.5rem 1.25rem;display:flex}.project-stack{flex-wrap:wrap;gap:.45rem;display:flex}.stack-badge{letter-spacing:.02em;color:var(--text-primary);border:1px solid;border-radius:20px;align-items:center;padding:.2rem .65rem;font-size:.78rem;font-weight:600;display:inline-flex}[data-theme=dark] .stack-badge{color:#e8e8f0}.project-github-link{color:#646cff;align-items:center;gap:.4rem;width:fit-content;font-size:.9rem;font-weight:600;text-decoration:none;transition:color .2s;display:inline-flex}.project-github-link:hover{color:#535bf2}.project-github-link:focus-visible{outline-offset:3px;border-radius:4px;outline:2px solid #646cff}.project-github-link svg{width:18px;height:18px}.card-github-private{color:var(--text-muted);align-items:center;font-size:.9rem;font-style:italic;font-weight:600;display:inline-flex}@media (max-width:768px){.projects-section{padding:1.8rem 1.2rem}.projects-section h2{font-size:2rem}.projects-grid{grid-template-columns:1fr}}.flag-icon{vertical-align:middle;margin-left:.4rem;font-size:.9em}.cv-wrapper{max-width:1100px;box-shadow:var(--shadow-card);background:linear-gradient(135deg,#646cff1f,#0ea5e914);border-radius:16px;margin:2rem auto;padding:3rem 2rem}.cv-wrapper h2{color:var(--text-primary);text-align:center;margin-bottom:2rem;font-size:2.8rem}.cv-content{flex-direction:column;gap:2rem;display:flex}.cv-header{text-align:center;background:var(--bg-card);box-shadow:var(--shadow-card);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem 1rem;transition:background .3s}.cv-header h3{color:var(--text-primary);margin-bottom:.5rem;font-size:2.2rem}.cv-header p{color:var(--text-secondary);margin:.25rem 0}.cv-header p a{color:#646cff;font-weight:500;text-decoration:none}.cv-header p a:hover{color:#535bf2;text-decoration:underline}.cv-download-btn{color:#fff;background:linear-gradient(135deg,#646cff,#0ea5e9);border-radius:999px;align-items:center;gap:.4rem;margin-top:1rem;padding:.55rem 1.3rem;font-size:.95rem;font-weight:600;text-decoration:none;transition:opacity .2s,transform .2s;display:inline-flex;box-shadow:0 4px 14px #646cff59}.cv-download-btn:hover{opacity:.9;transform:translateY(-2px)}.cv-download-btn:focus-visible{outline-offset:3px;border-radius:999px;outline:2px solid #646cff}.cv-section{background:var(--bg-card);box-shadow:var(--shadow-card);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;transition:background .3s}.cv-section h3{color:#646cff;border-bottom:2px solid #646cff40;margin-bottom:1rem;padding-bottom:.5rem;font-size:1.9rem}.cv-item{border-bottom:1px solid var(--border-color);margin-bottom:1.25rem;padding-bottom:.5rem;transition:transform .25s,box-shadow .25s}.cv-item:hover{box-shadow:var(--shadow-card);transform:translateY(-2px)}.cv-item h4{color:var(--text-primary);margin-bottom:.5rem;font-size:1.25rem}.cv-item p{color:var(--text-secondary);line-height:1.65}.cv-skills{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;display:grid}.cv-skills div{border:1px solid var(--border-color);background:linear-gradient(135deg,#646cff1a,#0ea5e914);border-radius:12px;padding:1.25rem;box-shadow:0 10px 18px #0000000d}.cv-skills h4{color:var(--text-primary);margin-bottom:.8rem}.cv-skills p{color:var(--text-secondary);margin:0}.skill-badges{flex-wrap:wrap;gap:.45rem;margin-top:.25rem;display:flex}.skill-badge{letter-spacing:.01em;opacity:1;border:1px solid;border-radius:20px;align-items:center;padding:.25rem .7rem;font-size:.8rem;font-weight:600;display:inline-flex;transform:none}.skill-badge--animated{opacity:0;transition:opacity .5s,transform .5s;transform:translateY(8px)}.skill-badge--animated.visible{opacity:1;transform:translateY(0)}[data-theme=dark] .skill-badge--lang{color:#a5b4fc;background:#a5b4fc1a;border-color:#a5b4fc66}[data-theme=dark] .skill-badge--framework{color:#67e8f9;background:#67e8f91a;border-color:#67e8f966}[data-theme=dark] .skill-badge--tool{color:#6ee7b7;background:#6ee7b71a;border-color:#6ee7b766}[data-theme=dark] .skill-badge--area{color:#fcd34d;background:#fcd34d1a;border-color:#fcd34d66}[data-theme=dark] .skill-badge--soft{color:#f9a8d4;background:#f9a8d41a;border-color:#f9a8d466}.skill-badge--lang{color:#3a3adb;background:#646cff1f;border-color:#646cff73}.skill-badge--framework{color:#0369a1;background:#0ea5e91f;border-color:#0ea5e980}.skill-badge--tool{color:#065f46;background:#10b9811f;border-color:#10b98180}.skill-badge--area{color:#92400e;background:#f59e0b1f;border-color:#f59e0b80}.skill-badge--soft{color:#9d174d;background:#ec48991a;border-color:#ec489973}.timeline{margin-top:.5rem;padding-left:2rem;position:relative}.timeline:before{content:"";background:linear-gradient(#646cff,#0ea5e9);border-radius:2px;width:2px;position:absolute;top:4px;bottom:4px;left:7px}.timeline-item{align-items:flex-start;gap:1.1rem;margin-bottom:1.75rem;display:flex;position:relative}.timeline-item:last-child{margin-bottom:0}.timeline-item:before{content:"";border:2px solid var(--bg-card);z-index:1;background:#646cff;border-radius:50%;flex-shrink:0;width:12px;height:12px;position:absolute;top:.35rem;left:-1.72rem;box-shadow:0 0 0 2px #646cff59}.timeline-date{color:#646cff;letter-spacing:.02em;flex-shrink:0;min-width:130px;padding-top:.25rem;font-size:.8rem;font-weight:600}.timeline-content{flex:1}.timeline-content h4{color:var(--text-primary);margin:0 0 .2rem;font-size:1.1rem;font-weight:700}.timeline-org{color:#646cff;margin:0 0 .35rem;font-size:.875rem;font-weight:600}.timeline-content p:not(.timeline-org){color:var(--text-secondary);margin:0;font-size:.9rem;line-height:1.65}@media (max-width:768px){.cv-wrapper{padding:1.5rem}.cv-skills{grid-template-columns:1fr}.timeline{padding-left:1.25rem}.timeline-item{flex-direction:column;gap:.3rem}.timeline-date{min-width:unset;font-size:.75rem}.timeline-item:before{top:.3rem;left:-1.05rem}}.contact-section{box-shadow:var(--shadow-card);background:linear-gradient(135deg,#646cff14,#0ea5e90f);border-radius:16px;max-width:1100px;margin:2rem auto;padding:4rem 2rem}.contact-section h2{color:var(--text-primary);text-align:center;margin-bottom:2.5rem;font-size:2.6rem;font-weight:800}.contact-inner{grid-template-columns:1fr 1.3fr;align-items:start;gap:3rem;max-width:960px;margin:0 auto;display:grid}.contact-intro{flex-direction:column;gap:1rem;display:flex}.contact-intro-lead{color:#646cff;margin:0;font-size:1.25rem;font-weight:700}.contact-intro p{color:var(--text-secondary);margin:0;line-height:1.7}.contact-details{flex-direction:column;gap:.75rem;margin:.5rem 0 0;padding:0;list-style:none;display:flex}.contact-details li{align-items:center;gap:.6rem;font-size:.95rem;display:flex}.contact-details a{color:#646cff;font-weight:500;text-decoration:none;transition:color .18s}.contact-details a:hover{color:#535bf2;text-decoration:underline}.contact-icon{fill:#646cff;flex-shrink:0;width:18px;height:18px}.contact-form{background:var(--bg-card);-webkit-backdrop-filter:blur(8px);border:1px solid var(--border-color);box-shadow:var(--shadow-card);border-radius:14px;flex-direction:column;gap:1.1rem;padding:2rem;transition:background .3s;display:flex}.form-group{flex-direction:column;gap:.4rem;display:flex}.form-group label{color:var(--text-secondary);font-size:.875rem;font-weight:600}.form-group input,.form-group textarea{border:1px solid var(--border-color);width:100%;color:var(--text-primary);background:var(--bg-card);resize:vertical;border-radius:8px;padding:.65rem .9rem;font-family:inherit;font-size:.95rem;transition:border-color .18s,box-shadow .18s,background .3s,color .3s}.form-group input:focus,.form-group textarea:focus{border-color:#646cff;outline:none;box-shadow:0 0 0 3px #646cff26}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}.contact-submit{color:#fff;cursor:pointer;background:linear-gradient(135deg,#646cff,#0ea5e9);border:none;border-radius:999px;justify-content:center;align-self:flex-end;align-items:center;gap:.4rem;padding:.75rem 1.8rem;font-size:1rem;font-weight:700;transition:opacity .2s,transform .2s,box-shadow .2s;display:inline-flex;box-shadow:0 4px 14px #646cff66}.contact-submit:hover{opacity:.9;transform:translateY(-2px);box-shadow:0 6px 20px #646cff73}.contact-submit:focus-visible{outline-offset:3px;border-radius:999px;outline:2px solid #646cff}.contact-submit:disabled{opacity:.65;cursor:not-allowed;transform:none}.contact-feedback{border-radius:8px;margin:0;padding:.5rem .75rem;font-size:.9rem;font-weight:600}.contact-feedback--success{color:#065f46;background:#10b9811f;border:1px solid #10b98166}.contact-feedback--error{color:#991b1b;background:#ef44441a;border:1px solid #ef444459}@media (max-width:768px){.contact-section{padding:2.5rem 1.25rem}.contact-section h2{font-size:2rem}.contact-inner{grid-template-columns:1fr;gap:2rem}.contact-submit{align-self:stretch}}@media (max-width:480px){.contact-form{padding:1.25rem}}.site-footer{text-align:center;color:#ffffffd6;background:#141414eb;padding:2rem 1rem;font-size:.95rem;transition:background .3s}[data-theme=dark] .site-footer{background:#080812f5}.site-footer p{margin:.5rem 0}.footer-links{justify-content:center;gap:1rem;margin:1rem 0 0;display:flex}.footer-link{color:#ffffffe6;background:#ffffff1f;border:1px solid #ffffff2e;border-radius:999px;align-items:center;gap:.5rem;padding:.6rem .9rem;text-decoration:none;transition:transform .2s,background .2s;display:inline-flex}.footer-link:hover{background:#fff3;transform:translateY(-2px)}.footer-link:focus-visible{outline-offset:3px;border-radius:4px;outline:2px solid #fffc}.footer-link svg{fill:#ffffffe6;width:20px;height:20px}.footer-link span{display:none}@media (min-width:640px){.footer-link span{display:inline}}
