html,body{margin:0;padding:0;font-family:Montserrat,Arial,sans-serif;background:#f7f7f7;color:#1f2937}*,*:before,*:after{box-sizing:border-box}ul{list-style:none;padding:0;margin:0}.lm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1f2937bf;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .4s ease;z-index:100}.lm-overlay.lm-show{opacity:1}.lm-card{background:#fff;border-radius:12px;padding:2rem;max-width:360px;width:90%;text-align:center;transform:translateY(-20px) scale(.95);opacity:0;transition:transform .4s ease,opacity .4s ease;box-shadow:0 8px 24px #1f293726}.lm-card.lm-show{transform:translateY(0) scale(1);opacity:1}.lm-title{margin-bottom:1.5rem;font-size:1.25rem;color:#7c3aed;font-family:Poppins,sans-serif}.lm-subtext{margin-bottom:1.5rem;font-size:.95rem;color:#4b5563;font-family:Poppins,sans-serif}.lm-buttons{display:flex;flex-direction:column;gap:.75rem}.lm-btn{padding:.75rem 1.25rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:background .25s,color .25s,transform .15s;border:none}.lm-btn-lang{background:#f7f7f7;color:#1f2937;border:1px solid #D1D5DB}.lm-btn-lang:hover{background:#e5e7eb}.lm-btn-primary{background:#7c3aed;color:#fff}.lm-btn-primary:hover{background:#6827c9}.lm-btn-secondary{background:#fbbf24;color:#1f2937}.lm-btn-secondary:hover{background:#e0a71f}.lm-btn:active{transform:scale(.97)}.header{position:fixed;top:0;width:100%;background:#f1f3f5;border-bottom:1px solid #DDD;z-index:1000}.header__inner{max-width:1200px;margin:0 auto;height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 24px}.header__logo{height:40px}.header__nav{display:flex;gap:24px}.header__link{font-family:Montserrat,Arial,sans-serif;font-weight:500;font-size:1rem;color:#7c3aed;text-decoration:none}.header__link:hover{color:#fbbf24}.header__toggles{display:flex;gap:16px;align-items:center}.header__lang-toggle{background:none;border:none;color:#fbbf24;font-weight:600}.header__lang-toggle:hover{background:#fbbf241a}@media (max-width: 768px){.header__inner{flex-wrap:wrap;height:auto;padding:8px 16px}.header__logo{height:32px}.header__toggles{order:2;margin-top:8px}.header__nav{order:1;width:100%;justify-content:center;flex-wrap:wrap;gap:12px;margin-top:8px}.header__link{font-size:.9rem;padding:4px 8px}}.app{padding-top:64px;min-height:100vh;background:#f7f7f7;color:#1f2937;transition:background .3s,color .3s}.footer{margin-top:auto;background:#1f2937;color:#fff;text-align:center;padding:12px 0}html.dark .app{background:#1f2937;color:#f7f7f7}html.dark .footer{background:#111827;color:#d1d5db}.scroll-to-top{position:fixed;bottom:2rem;right:2rem;width:3rem;height:3rem;background:#fbbf24;color:#fff;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;pointer-events:none;transition:opacity .3s;z-index:1000}.scroll-to-top.visible{opacity:1;pointer-events:auto}.scroll-to-top:hover{background:#fbbf24}.hero{position:relative;overflow:hidden;background:#1f2937;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;cursor:none}.hero__blobs{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none}.blob{position:absolute;border-radius:50%;opacity:.3}.blob--purple{width:400px;height:400px;background:radial-gradient(circle,#7C3AED 0%,transparent 70%);top:-100px;left:-100px}.blob--gold{width:300px;height:300px;background:radial-gradient(circle,#FBBF24 0%,transparent 70%);bottom:-50px;right:-50px}.hero__content{position:relative;z-index:1;max-width:600px;text-align:center}.hero__title{font-family:Poppins,sans-serif;font-size:3rem;color:#f7f7f7;margin-bottom:1rem}.hero__subtitle{font-size:1.25rem;color:#d1ccc3;min-height:3em;white-space:pre-wrap}.hero__cursor{display:inline-block;width:1ch;background:#d1ccc3;margin-left:2px;animation:blink 1s steps(2) infinite}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.hero__cta{display:inline-block;background:#7c3aed;color:#f7f7f7;padding:.75rem 1.5rem;border-radius:8px;font-weight:500;text-decoration:none;transition:background .2s}.hero__cta:hover{background:#6827c9}.hero__content:hover .hero__title,.hero__content:hover .hero__subtitle{color:#7c3aed}.about{position:relative;overflow:hidden;background:linear-gradient(135deg,#7c3eed0d,#fbbf240d);padding:4rem 2rem;color:#1f2937}.about__blobs{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.about__blobs .blob{position:absolute;border-radius:50%;opacity:.3}.about__blobs .blob--purple{width:300px;height:300px;background:radial-gradient(circle,#7C3AED 0%,transparent 70%);top:-80px;left:-80px}.about__blobs .blob--gold{width:200px;height:200px;background:radial-gradient(circle,#FBBF24 0%,transparent 70%);bottom:-50px;right:-50px}.about__box{position:relative;z-index:1;max-width:700px;margin:0 auto;background:#f7f7f7;box-shadow:0 4px 12px #0000000d;border-radius:8px;padding:2.5rem 2rem;text-align:center}.about__title{font-family:Poppins,sans-serif;font-size:2.25rem;color:#7c3aed;margin-bottom:1rem}.about__text,.about__note{font-size:1rem;line-height:1.6;margin-bottom:1rem}.about__note{font-style:italic}.about__resume{display:inline-block;margin:1.5rem 0;padding:.75rem 1.5rem;background:#fbbf24;color:#1f2937;border-radius:8px;font-weight:500;text-decoration:none;transition:background .2s}.about__resume:hover{background:#6827c9}.about__social{margin-top:2rem;display:flex;justify-content:center;gap:2rem;flex-wrap:wrap}.about__social a{color:#1f2937;font-size:1.25rem;display:inline-flex;align-items:center;gap:.5rem;transition:color .2s}.about__social a:hover{color:#7c3aed}.about-basic{position:relative;overflow:hidden;background:linear-gradient(135deg,#7c3eed0d,#fbbf240d);padding:4rem 2rem;color:#1f2937}.about-basic__blobs{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.about-basic__blobs .blob{position:absolute;border-radius:50%;opacity:.3}.about-basic__blobs .blob--purple{width:300px;height:300px;background:radial-gradient(circle,#7C3AED 0%,transparent 70%);top:-80px;left:-80px}.about-basic__blobs .blob--gold{width:200px;height:200px;background:radial-gradient(circle,#FBBF24 0%,transparent 70%);bottom:-50px;right:-50px}.about-basic__box{position:relative;z-index:1;max-width:700px;margin:0 auto;background:#f7f7f7;box-shadow:0 4px 12px #0000000d;border-radius:8px;padding:2.5rem 2rem;text-align:center}.about-basic__title{font-family:Poppins,sans-serif;font-size:2.25rem;color:#7c3aed;margin-bottom:1rem}.about-basic__text,.about-basic__note{font-size:1rem;line-height:1.6;margin-bottom:1rem}.about-basic__note{font-style:italic}.about-basic__resume{display:inline-block;margin:1.5rem 0;padding:.75rem 1.5rem;background:#fbbf24;color:#1f2937;border-radius:8px;font-weight:500;text-decoration:none;transition:background .2s}.about-basic__resume:hover{background:#6827c9}.about-basic__social{margin-top:2rem;display:flex;justify-content:center;gap:2rem}.about-basic__social a{color:#1f2937;font-size:1.25rem;display:inline-flex;align-items:center;gap:.5rem;transition:color .2s}.about-basic__social a:hover{color:#7c3aed}.services{position:relative;overflow:hidden;padding:4rem 2rem;text-align:center;background:linear-gradient(135deg,#7c3eed0d,#fbbf240d)}.services__blobs{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.services__blobs .blob{position:absolute;border-radius:50%;opacity:.3}.services__blobs .blob--purple{width:300px;height:300px;background:radial-gradient(circle,#7C3AED 0%,transparent 70%);top:-80px;left:-80px}.services__blobs .blob--gold{width:200px;height:200px;background:radial-gradient(circle,#FBBF24 0%,transparent 70%);bottom:-50px;right:-50px}.services__content{position:relative;z-index:1;max-width:1200px;margin:0 auto}.services__title{font-family:Poppins,sans-serif;font-size:2rem;color:#7c3aed;margin-bottom:.5rem}.services__click{color:#555;margin-bottom:2rem}.services__grid{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.card{perspective:1000px;cursor:pointer}.card__face{width:100%;height:180px;backface-visibility:hidden;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:1rem;box-shadow:0 4px 8px #0000001a;transition:transform .6s;transform-style:preserve-3d}.card__face--front{background:#fff;color:#1f2937;font-weight:600;font-size:1.125rem}.card__face--back{background:#fbbf24;color:#1f2937;transform:rotateY(180deg);font-size:.95rem;line-height:1.4;padding:1.5rem}.card.flipped .card__face--front{transform:rotateY(180deg)}.card.flipped .card__face--back{transform:rotateY(360deg)}.card__face--front{transition:background-color .3s,color .3s}.card:hover .card__face--front{background-color:#7c3aed;color:#fff}.projects{position:relative;overflow:hidden;padding:4rem 2rem;text-align:center;background:linear-gradient(135deg,#7c3eed0d,#fbbf240d)}.projects__blobs{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.projects__blobs .blob{position:absolute;border-radius:50%;opacity:.3}.projects__blobs .blob--purple{width:300px;height:300px;background:radial-gradient(circle,#7c3aed 0%,transparent 70%);top:-80px;left:-80px}.projects__blobs .blob--gold{width:200px;height:200px;background:radial-gradient(circle,#fbbf24 0%,transparent 70%);bottom:-50px;right:-50px}.projects__content{position:relative;z-index:1;max-width:1200px;margin:0 auto}.projects__title{font-family:Poppins,sans-serif;font-size:2rem;color:#7c3aed;margin-bottom:.5rem}.projects__click{color:#555;margin-bottom:2rem}.projects__carousel{display:flex;align-items:center;justify-content:center;gap:1rem}.projects__arrow{background:none;border:none;font-size:2rem;color:#7c3aed;cursor:pointer;transition:color .2s}.projects__arrow.disabled{color:#ccc;cursor:default}.projects__arrow:hover:not(.disabled){color:#5a24b8}.projects__grid{display:grid;gap:1.5rem;grid-template-columns:repeat(4,1fr);width:100%}.projects__card{position:relative;background:#fff;border-radius:8px;box-shadow:0 4px 8px #0000001a;cursor:pointer;overflow:hidden;transition:transform .2s;display:flex;flex-direction:column;align-items:center;padding:1rem;min-height:260px}.projects__card:hover{transform:translateY(-4px)}.projects__thumb-container{position:relative;width:100%}.projects__thumb{width:100%;height:180px;object-fit:cover;border-radius:4px;margin-bottom:.75rem}.projects__tech-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0009;opacity:0;display:flex;flex-wrap:wrap;gap:.25rem;align-items:center;justify-content:center;padding:1rem;transition:opacity .3s}.projects__card:hover .projects__tech-overlay{opacity:1}.projects__tech-badge{background:#7c3aed;color:#fff;font-size:.75rem;padding:.25rem .5rem;border-radius:4px}.projects__card-title{font-size:1rem;color:#1f2937;text-align:center;margin-top:.5rem}.projects__overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:999}.projects__modal{position:fixed;top:0;right:0;bottom:0;left:0;margin:auto;width:90vw;max-width:800px;height:90vh;background:#fff;border-radius:8px;padding:1.5rem;overflow-y:auto;z-index:1000;box-shadow:0 8px 24px #0003}.projects__close-btn{position:absolute;top:1rem;right:1rem;background:transparent;border:none;font-size:1.5rem;cursor:pointer;z-index:1001}.projects__fullimg{max-width:100%;max-height:60vh;margin:1rem 0;border-radius:4px}.lb-prev,.lb-next{position:absolute;top:50%;transform:translateY(-50%);background:none;border:none;font-size:2rem;color:#7c3aed;cursor:pointer}.lb-prev{left:1rem}.lb-next{right:1rem}.projects__item-title{margin-top:1rem;font-size:1.5rem;color:#1f2937}.projects__item-desc{margin:.5rem 0 1rem;color:#555;line-height:1.6}.projects__github-btn{display:inline-block;padding:.5rem 1rem;background:#1f2937;color:#fff;border-radius:4px;text-decoration:none;transition:background .2s}.projects__github-btn:hover{background:#444}@media (max-width: 1024px){.projects__grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.projects__grid{grid-template-columns:1fr}.projects__carousel{flex-direction:column;gap:.5rem}.projects__arrow{font-size:1.5rem}}.skills{position:relative;overflow:hidden;padding:4rem 2rem;text-align:center;background:linear-gradient(135deg,#7c3eed0d,#fbbf240d)}.skills__blobs{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.skills__blobs .blob{position:absolute;border-radius:50%;opacity:.3}.skills__blobs .blob--purple{width:300px;height:300px;background:radial-gradient(circle,#7C3AED 0%,transparent 70%);top:-80px;left:-80px}.skills__blobs .blob--gold{width:200px;height:200px;background:radial-gradient(circle,#FBBF24 0%,transparent 70%);bottom:-50px;right:-50px}.skills__content{position:relative;z-index:1;max-width:1000px;margin:0 auto}.skills__title{font-family:Poppins,sans-serif;font-size:2rem;color:#7c3aed;margin-bottom:1.5rem;text-align:center}.skills__category{margin-bottom:2.5rem}.skills__category-title{font-size:1.25rem;font-weight:600;margin-bottom:1rem;color:#1f2937}.skills__grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));justify-items:center}.skills__card{background:#fff;border-radius:8px;box-shadow:0 4px 12px #0000000d;padding:1rem;width:120px;text-align:center;transition:transform .2s}.skills__card:hover{transform:translateY(-4px)}.skills__logo{width:48px;height:48px;object-fit:contain;margin-bottom:.5rem}.skills__label{font-size:.9rem;color:#1f2937}.skills,.skills__content,.skills__title{text-align:center!important;z-index:0}.contact{position:relative;overflow:hidden;padding:4rem 2rem;text-align:center;background:linear-gradient(135deg,#7c3eed0d,#fbbf240d)}.contact__blobs{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.contact__blobs .blob{position:absolute;border-radius:50%;opacity:.3}.contact__blobs .blob--purple{width:300px;height:300px;background:radial-gradient(circle,#7c3aed 0%,transparent 70%);top:-80px;left:-80px}.contact__blobs .blob--gold{width:200px;height:200px;background:radial-gradient(circle,#fbbf24 0%,transparent 70%);bottom:-50px;right:-50px}.contact__content{position:relative;z-index:1;max-width:900px;margin:0 auto}.contact__title{font-family:Poppins,sans-serif;font-size:2rem;color:#7c3aed;margin-bottom:.5rem}.contact__subtitle{color:#555;margin-bottom:2rem;line-height:1.5}.contact__grid{display:grid;grid-template-columns:200px 1fr 80px;gap:2rem;align-items:start}.contact__animation{display:flex;align-items:center;justify-content:center}.contact__form{display:flex;flex-direction:column;gap:1rem}.contact__form label{font-weight:600;text-align:left}.contact__form input,.contact__form textarea{padding:.75rem;border:1px solid #ccc;border-radius:4px;font-family:inherit;font-size:1rem;resize:vertical}.contact__form textarea{min-height:150px}.contact__button{background:#7c3aed;color:#fff;border:none;padding:.75rem;border-radius:4px;font:inherit;cursor:pointer;transition:background .2s}.contact__button:hover{background:#5a24b8}.contact__info{display:flex;flex-direction:column;gap:1rem;align-items:center;justify-content:start}.contact__info a{color:#1f2937;transition:color .2s}.contact__info a:hover{color:#7c3aed}.contact__info svg{width:32px;height:32px}@media (max-width: 768px){.contact__grid{grid-template-columns:1fr}.contact__animation{margin-bottom:1.5rem}.contact__info{flex-direction:row;justify-content:center;margin-top:1rem;gap:1rem}}@media (max-width: 480px){.contact__form input,.contact__form textarea{font-size:.9rem}.contact__button{padding:.6rem;font-size:.9rem}.contact__info svg{width:28px;height:28px}}
