.logo[data-v-94d95811]{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo[data-v-94d95811]:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.vue[data-v-94d95811]:hover{filter:drop-shadow(0 0 2em #42b883aa)}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}header{position:relative;width:100%;background-color:#1a1a1acc;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:1000;transition:all .3s ease;animation:slideDown .6s ease-out}header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent 0%,rgba(255,255,255,.08) 20%,rgba(255,255,255,.12) 50%,rgba(255,255,255,.08) 80%,transparent 100%)}header.scrolled{box-shadow:0 2px 20px #0000004d}header nav{width:100%;max-width:1200px;margin:0 auto;padding:1.5rem 2rem;animation:fadeInUp .8s ease-out .2s both}@media(max-width:768px){header nav{padding:1rem 1.5rem}}header ul{display:flex;list-style:none;margin:0;padding:0;gap:2rem;align-items:center;justify-content:flex-start}@media(max-width:768px){header ul{gap:1.5rem}}@media(max-width:480px){header ul{gap:1rem;flex-wrap:wrap}}.language-selector{margin-left:auto;opacity:1!important;animation:none!important}.language-selector:after{display:none}.language-selector select{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:4px;color:#ffffffde;padding:.5rem 1rem;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s ease;font-family:inherit;text-transform:uppercase;letter-spacing:.05em}.language-selector select:hover{background:#ffffff14;border-color:#646cff}.language-selector select:focus{outline:2px solid #646cff;outline-offset:2px}.language-selector select option{background:#1a1a1acc;color:#ffffffde}@media(max-width:768px){.language-selector{margin-left:0}}header li{position:relative;margin:0;padding:0;opacity:0;animation:fadeInUp .5s ease-out forwards}header li:nth-child(1){animation-delay:.5s}header li:nth-child(2){animation-delay:.6s}header li:nth-child(3){animation-delay:.7s}header li:nth-child(4){animation-delay:.8s}header li:nth-child(5){animation-delay:.9s}header li:after{content:"";position:absolute;bottom:-5px;left:0;width:0;height:2px;background-color:#646cff;transition:width all .3s ease}header li:hover:after{width:100%}header a{display:inline-block;color:#ffffffde;text-decoration:none;font-weight:500;font-size:.95rem;letter-spacing:.05em;text-transform:uppercase;padding:.5rem 0;transition:all .3s ease;position:relative}header a:link,header a:visited{color:#ffffffde}header a:hover{color:#646cff;transform:translateY(-2px)}header a.router-link-active,header a.router-link-exact-active{color:#535bf2;font-weight:600}header a.router-link-active:after,header a.router-link-exact-active:after{content:"";position:absolute;bottom:-5px;left:0;width:100%;height:2px;background-color:#535bf2}header a:focus{outline:2px solid #646cff;outline-offset:4px;border-radius:4px}header a:active{transform:translateY(0)}@media(max-width:480px){nav ul{justify-content:center}nav a{font-size:.85rem;padding:.4rem 0}}@keyframes slideDownFade{0%{transform:translateY(-30px);opacity:0}to{transform:translateY(0);opacity:1}}header{animation:slideDownFade .7s cubic-bezier(.4,0,.2,1)}.container-home{width:100%;max-width:1200px;margin:0 auto;padding:2rem;color:#ffffffde;animation:fadeIn .5s ease-out}@media(max-width:768px){.container-home{padding:1rem}}.container-home-content{display:flex;flex-direction:column;gap:6rem}.home-content-item{display:flex;flex-direction:column;gap:2rem}.home-content-item img{width:20px;height:20px;object-fit:contain}.home-content-top{position:relative;min-height:500px;border-radius:8px;overflow:hidden;background-size:cover;background-position:center;background-repeat:no-repeat;animation:fadeIn .6s ease-out .2s both}.home-content-top:before{content:"";position:absolute;inset:0;background:linear-gradient(to right,#1a1a1ad9,#1a1a1ab3,#1a1a1a4d);z-index:1}.home-content-top .card-section-item{position:relative;z-index:2;width:50%;max-width:600px;padding:2rem;display:flex;flex-direction:column;gap:1.5rem;opacity:0;animation:fadeInUp .6s ease-out forwards}.home-content-top .card-section-item:nth-child(1){animation-delay:.4s}.home-content-top .card-section-item:nth-child(2){animation-delay:.6s}.home-content-top .card-section-item:nth-child(3){animation-delay:.8s}@media(max-width:968px){.home-content-top .card-section-item{width:60%}}@media(max-width:768px){.home-content-top .card-section-item{width:80%;padding:1.5rem}}@media(max-width:480px){.home-content-top .card-section-item{width:100%;padding:1rem}}.home-content-top .card-section-item:first-child{flex-direction:row;align-items:center;gap:.75rem;margin-bottom:0;padding-top:2rem}@media(max-width:768px){.home-content-top .card-section-item:first-child{padding-top:1.5rem}}@media(max-width:480px){.home-content-top .card-section-item:first-child{padding-top:1rem}}.home-content-top .card-section-item:first-child h3{margin:0;font-size:1rem;font-weight:400;text-transform:uppercase;letter-spacing:.1em;opacity:.9;color:#ffffffde}.home-content-top .card-section-item h2{font-size:3.5rem;font-weight:700;margin:0;line-height:1.1;color:#ffffffde}@media(max-width:768px){.home-content-top .card-section-item h2{font-size:2.5rem}}@media(max-width:480px){.home-content-top .card-section-item h2{font-size:2rem}}.home-content-top .card-section-item p{font-size:1.2rem;line-height:1.6;opacity:.95;margin:0;color:#ffffffde}@media(max-width:768px){.home-content-top .card-section-item p{font-size:1.1rem}}.card-section-item{display:flex;flex-direction:column;gap:1rem}.card-section-item:first-child{flex-direction:row;align-items:center;gap:.75rem;margin-bottom:1rem}.card-section-item:first-child h3{margin:0;font-size:1rem;font-weight:400;text-transform:uppercase;letter-spacing:.1em;opacity:.7}.card-section-item h2{font-size:3.5rem;font-weight:700;margin:0;line-height:1.1}@media(max-width:768px){.card-section-item h2{font-size:2.5rem}}@media(max-width:480px){.card-section-item h2{font-size:2rem}}.card-section-item p{font-size:1.2rem;line-height:1.6;opacity:.9;margin:0;max-width:700px}@media(max-width:768px){.card-section-item p{font-size:1.1rem}}.card-section-item img{filter:invert(1)}.about-section-item-white-blur{position:relative;z-index:2;padding:2rem;background:#ffffff26;border:1px solid rgba(255,255,255,.3);border-radius:8px;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 8px 32px #0000004d;transition:all .3s ease}.about-section-item-white-blur:hover{transform:translateY(-5px);border-color:#fff6;background:#fff3;box-shadow:0 12px 40px #0006}.about-section-item-white-blur span{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.about-section-item-white-blur span img{filter:invert(1);width:20px;height:20px}.about-section-item-white-blur span h3{margin:0;font-size:1.5rem;font-weight:600;color:#ffffffde}.about-section-item-white-blur p{font-size:1.1rem;line-height:1.8;opacity:.95;margin:0;color:#ffffffde}.home-content-items{display:grid;grid-template-columns:1fr auto;gap:3rem;align-items:start;opacity:0;animation:fadeInUp .8s ease-out 1s both}@media(max-width:968px){.home-content-items{grid-template-columns:1fr;gap:2rem}}.home-content-items img{filter:invert(1);width:20px;height:20px;object-fit:contain}.about-section-item{opacity:0;animation:fadeInUp .6s ease-out 1.2s both}.about-section-item h2{font-size:2.5rem;font-weight:600;margin:0 0 1.5rem;line-height:1.2}@media(max-width:768px){.about-section-item h2{font-size:2rem}}.about-section-item p{font-size:1.1rem;line-height:1.8;margin-bottom:1.5rem;opacity:.9}.about-section-item p:last-of-type{margin-bottom:0}.cv-section-item{display:flex;flex-direction:column;gap:1.5rem;padding:2rem;background:#ffffff05;border:1px solid rgba(255,255,255,.1);border-radius:8px;min-width:250px;transition:all .3s ease;opacity:0;animation:fadeInUp .6s ease-out 1.4s both}.cv-section-item:hover{transform:translateY(-5px);border-color:#fff3;background:#ffffff0a}.cv-section-item span{display:flex;align-items:center;gap:.75rem}.cv-section-item span img{filter:invert(1);width:20px;height:20px}.cv-section-item span h2{margin:0;font-size:1.5rem;font-weight:600}.cv-section-item button{padding:.75rem 1.5rem;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:transparent;color:#ffffffde;font-family:inherit;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease}.cv-section-item button:hover{background:#ffffff0d;border-color:#fff3;transform:translateY(-2px)}.cv-section-item button:active{transform:translateY(0)}.cv-section-item button:focus{outline:2px solid #646cff;outline-offset:2px}.professional-section{opacity:0;animation:fadeInUp .8s ease-out 1.6s both}.professional-timeline{display:flex;flex-direction:column;gap:2.5rem;position:relative;padding-left:2rem}.professional-timeline:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,#10b981,#10b9814d)}@media(max-width:768px){.professional-timeline{padding-left:1.5rem;gap:2rem}}.professional-item{position:relative;display:flex;gap:2rem;padding-bottom:1rem}.professional-item:before{content:"";position:absolute;left:-2.5rem;top:.5rem;width:12px;height:12px;border-radius:50%;background:#10b981;border:2px solid #1a1a1a;box-shadow:0 0 0 3px #10b98133}@media(max-width:768px){.professional-item{flex-direction:column;gap:1rem}.professional-item:before{left:-1.75rem}}.professional-year{width:150px;min-width:150px;max-width:150px;font-weight:600;color:#10b981;font-size:1rem;padding-top:.25rem;text-align:right;word-break:break-word;overflow-wrap:break-word}@media(max-width:768px){.professional-year{width:auto;min-width:auto;max-width:none;text-align:left;font-size:.95rem}}.professional-content{flex:1}.professional-content h3{font-size:1.5rem;font-weight:600;margin:0 0 .5rem;color:#ffffffde}@media(max-width:768px){.professional-content h3{font-size:1.3rem}}.professional-company{font-size:1.1rem;color:#ffffffb3;margin:0 0 .75rem;font-weight:500}.professional-description{font-size:1rem;line-height:1.7;color:#ffffffb3;margin:0;opacity:.9}.academic-section{opacity:0;animation:fadeInUp .8s ease-out 1.6s both}.academic-section .section-title{font-size:2.5rem;font-weight:600;margin:0 0 3rem;line-height:1.2}@media(max-width:768px){.academic-section .section-title{font-size:2rem;margin-bottom:2rem}}.academic-timeline{display:flex;flex-direction:column;gap:2.5rem;position:relative;padding-left:2rem}.academic-timeline:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,#646cff,#646cff4d)}@media(max-width:768px){.academic-timeline{padding-left:1.5rem;gap:2rem}}.academic-item{position:relative;display:flex;gap:2rem;padding-bottom:1rem}.academic-item:before{content:"";position:absolute;left:-2.5rem;top:.5rem;width:12px;height:12px;border-radius:50%;background:#646cff;border:2px solid #1a1a1a;box-shadow:0 0 0 3px #646cff33}@media(max-width:768px){.academic-item{flex-direction:column;gap:1rem}.academic-item:before{left:-1.75rem}}.academic-year{width:150px;min-width:150px;max-width:150px;font-weight:600;color:#646cff;font-size:1rem;padding-top:.25rem;text-align:right;word-break:break-word;overflow-wrap:break-word}@media(max-width:768px){.academic-year{width:auto;min-width:auto;max-width:none;text-align:left;font-size:.95rem}}.academic-content{flex:1}.academic-content h3{font-size:1.5rem;font-weight:600;margin:0 0 .5rem;color:#ffffffde}@media(max-width:768px){.academic-content h3{font-size:1.3rem}}.academic-institution{font-size:1.1rem;color:#ffffffb3;margin:0 0 .75rem;font-weight:500}.academic-description{font-size:1rem;line-height:1.7;color:#ffffffb3;margin:0;opacity:.9}.contact-section{opacity:0;animation:fadeInUp .8s ease-out 1.8s both;max-width:800px;margin:0 auto}.section-title{font-size:2.5rem;font-weight:600;margin:0 0 1rem;line-height:1.2}@media(max-width:768px){.section-title{font-size:2rem}}.contact-subtitle{font-size:1.1rem;line-height:1.7;opacity:.9;margin:0 0 1.5rem;color:#ffffffb3}.contact-form-box{background:#ffffff05;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:2rem;margin-bottom:2rem;transition:all .3s ease}.contact-form-box:hover{border-color:#fff3;background:#ffffff08}@media(max-width:768px){.contact-form-box{padding:1.5rem}}@media(max-width:480px){.contact-form-box{padding:1.25rem}}.contact-form{margin:0}.form-group{margin-bottom:1.25rem}.form-group:last-of-type{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#ffffffde;font-size:.95rem}.form-input,.form-textarea{width:100%;padding:.75rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#ffffffde;font-family:inherit;font-size:1rem;transition:all .3s ease}.form-input::placeholder,.form-textarea::placeholder{color:#ffffff80;opacity:.6}.form-input:focus,.form-textarea:focus{outline:none;border-color:#646cff;background:#ffffff14;box-shadow:0 0 0 3px #646cff1a}.form-input:hover,.form-textarea:hover{border-color:#fff3}.form-textarea{min-height:150px;resize:vertical;font-family:inherit}.char-count{display:block;text-align:right;font-size:.85rem;opacity:.6;margin-top:.5rem;color:#ffffff80}.btn-submit{width:100%;padding:1rem 2rem;background:#646cff;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;font-family:inherit}.btn-submit:hover{background:#535bf2;transform:translateY(-2px);box-shadow:0 4px 12px #646cff4d}.btn-submit:active{transform:translateY(0)}.btn-submit:focus{outline:2px solid #646cff;outline-offset:2px}.contact-links{text-align:center;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1)}.contact-or{margin-bottom:1rem;opacity:.8;color:#ffffffb3;font-size:.95rem}.contact-section .social-links{display:flex;justify-content:center;gap:1.5rem;flex-wrap:wrap;flex-direction:row!important}.contact-section .social-link{color:#646cff;text-decoration:none;font-weight:500;transition:all .3s ease;padding:.5rem 0}.contact-section .social-link:hover{color:#535bf2;transform:translateY(-2px)}.associations-section{opacity:0;animation:fadeInUp .8s ease-out 1.65s both}.associations-timeline{display:flex;flex-direction:column;gap:2.5rem;position:relative;padding-left:2rem}.associations-timeline:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,#f59e0b,#f59e0b4d)}@media(max-width:768px){.associations-timeline{padding-left:1.5rem;gap:2rem}}.association-item{position:relative;display:flex;gap:2rem;padding-bottom:1rem}.association-item:before{content:"";position:absolute;left:-2.5rem;top:1.75rem;width:12px;height:12px;border-radius:50%;background:#f59e0b;border:2px solid #1a1a1a;box-shadow:0 0 0 3px #f59e0b33}@media(max-width:768px){.association-item{flex-direction:column;gap:1rem}.association-item:before{left:-1.75rem;top:1.25rem}}.association-year{width:150px;min-width:150px;max-width:150px;font-weight:600;color:#f59e0b;font-size:1rem;padding-top:.25rem;text-align:right;word-break:break-word;overflow-wrap:break-word}@media(max-width:768px){.association-year{width:auto;min-width:auto;max-width:none;text-align:left;font-size:.95rem}}.association-content{flex:1}.association-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:.75rem}@media(max-width:768px){.association-header{flex-direction:column;align-items:flex-start;gap:1rem}}.association-logo{width:80px;height:80px;object-fit:contain;flex-shrink:0}@media(max-width:768px){.association-logo{width:60px;height:60px}}.association-text{flex:1}.association-text h3{font-size:1.5rem;font-weight:600;margin:0 0 .5rem;color:#ffffffde}@media(max-width:768px){.association-text h3{font-size:1.3rem}}.association-role{font-size:1.1rem;color:#ffffffb3;margin:0 0 .75rem;font-weight:500}.association-description{font-size:1rem;line-height:1.7;color:#ffffffb3;margin:0;opacity:.9}@media(max-width:480px){.card-section-item h2{font-size:1.75rem}.card-section-item p{font-size:1rem}.about-section-item-white-blur{padding:1.5rem}.cv-section-item{min-width:auto;width:100%}.academic-timeline{padding-left:1rem}.academic-timeline:before{left:-.5rem}.academic-item:before{left:-1.25rem}.contact-form-box{margin-bottom:1.5rem}.contact-form{margin-bottom:0}.social-links{gap:1rem}.technologies-grid{margin-bottom:1.5rem}}.technologies-section{opacity:0;animation:fadeInUp .8s ease-out 1.7s both;max-width:1000px;margin:0 auto}.technologies-subtitle{font-size:1.1rem;line-height:1.7;opacity:.9;margin:0 0 2rem;color:#ffffffb3;text-align:center}@media(max-width:768px){.technologies-subtitle{font-size:1rem;margin-bottom:1.5rem}}.technologies-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1.5rem;margin-bottom:2rem}@media(max-width:768px){.technologies-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:1.25rem}}@media(max-width:480px){.technologies-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:1rem}}.tech-item{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.25rem 1rem;background:#ffffff05;border:1px solid rgba(255,255,255,.1);border-radius:8px;text-decoration:none;color:#ffffffde;transition:all .3s ease;cursor:pointer}.tech-item:hover{transform:translateY(-5px);border-color:#646cff;background:#646cff1a;box-shadow:0 4px 12px #646cff33}.tech-item:active{transform:translateY(-3px)}@media(max-width:480px){.tech-item{padding:1rem .75rem;gap:.5rem}}.tech-icon-wrapper{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#ffffff08;border-radius:8px;padding:.5rem;transition:all .3s ease}.tech-item:hover .tech-icon-wrapper{background:#ffffff14;transform:scale(1.1)}@media(max-width:480px){.tech-icon-wrapper{width:40px;height:40px}}.tech-icon{width:100%;height:100%;object-fit:contain;opacity:.9;transition:all .3s ease}.tech-item:hover .tech-icon{opacity:1;filter:drop-shadow(0 0 8px rgba(100,108,255,.5))}.tech-name{font-size:.9rem;font-weight:500;text-align:center;transition:all .3s ease}.tech-item:hover .tech-name{color:#646cff}@media(max-width:480px){.tech-name{font-size:.85rem}}.tech-more{text-align:center;font-size:1.1rem;opacity:.7;margin-top:1rem;color:#ffffffb3;font-style:italic}@media(max-width:480px){.technologies-grid{margin-bottom:1.5rem}}.container-work{width:100%;max-width:1200px;margin:0 auto;padding:2rem;color:#ffffffde;animation:fadeIn .5s ease-out}@media(max-width:768px){.container-work{padding:1rem}}.container-work-content{display:flex;flex-direction:column;gap:6rem}.work-header{text-align:left;opacity:0;animation:fadeInUp .6s ease-out .2s both;margin-bottom:3rem;padding:0}.work-title{font-size:2.5rem;font-weight:600;margin:0 0 1.5rem;line-height:1.2;color:#ffffffde}@media(max-width:768px){.work-title{font-size:2rem}}@media(max-width:480px){.work-title{font-size:1.75rem}}.work-subtitle{font-size:1.1rem;line-height:1.7;opacity:.9;color:#ffffffb3;max-width:800px;margin:0}@media(max-width:768px){.work-subtitle{font-size:1rem}}.github-link{color:#646cff;text-decoration:none;font-weight:500;transition:all .3s ease}.github-link:hover{color:#535bf2;text-decoration:underline}.projects-grid{display:grid;grid-template-columns:1fr;gap:3rem;opacity:0;animation:fadeInUp .8s ease-out .4s both}@media(min-width:968px){.projects-grid{grid-template-columns:repeat(2,1fr);gap:2.5rem}}@media(max-width:768px){.projects-grid{gap:2rem}}.project-card{background:#ffffff05;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:2rem;display:flex;flex-direction:column;gap:1.5rem;transition:all .3s ease}.project-card:hover{transform:translateY(-5px);border-color:#fff3;background:#ffffff0a;box-shadow:0 8px 24px #0000004d}@media(max-width:768px){.project-card{padding:1.5rem;gap:1.25rem}}@media(max-width:480px){.project-card{padding:1.25rem;gap:1rem}}.project-header{display:flex;flex-direction:column;gap:.5rem}.project-title{font-size:1.75rem;font-weight:600;margin:0;line-height:1.3;color:#ffffffde}@media(max-width:768px){.project-title{font-size:1.5rem}}@media(max-width:480px){.project-title{font-size:1.3rem}}.project-period{font-size:.95rem;color:#646cff;font-weight:500;opacity:.9}.project-description{font-size:1rem;line-height:1.7;color:#ffffffb3;margin:0;opacity:.9}@media(max-width:480px){.project-description{font-size:.95rem}}.project-carousel{display:flex;flex-direction:column;gap:1rem;width:100%}.carousel-thumbnails{display:flex;gap:.75rem;overflow-x:auto;padding:.5rem 0;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}.carousel-thumbnails::-webkit-scrollbar{height:6px}.carousel-thumbnails::-webkit-scrollbar-track{background:transparent}.carousel-thumbnails::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.carousel-thumbnails::-webkit-scrollbar-thumb:hover{background:#fff3}.thumbnail-button{flex-shrink:0;width:80px;height:60px;padding:0;border:2px solid rgba(255,255,255,.1);border-radius:6px;background:transparent;cursor:pointer;transition:all .3s ease;overflow:hidden;position:relative}.thumbnail-button:hover{border-color:#646cff;transform:scale(1.05)}.thumbnail-button.active{border-color:#646cff;box-shadow:0 0 0 2px #646cff4d}@media(max-width:480px){.thumbnail-button{width:70px;height:52px}}.thumbnail-image{width:100%;height:100%;object-fit:cover;display:block;max-width:100%;max-height:100%}.carousel-main{width:100%;max-width:100%;aspect-ratio:16/9;border-radius:8px;overflow:hidden;background:#ffffff05;border:1px solid rgba(255,255,255,.1);position:relative}.main-image{width:100%;height:100%;max-width:100%;max-height:100%;object-fit:cover;object-position:center;display:block;transition:opacity .3s ease}.project-tech-icons{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;padding:.75rem 0}.tech-icon-small{width:24px;height:24px;object-fit:contain;opacity:.8;transition:all .3s ease;filter:brightness(.9)}.tech-icon-small:hover{opacity:1;transform:scale(1.15);filter:brightness(1) drop-shadow(0 0 4px rgba(100,108,255,.4))}@media(max-width:480px){.tech-icon-small{width:20px;height:20px}}.project-links{display:flex;gap:1rem;flex-wrap:wrap;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.1)}.github-button,.blog-button{padding:.75rem 1.5rem;border-radius:8px;font-size:.95rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .3s ease;text-decoration:none;display:inline-block;text-align:center}@media(max-width:480px){.github-button,.blog-button{padding:.65rem 1.25rem;font-size:.9rem}}.github-button{background:#646cff;color:#fff;border:none}.github-button:hover{background:#535bf2;transform:translateY(-2px);box-shadow:0 4px 12px #646cff4d}.github-button:active{transform:translateY(0)}.blog-button{background:transparent;color:#ffffffde;border:1px solid rgba(255,255,255,.1)}.blog-button:hover{background:#ffffff0d;border-color:#fff3;transform:translateY(-2px)}.blog-button:active{transform:translateY(0)}.blog-button:focus{outline:2px solid #646cff;outline-offset:2px}@media(max-width:968px){.projects-grid{grid-template-columns:1fr}}@media(max-width:480px){.work-header{margin-bottom:1.5rem}.project-card:hover{transform:none}.carousel-thumbnails{gap:.5rem}.project-links{flex-direction:column}.project-links .github-button,.project-links .blog-button{width:100%}}.container-blog{width:100%;max-width:1200px;margin:0 auto;padding:2rem;color:#ffffffde;animation:fadeIn .5s ease-out}@media(max-width:768px){.container-blog{padding:1rem}}.container-blog-content{display:flex;flex-direction:column;gap:6rem}.blog-header{text-align:left;opacity:0;animation:fadeInUp .6s ease-out .2s both;margin-bottom:3rem;padding:0}.blog-title{font-size:2.5rem;font-weight:600;margin:0 0 1.5rem;line-height:1.2;color:#ffffffde}@media(max-width:768px){.blog-title{font-size:2rem}}@media(max-width:480px){.blog-title{font-size:1.75rem}}.blog-subtitle{font-size:1.1rem;line-height:1.7;opacity:.9;color:#ffffffb3;max-width:800px;margin:0}@media(max-width:768px){.blog-subtitle{font-size:1rem}}.blog-articles-section{opacity:0;animation:fadeInUp .8s ease-out .4s both}.blog-timeline{display:flex;flex-direction:column;gap:2.5rem;position:relative;padding-left:2rem}.blog-timeline:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,#646cff,#646cff4d)}@media(max-width:768px){.blog-timeline{padding-left:1.5rem;gap:2rem}}.blog-item{position:relative;display:flex;gap:2rem;padding-bottom:1rem;cursor:pointer;transition:all .3s ease}.blog-item:before{content:"";position:absolute;left:-2.5rem;top:.5rem;width:12px;height:12px;border-radius:50%;background:#646cff;border:2px solid #1a1a1a;box-shadow:0 0 0 3px #646cff33;transition:all .3s ease}.blog-item:hover .blog-content-card{transform:translate(5px);border-color:#fff3;background:#ffffff0a}.blog-item:hover:before{transform:scale(1.2);box-shadow:0 0 0 4px #646cff4d}@media(max-width:768px){.blog-item{flex-direction:column;gap:1rem}.blog-item:before{left:-1.75rem}.blog-item:hover .blog-content-card{transform:translate(0)}}.blog-date{width:150px;min-width:150px;max-width:150px;font-weight:600;color:#646cff;font-size:1rem;padding-top:.25rem;text-align:right;word-break:break-word;overflow-wrap:break-word}@media(max-width:768px){.blog-date{width:auto;min-width:auto;max-width:none;text-align:left;font-size:.95rem}}.blog-content-card{flex:1;padding:2rem;background:#ffffff05;border:1px solid rgba(255,255,255,.1);border-radius:8px;transition:all .3s ease}@media(max-width:768px){.blog-content-card{padding:1.5rem}}@media(max-width:480px){.blog-content-card{padding:1.25rem}}.blog-article-title{font-size:1.5rem;font-weight:600;margin:0 0 .75rem;color:#ffffffde;transition:all .3s ease}.blog-item:hover .blog-article-title{color:#646cff}@media(max-width:768px){.blog-article-title{font-size:1.3rem}}.blog-article-description{font-size:1rem;line-height:1.7;color:#ffffffb3;margin:0;opacity:.9}@media(max-width:480px){.blog-header{margin-bottom:2rem}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.article-container{width:100%;max-width:1200px;margin:0 auto;padding:2rem;color:#ffffffde;animation:fadeIn .5s ease-out;display:grid;grid-template-columns:1fr 250px;gap:3rem;position:relative}@media(max-width:968px){.article-container{grid-template-columns:1fr;gap:2rem}}@media(max-width:768px){.article-container{padding:1rem}}.article-table-of-contents{position:sticky;top:2rem;align-self:start;background:#ffffff05;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:2rem;max-height:calc(100vh - 4rem);overflow-y:auto;opacity:0;animation:fadeInUp .6s ease-out .3s both}@media(max-width:968px){.article-table-of-contents{position:relative;top:0;max-height:none;order:-1}}@media(max-width:768px){.article-table-of-contents{padding:1.5rem}}.article-table-of-contents h3{font-size:1.25rem;font-weight:600;margin:0 0 1rem;color:#ffffffde;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.1)}.article-table-of-contents ul{list-style:none;padding:0;margin:0}.article-table-of-contents li{margin-bottom:.75rem}.article-table-of-contents li:last-child{margin-bottom:0}.article-table-of-contents a{color:#ffffffb3;text-decoration:none;font-size:.95rem;transition:all .3s ease;display:block;padding:.25rem 0}.article-table-of-contents a:hover{color:#646cff;transform:translate(5px)}.article-table-of-contents::-webkit-scrollbar{width:6px}.article-table-of-contents::-webkit-scrollbar-track{background:transparent}.article-table-of-contents::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.article-table-of-contents::-webkit-scrollbar-thumb:hover{background:#fff3}.article-content{opacity:0;animation:fadeInUp .6s ease-out .2s both}.article-header{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;margin-bottom:3rem;padding-bottom:2rem;border-bottom:1px solid rgba(255,255,255,.1)}@media(max-width:768px){.article-header{flex-direction:column;gap:1.5rem}}.article-header-left{flex:1}.article-header-right{flex-shrink:0;text-align:right}@media(max-width:768px){.article-header-right{text-align:left}}.article-title{font-size:2.5rem;font-weight:600;margin:0 0 1rem;line-height:1.2;color:#ffffffde}@media(max-width:768px){.article-title{font-size:2rem}}@media(max-width:480px){.article-title{font-size:1.75rem}}.article-meta{display:flex;align-items:center;gap:.75rem;font-size:1rem;color:#ffffffb3;flex-wrap:wrap}.article-author{font-weight:500}.article-separator{opacity:.5}.article-date{opacity:.8}.article-word-count{font-size:.9rem;color:#ffffff80;background:#ffffff05;padding:.5rem 1rem;border-radius:8px;border:1px solid rgba(255,255,255,.1);display:inline-block}.article-body{line-height:1.8;font-size:1.1rem;color:#ffffffb3}@media(max-width:768px){.article-body{font-size:1rem}}.article-body section{margin-bottom:3rem}.article-body section:last-child{margin-bottom:0}@media(max-width:768px){.article-body section{margin-bottom:2rem}}.article-body h2{font-size:2rem;font-weight:600;margin:0 0 1.5rem;color:#ffffffde;padding-top:1rem;scroll-margin-top:2rem}@media(max-width:768px){.article-body h2{font-size:1.75rem;margin-bottom:1rem}}@media(max-width:480px){.article-body h2{font-size:1.5rem}}.article-body p{margin:0 0 1.5rem;text-align:justify}.article-body p:last-child{margin-bottom:0}@media(max-width:768px){.article-body p{text-align:left}}.article-body a{color:#646cff;text-decoration:none;transition:all .3s ease}.article-body a:hover{color:#535bf2;text-decoration:underline}.article-body ul,.article-body ol{margin:1.5rem 0;padding-left:2rem;color:#ffffffb3}.article-body ul li,.article-body ol li{margin-bottom:.75rem}.article-body code{background:#ffffff05;padding:.2rem .5rem;border-radius:4px;font-family:Courier New,monospace;font-size:.9em;color:#646cff;border:1px solid rgba(255,255,255,.1)}.article-body pre{background:#ffffff05;padding:1.5rem;border-radius:8px;border:1px solid rgba(255,255,255,.1);overflow-x:auto;margin:1.5rem 0}.article-body pre code{background:transparent;padding:0;border:none;color:#ffffffde}.article-body blockquote{border-left:3px solid #646cff;padding-left:1.5rem;margin:1.5rem 0;color:#ffffffb3;font-style:italic}.article-body img{max-width:100%;height:auto;border-radius:8px;margin:1.5rem 0}@media(max-width:968px){.article-container{grid-template-columns:1fr}.article-table-of-contents{order:-1}}@media(max-width:480px){.article-header{margin-bottom:2rem;padding-bottom:1.5rem}.article-body section{margin-bottom:2rem}}.site-footer{background:#1a1a1af2;border-top:1px solid rgba(255,255,255,.1);padding:3rem 2rem 1.5rem;margin-top:4rem;color:#ffffffde;animation:fadeInUp .6s ease-out}@media(max-width:768px){.site-footer{padding:2rem 1.5rem 1rem;margin-top:3rem}}.footer-content{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:3rem;margin-bottom:2rem}@media(max-width:968px){.footer-content{grid-template-columns:repeat(2,1fr);gap:2rem}}@media(max-width:640px){.footer-content{grid-template-columns:1fr;gap:2rem}}.footer-section h3{font-size:1.1rem;font-weight:600;margin:0 0 1rem;color:#ffffffde;text-transform:uppercase;letter-spacing:.05em}.footer-section p{margin:0;color:#fff9;font-size:.95rem;line-height:1.6}.footer-section p a{color:#ffffffde;text-decoration:none;transition:all .3s ease}.footer-section p a:hover{color:#646cff}.site-footer .social-links{display:flex;flex-direction:column;gap:.75rem}.site-footer .social-links a{color:#ffffffde;text-decoration:none;font-size:.95rem;transition:all .3s ease;display:inline-block}.site-footer .social-links a:hover{color:#646cff;transform:translate(5px)}.site-footer .footer-nav{display:flex;flex-direction:column;gap:.75rem;align-items:flex-start}.site-footer .footer-nav a{color:#ffffffde;text-decoration:none;font-size:.95rem;display:inline-block}.site-footer .footer-nav a:hover{color:#ffffffde}.site-footer .footer-nav a.router-link-active{color:#ffffffde;font-weight:500}.footer-bottom{max-width:1200px;margin:0 auto;padding-top:2rem;border-top:1px solid rgba(255,255,255,.1);text-align:center}.footer-bottom p{margin:0;color:#fff9;font-size:.85rem}@media(max-width:768px){.footer-bottom{padding-top:1.5rem}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffde;background-color:#1a1a1a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;min-height:100vh;background-color:#1a1a1a;margin:0;padding:0}body{display:flex;place-items:center;min-width:320px}#app{width:100%;min-height:100vh;background-color:#1a1a1a}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#ffffff0d;color:#ffffffde;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff;background-color:#ffffff14}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}
