*{box-sizing:border-box;margin:0;padding:0}:root{--bg-color:#0f172a;--surface-color:#111827;--brand-facebook:#1877f2;--brand-instagram-start:#f58529;--brand-instagram-mid:#dd2a7b;--brand-instagram-end:#8134af;--brand-whatsapp:#25d366;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;font-weight:400;line-height:1.6}[data-theme=dark],:root:not([data-theme]){--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-surface:#111827;--bg-surface-light:#1f2937;--primary-color:#38bdf8;--primary-dark:#0ea5e9;--secondary-color:#22d3ee;--text-primary:#e5e7eb;--text-secondary:#9ca3af;--text-light:#6b7280;--border-color:#ffffff14;--border-color-hover:#38bdf84d;--shadow-sm:0 1px 3px #00000080;--shadow-md:0 4px 20px #0009;--shadow-lg:0 8px 30px #000000b3;--shadow-accent:0 4px 20px #38bdf833;--bg-color:#0f172a;--surface-color:#111827}[data-theme=light]{--bg-primary:#f1f5f9;--bg-secondary:#e2e8f0;--bg-surface:#fff;--bg-surface-light:#f8fafc;--primary-color:#2563eb;--primary-dark:#1d4ed8;--secondary-color:#0ea5e9;--text-primary:#0f172a;--text-secondary:#475569;--text-light:#64748b;--border-color:#0f172a1a;--border-color-hover:#2563eb4d;--shadow-sm:0 2px 4px #0f172a0f;--shadow-md:0 8px 24px #0f172a14;--shadow-lg:0 12px 32px #0f172a1f;--shadow-accent:0 8px 24px #2563eb33;--bg-color:#f1f5f9;--surface-color:#fff}html{scroll-behavior:smooth;width:100%;scroll-padding-top:80px;overflow-x:hidden}body{background-color:var(--bg-primary);min-width:320px;min-height:100vh;color:var(--text-primary);background-image:radial-gradient(circle at 50% 0,#38bdf80d 0%,#0000 50%);width:100%;margin:0;overflow-x:hidden}[data-theme=light] body{background-image:radial-gradient(circle at 20% 20%,#2563eb08 0%,#0000 50%),radial-gradient(circle at 80% 80%,#0ea5e908 0%,#0000 50%)}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:700;line-height:1.2}p{color:var(--text-secondary);line-height:1.7}a{color:inherit;text-decoration:none;transition:all .3s}::selection{background-color:var(--primary-color);color:#fff}::selection{background-color:var(--primary-color);color:#fff}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--primary-color);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--primary-dark)}:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}img{max-width:100%;height:auto;display:block}button{cursor:pointer;background:0 0;border:none;font-family:inherit}ul,ol{list-style:none}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}[dir=rtl]{direction:rtl}[dir=rtl] body{text-align:right}[dir=rtl] svg,[dir=rtl] img,[dir=rtl] .icon,[dir=rtl] i{direction:ltr;transform:none!important}[dir=rtl] .navbar-container,[dir=rtl] .hero-content,[dir=rtl] .skills-grid,[dir=rtl] .projects-grid,[dir=rtl] .contact-content{direction:rtl}[dir=rtl] p,[dir=rtl] .hero-tagline,[dir=rtl] .about-text{text-align:right}[dir=rtl] .section-subtitle{text-align:center}[dir=rtl] button svg,[dir=rtl] .btn svg,[dir=rtl] a svg{transform:none}*{transition:background-color .3s,color .3s,border-color .3s}[data-theme=light] .skill-item,[data-theme=light] .project-card,[data-theme=light] .highlight-item,[data-theme=light] .experience-card,[data-theme=light] .contact-link{background:var(--bg-surface-light);box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}[data-theme=light] .theme-toggle,[data-theme=light] .language-switcher{background:var(--bg-surface);box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}[data-theme=light] .skill-item:hover,[data-theme=light] .project-card:hover,[data-theme=light] .highlight-item:hover,[data-theme=light] .contact-link:hover{box-shadow:var(--shadow-md),0 0 0 3px #2563eb14;border-color:var(--border-color-hover);transform:translateY(-2px)}[data-theme=light] .about-highlights,[data-theme=light] .skills-grid,[data-theme=light] .projects-grid,[data-theme=light] .timeline{background:0 0}[data-theme=light] .skill-category{background:var(--bg-surface-light);box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}[data-theme=light] .about-container,[data-theme=light] .skills-container,[data-theme=light] .projects-container,[data-theme=light] .experience-container,[data-theme=light] .contact-container{background:var(--bg-surface);box-shadow:var(--shadow-md);border:1px solid var(--border-color);border-radius:13px;max-width:calc(75% - 2rem);margin:1rem auto;padding:1.5rem}[data-theme=light] .hero{box-shadow:none;background:0 0;border:none}[data-theme=light] .btn-primary{background:var(--primary-color);color:#fff;box-shadow:var(--shadow-sm);border:1px solid var(--primary-color)}[data-theme=light] .btn-primary:hover{background:var(--primary-dark);box-shadow:var(--shadow-accent);transform:translateY(-2px)}[data-theme=light] .btn-secondary{color:var(--primary-color);border:2px solid var(--primary-color);box-shadow:var(--shadow-sm);background:0 0}[data-theme=light] .btn-secondary:hover{background:var(--primary-color);color:#fff;box-shadow:var(--shadow-accent)}[data-theme=light] .theme-toggle:hover{box-shadow:0 0 20px #2563eb4d}[data-theme=light] .language-switcher:hover{box-shadow:0 0 20px #0ea5e94d}@media (max-width:768px){[data-theme=light] .about-container,[data-theme=light] .skills-container,[data-theme=light] .projects-container,[data-theme=light] .experience-container,[data-theme=light] .contact-container{max-width:100%;box-shadow:none;background:#fafbfc;border:none;border-bottom:1px solid #0f172a14;border-radius:0;margin:0;padding:3rem 1.5rem}[data-theme=light] .about-container,[data-theme=light] .projects-container,[data-theme=light] .contact-container{background:#fff}[data-theme=light] .skills-container,[data-theme=light] .experience-container{background:#f8fafc}[data-theme=light] .skill-item,[data-theme=light] .project-card,[data-theme=light] .highlight-item,[data-theme=light] .experience-card,[data-theme=light] .contact-link{background:#fff;border:1px solid #0f172a1a;box-shadow:0 3px 10px #0f172a1f,0 1px 4px #0f172a14}[data-theme=light] .about-container .highlight-item,[data-theme=light] .projects-container .project-card,[data-theme=light] .contact-container .contact-link{background:#f8fafc}[data-theme=light] .btn-primary{color:#fff;background:#1e40af;border:2px solid #1e40af;font-weight:600;box-shadow:0 4px 14px #1e40af4d}[data-theme=light] .btn-secondary{color:#1e40af;background:#fff;border:2.5px solid #1e40af;font-weight:600;box-shadow:0 3px 10px #0f172a1f}[data-theme=light] .theme-toggle,[data-theme=light] .language-switcher{color:#0f172a;background:#fff;border:1.5px solid #0f172a26;box-shadow:0 4px 14px #0f172a2e}[data-theme=light] .contact{min-height:auto;padding:4rem 1.5rem}[data-theme=light] .section-title{margin-bottom:2rem;font-size:2rem}[data-theme=light] .section-subtitle{margin:-1rem 0 2rem;font-size:1rem}[data-theme=light] .contact-content{gap:2rem;margin-top:.5rem}[data-theme=light] .contact-info-title,[data-theme=light] .contact-form-title{margin-bottom:1.5rem;font-size:1.5rem}[data-theme=light] .contact-links{gap:1rem}[data-theme=light] .contact-link{gap:1rem;padding:1.25rem}[data-theme=light] .contact-icon{font-size:1.75rem}[data-theme=light] .contact-label{font-size:.8rem}[data-theme=light] .contact-value{font-size:.95rem}[data-theme=light] .contact-form-wrapper{border-radius:16px;padding:2rem 1.5rem}[data-theme=light] .contact-form{gap:1.5rem}[data-theme=light] .form-group{gap:.5rem}[data-theme=light] .form-group label{font-size:.95rem}[data-theme=light] .form-group input,[data-theme=light] .form-group textarea{border:2px solid var(--border-color);border-radius:8px;padding:.75rem .875rem;font-size:.95rem}[data-theme=light] .form-group textarea{min-height:120px}[data-theme=light] .submit-btn{border-radius:8px;padding:.875rem 1.75rem;font-size:.95rem}[data-theme=light] .submit-btn svg{font-size:1.1rem}[data-theme=light] .social-media-section{margin-top:2rem;padding-top:1.5rem}[data-theme=light] .social-media-title{margin-bottom:1.25rem;font-size:1.15rem}[data-theme=light] .social-media-icons{gap:1.25rem}[data-theme=light] .social-icon{color:#0f172acc;border:2px solid var(--border-color);width:45px;height:45px;font-size:1.35rem}[data-theme=light] .about,[data-theme=light] .skills,[data-theme=light] .projects,[data-theme=light] .experience{min-height:auto;margin-bottom:2rem;padding:5rem 1.5rem}}@media (max-width:480px){[data-theme=light] .about-container,[data-theme=light] .skills-container,[data-theme=light] .projects-container,[data-theme=light] .experience-container,[data-theme=light] .contact-container{padding:2.5rem 1rem}[data-theme=light] .about,[data-theme=light] .skills,[data-theme=light] .projects,[data-theme=light] .experience,[data-theme=light] .contact{padding:4rem 1.5rem}}.language-switcher{background:var(--bg-primary);border:2px solid var(--secondary-color);color:var(--secondary-color);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;min-width:50px;height:36px;padding:0 .75rem;font-size:.85rem;font-weight:700;transition:all .3s;display:flex;position:relative;box-shadow:0 0 10px #22d3ee33}.lang-text{justify-content:center;align-items:center;display:flex;position:relative}.lang-text:after{content:"";background:var(--secondary-color);border-radius:1px;width:20px;height:2px;position:absolute;bottom:-4px;left:50%;transform:translate(-50%)}.language-switcher:hover{background:var(--secondary-color);color:var(--bg-primary);transform:translateY(-2px);box-shadow:0 4px 12px #22d3ee66}.language-switcher:active{transform:scale(.95)}.language-switcher:hover .lang-text{animation:.3s flipLang}@keyframes flipLang{0%,to{transform:rotateY(0)}50%{transform:rotateY(180deg)}}.navbar{background:var(--bg-surface);width:100%;box-shadow:var(--shadow-md);border-bottom:1px solid var(--border-color);z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:0;position:fixed;top:0;left:0}[data-theme=light] .navbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow-sm);border-bottom:1px solid var(--border-color);background:#fffffff2}.navbar-container{justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto;padding:1rem 2rem;display:flex}.navbar-logo{cursor:pointer;flex-direction:column;display:flex}.logo-name{color:var(--text-primary);font-size:1.5rem;font-weight:700;line-height:1.2}.logo-title{color:var(--text-secondary);letter-spacing:.05em;text-transform:uppercase;font-size:.75rem;font-weight:400}.navbar-menu{gap:2.5rem;margin:0;padding:0;list-style:none;display:flex}.navbar-menu li{margin:0}.navbar-menu a{color:var(--text-secondary);font-size:1rem;font-weight:500;text-decoration:none;transition:color .3s;position:relative}.navbar-menu a:hover{color:var(--primary-color)}.navbar-menu a:after{content:"";background:var(--primary-color);width:0;height:2px;transition:width .3s;position:absolute;bottom:-5px;left:0}.navbar-menu a:hover:after{width:100%}.navbar-actions{align-items:center;gap:1rem;display:flex}.navbar-toggle{color:var(--text-primary);cursor:pointer;font-size:1.8rem;display:none}@media (max-width:768px){.navbar-container{padding:1rem 1.5rem}.navbar-actions{gap:.75rem}.navbar-toggle{display:block}.navbar-menu{background:var(--bg-surface);border-left:1px solid var(--border-color);flex-direction:column;gap:0;width:100%;max-width:300px;height:calc(100vh - 70px);padding:2rem;transition:right .3s;position:fixed;top:70px;right:-100%;box-shadow:-5px 0 10px #000c}.navbar-menu.active{right:0}.navbar-menu li{border-bottom:1px solid var(--border-color);width:100%;padding:1rem 0}.navbar-menu a{font-size:1.1rem;display:block}.navbar-menu a:after{display:none}.logo-name{font-size:1.3rem}.logo-title{font-size:.65rem}}@media (max-width:1024px) and (min-width:769px){.navbar-menu{gap:1.5rem}.navbar-menu a{font-size:.95rem}}[dir=rtl] .navbar-menu{gap:2.5rem}[dir=rtl] .navbar-menu a:after{left:auto;right:0}@media (max-width:768px){[dir=rtl] .navbar-menu{border-right:1px solid var(--border-color);border-left:none;left:-100%;right:auto;box-shadow:5px 0 10px #000c}[dir=rtl] .navbar-menu.active{left:0;right:auto}}.hero{background:var(--bg-primary);background-image:radial-gradient(circle at 30% 20%,#38bdf81a 0%,#0000 50%),radial-gradient(circle at 70% 80%,#22d3ee14 0%,#0000 50%);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex;position:relative}[data-theme=light] .hero{min-height:85vh;padding:2rem 2rem 3rem}.hero-wrapper{grid-template-columns:1fr 400px;align-items:center;gap:4rem;width:100%;max-width:1200px;display:grid}.hero-content{text-align:left}.hero-greeting{color:var(--primary-color);letter-spacing:.05em;margin-bottom:.75rem;font-size:1.2rem;font-weight:500}.hero-name{color:var(--text-primary);margin:0 0 1rem;font-size:3.5rem;font-weight:700;line-height:1.2}.hero-title{color:var(--text-secondary);margin:0 0 1.5rem;font-size:2rem;font-weight:600;line-height:1.3}.hero-tagline{color:var(--text-secondary);max-width:600px;margin:0 0 2.5rem;font-size:1.1rem;line-height:1.8}.hero-image-container{justify-content:center;align-items:center;display:flex}.hero-image-wrapper{background:linear-gradient(135deg,var(--primary-color)0%,var(--secondary-color)100%);border-radius:50%;width:320px;height:320px;padding:8px;transition:all .3s;position:relative;box-shadow:0 0 40px #38bdf84d,0 10px 30px #00000080}.hero-image-wrapper:before{content:"";filter:blur(40px);z-index:-1;background:radial-gradient(circle,#38bdf833 0%,#22d3ee26 30%,#0000 70%);border-radius:50%;width:140%;height:140%;animation:4s ease-in-out infinite pulse-glow;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes pulse-glow{0%,to{opacity:.6;transform:translate(-50%,-50%)scale(1)}50%{opacity:1;transform:translate(-50%,-50%)scale(1.1)}}.hero-image-wrapper:hover{transform:scale(1.05);box-shadow:0 0 50px #38bdf880,0 15px 40px #0009}.hero-image{object-fit:cover;border:4px solid var(--bg-primary);border-radius:50%;width:100%;height:100%}.hero-buttons{flex-wrap:wrap;justify-content:flex-start;gap:1.5rem;display:flex}.btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.875rem 2rem;font-size:1rem;font-weight:600;text-decoration:none;transition:all .3s;display:inline-flex}.btn svg{font-size:1.1rem;transition:transform .3s}.btn-primary{background:var(--primary-color);color:var(--bg-primary);box-shadow:var(--shadow-accent)}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 6px 25px #38bdf859}.btn-secondary{color:var(--primary-color);border:2px solid var(--primary-color);box-shadow:none;background:0 0}.btn-secondary:hover{background:var(--primary-color);color:var(--bg-primary);transform:translateY(-2px)scale(1.05);box-shadow:0 6px 25px #38bdf840}.btn-secondary:hover svg{transform:scale(1.1)}@media (max-width:768px){.hero{min-height:calc(100vh - 70px);padding:1rem}.hero-wrapper{grid-template-columns:1fr;gap:2rem}.hero-content{text-align:center;order:2}.hero-image-container{order:1}.hero-image-wrapper{width:220px;height:220px;padding:6px}.hero-greeting{margin-bottom:.75rem;font-size:1rem}.hero-name{margin-bottom:.75rem;font-size:2.2rem}.hero-title{margin-bottom:1rem;font-size:1.4rem}.hero-tagline{max-width:100%;margin:0 auto 2rem;font-size:1rem}.hero-buttons{flex-direction:column;justify-content:center;align-items:center;gap:1rem}.btn{width:100%;max-width:300px;padding:.75rem 1.5rem}}@media (max-width:1024px) and (min-width:769px){.hero-wrapper{grid-template-columns:1fr;gap:3rem;max-width:700px}.hero-content{text-align:center;order:2}.hero-image-container{order:1}.hero-image-wrapper{width:280px;height:280px}.hero-name{font-size:3rem}.hero-title{font-size:1.8rem}.hero-tagline{margin-left:auto;margin-right:auto;font-size:1.05rem}.hero-buttons{justify-content:center}}@media (min-width:1440px){.hero-wrapper{grid-template-columns:1fr 450px;gap:5rem;max-width:1400px}.hero-image-wrapper{width:380px;height:380px}.hero-name{font-size:4rem}.hero-title{font-size:2.25rem}.hero-tagline{font-size:1.2rem}}.about{background:var(--bg-secondary);align-items:center;min-height:100vh;padding:5rem 2rem;display:flex}[data-theme=light] .about{min-height:auto;padding:4rem 2rem}.about-container{width:100%;max-width:1100px;margin:0 auto}.about-content{margin-bottom:3rem}.about-text{color:var(--text-secondary);text-align:left;margin-bottom:1.5rem;font-size:1.1rem;line-height:1.8}.about-text strong{color:var(--text-primary);font-weight:600}.about-text:last-child{margin-bottom:0}.about-highlights{grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3rem;display:grid}.highlight-item{background:var(--bg-surface);text-align:center;border:1px solid var(--border-color);border-radius:12px;padding:2rem 1.5rem;transition:all .3s}.highlight-item:hover{box-shadow:var(--shadow-accent);border-color:var(--primary-color);transform:translateY(-5px)}.highlight-item h3{color:var(--text-primary);margin:0 0 .75rem;font-size:1.2rem;font-weight:600}.highlight-item p{color:var(--text-secondary);margin:0;font-size:1rem;line-height:1.6}@media (max-width:768px){.about{min-height:auto;padding:4rem 1.5rem}.section-title{margin-bottom:2rem;font-size:2rem}.section-title:after{width:50px;height:3px}.about-content{margin-bottom:2rem}.about-text{margin-bottom:1.25rem;font-size:1rem}.about-highlights{grid-template-columns:1fr;gap:1.5rem;margin-top:2rem}.highlight-item{padding:1.5rem 1rem}.highlight-item h3{font-size:1.1rem}.highlight-item p{font-size:.95rem}}@media (max-width:1024px) and (min-width:769px){.about{padding:4.5rem 2rem}.section-title{font-size:2.25rem}.about-text{font-size:1.05rem}.about-highlights{grid-template-columns:repeat(3,1fr);gap:1.5rem}.highlight-item{padding:1.75rem 1.25rem}}@media (min-width:1440px){.about-container{max-width:1200px}.section-title{font-size:3rem}.about-text{font-size:1.15rem}.about-highlights{gap:2.5rem}.highlight-item{padding:2.5rem 2rem}}.skills{background:var(--bg-primary);align-items:center;min-height:100vh;padding:5rem 2rem;display:flex}[data-theme=light] .skills{min-height:auto;padding:4rem 2rem}.skills-container{width:100%;max-width:1300px;margin:0 auto}.skills-grid{grid-template-columns:repeat(3,1fr);gap:2.5rem;margin-top:1rem;display:grid}.skill-category{background:var(--bg-surface);box-shadow:var(--shadow-md);border:1px solid var(--border-color);border-radius:16px;padding:2rem;transition:all .3s}.skill-category:hover{box-shadow:var(--shadow-accent);border-color:var(--primary-color);transform:translateY(-8px)}.category-title{color:var(--text-primary);text-align:center;margin:0 0 1.5rem;font-size:1.5rem;font-weight:700}.skills-list{flex-direction:column;gap:1rem;display:flex}.skill-item{background:var(--bg-surface-light);cursor:pointer;border:2px solid #0000;border-radius:10px;align-items:center;gap:1rem;padding:1rem;transition:all .3s;display:flex}.skill-item:hover{background:var(--bg-primary);border-color:var(--skill-color);box-shadow:var(--shadow-sm);transform:translate(8px)}.skill-icon{color:var(--skill-color);justify-content:center;align-items:center;font-size:2rem;transition:all .3s;display:flex}.skill-item:hover .skill-icon{transform:scale(1.2)rotate(5deg)}.skill-name{color:var(--text-primary);font-size:1.1rem;font-weight:500}@media (max-width:768px){.skills{min-height:auto;padding:4rem 1.5rem}.section-title{margin-bottom:2rem;font-size:2rem}.skills-grid{grid-template-columns:1fr;gap:1.5rem;margin-top:.5rem}.skill-category{padding:1.5rem}.category-title{margin-bottom:1rem;font-size:1.3rem}.skills-list{gap:.75rem}.skill-item{gap:.875rem;padding:.875rem}.skill-item:hover{transform:translate(4px)}.skill-icon{font-size:1.75rem}.skill-name{font-size:1rem}}@media (max-width:1024px) and (min-width:769px){.skills{padding:4.5rem 2rem}.skills-grid{grid-template-columns:repeat(2,1fr);gap:2rem}.skill-category{padding:1.75rem}.category-title{font-size:1.4rem}.skill-icon{font-size:1.85rem}.skill-name{font-size:1.05rem}}@media (max-width:900px) and (min-width:769px){.skills-grid{grid-template-columns:1fr}}@media (min-width:1440px){.skills-container{max-width:1400px}.skills-grid{gap:3rem}.skill-category{padding:2.5rem}.category-title{font-size:1.65rem}.skill-item{padding:1.25rem}.skill-icon{font-size:2.25rem}.skill-name{font-size:1.15rem}}.projects{background:var(--bg-secondary);min-height:100vh;padding:5rem 2rem}[data-theme=light] .projects{min-height:auto;padding:4rem 2rem}.projects-container{width:100%;max-width:1200px;margin:0 auto}.section-subtitle{text-align:center;color:var(--text-secondary);margin:-1.5rem 0 3rem;font-size:1.1rem}.projects-grid{flex-wrap:wrap;justify-content:center;align-items:stretch;gap:2.5rem;margin-top:1rem;display:flex}.project-card{background:var(--bg-surface);box-shadow:var(--shadow-md);border:1px solid var(--border-color);border-radius:16px;flex-direction:column;flex:320px;max-width:380px;transition:all .3s;display:flex;overflow:hidden}.project-card:hover{box-shadow:var(--shadow-accent);border-color:var(--primary-color);transform:translateY(-10px)}.project-image-container{background:var(--bg-surface-light);width:100%;height:250px;position:relative;overflow:hidden}.project-image{object-fit:cover;width:100%;height:100%;transition:transform .5s}.project-card:hover .project-image{transform:scale(1.1)}.project-overlay{opacity:0;background:#38bdf8f2;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:absolute;inset:0}.project-card:hover .project-overlay{opacity:1}.project-links{gap:1.5rem;display:flex}.project-links.single-link{justify-content:center}.project-link{color:#fff;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;font-size:1.8rem;text-decoration:none;transition:all .3s;display:flex}.project-link:hover{transform:scale(1.2)}.project-link span{font-size:.9rem;font-weight:500}.project-content{flex-direction:column;flex-grow:1;padding:1.75rem;display:flex}.project-title{color:var(--text-primary);margin:0 0 1rem;font-size:1.5rem;font-weight:700}.project-description{color:var(--text-secondary);flex-grow:1;margin:0 0 1.5rem;font-size:1rem;line-height:1.7}.project-tech{flex-wrap:wrap;gap:.5rem;display:flex}.tech-tag{color:var(--primary-color);background:#38bdf81a;border:1px solid #38bdf833;border-radius:20px;padding:.4rem .875rem;font-size:.85rem;font-weight:500;transition:all .3s}.tech-tag:hover{background:var(--primary-color);color:var(--bg-primary);border-color:var(--primary-color);transform:translateY(-2px)}@media (max-width:768px){.projects{min-height:auto;padding:4rem 1.5rem}.section-title{margin-bottom:2rem;font-size:2rem}.section-subtitle{margin:-1rem 0 2rem;font-size:1rem}.projects-grid{grid-template-columns:1fr;gap:2rem;margin-top:.5rem}.project-image-container{height:200px}.project-content{padding:1.5rem}.project-title{margin-bottom:.875rem;font-size:1.3rem}.project-description{margin-bottom:1.25rem;font-size:.95rem}.project-links{gap:1rem}.project-link{padding:.75rem;font-size:1.5rem}.project-link span{font-size:.8rem}.tech-tag{padding:.35rem .75rem;font-size:.8rem}}@media (max-width:1024px) and (min-width:769px){.projects{padding:4.5rem 2rem}.projects-grid{grid-template-columns:repeat(2,1fr);gap:2rem}.project-image-container{height:220px}.project-title{font-size:1.4rem}.project-description{font-size:.98rem}}@media (min-width:1440px){.projects-container{max-width:1400px}.projects-grid{grid-template-columns:repeat(3,1fr);gap:3rem}.project-image-container{height:280px}.project-content{padding:2rem}.project-title{font-size:1.6rem}.project-description{font-size:1.05rem}}.experience{background:var(--bg-primary);align-items:center;min-height:100vh;padding:5rem 2rem;display:flex}[data-theme=light] .experience{min-height:auto;padding:4rem 2rem}.experience-container{width:100%;max-width:1000px;margin:0 auto}.timeline{padding:2rem 0;position:relative}.timeline:before{content:"";background:linear-gradient(180deg,var(--primary-color)0%,var(--secondary-color)100%);width:3px;position:absolute;top:0;bottom:0;left:30px}.timeline-item{margin-bottom:3rem;padding-left:80px;position:relative}.timeline-item:last-child{margin-bottom:0}.timeline-marker{background:var(--primary-color);border:4px solid var(--bg-primary);width:35px;height:35px;color:var(--bg-primary);z-index:1;border-radius:50%;justify-content:center;align-items:center;font-size:.9rem;display:flex;position:absolute;top:0;left:14px;box-shadow:0 4px 10px #38bdf866}.timeline-content{background:var(--bg-surface);box-shadow:var(--shadow-md);border:1px solid var(--border-color);border-radius:12px;padding:2rem;transition:all .3s}.timeline-content:hover{box-shadow:var(--shadow-accent);border-color:var(--primary-color);transform:translateY(-5px)}.experience-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.experience-role{color:var(--text-primary);margin:0 0 .5rem;font-size:1.5rem;font-weight:700;line-height:1.3}.experience-company{color:var(--primary-color);margin:0;font-size:1.1rem;font-weight:500}.experience-period{color:var(--text-secondary);white-space:nowrap;align-items:center;gap:.5rem;font-size:.95rem;font-weight:500;display:flex}.experience-period svg{color:var(--primary-color)}.experience-responsibilities{margin:0 0 1.5rem;padding:0;list-style:none}.experience-responsibilities li{color:var(--text-secondary);margin-bottom:.875rem;padding-left:1.5rem;font-size:1rem;line-height:1.7;position:relative}.experience-responsibilities li:before{content:"▹";color:var(--primary-color);font-size:1.2rem;font-weight:700;position:absolute;left:0}.experience-responsibilities li:last-child{margin-bottom:0}.experience-skills{flex-wrap:wrap;gap:.625rem;margin-top:1.5rem;display:flex}.skill-badge{color:var(--primary-color);background:#38bdf81a;border:1px solid #38bdf833;border-radius:20px;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .3s}.skill-badge:hover{background:var(--primary-color);color:var(--bg-primary);border-color:var(--primary-color);transform:translateY(-2px)}@media (max-width:768px){.experience{min-height:auto;padding:4rem 1.5rem}.section-title{margin-bottom:2rem;font-size:2rem}.section-subtitle{margin:-1rem 0 2rem;font-size:1rem}.timeline:before{left:15px}.timeline-item{margin-bottom:2.5rem;padding-left:50px}.timeline-marker{width:30px;height:30px;font-size:.8rem;left:0}.timeline-content{padding:1.5rem}.experience-header{flex-direction:column;align-items:flex-start}.experience-role{margin-bottom:.375rem;font-size:1.25rem}.experience-company{font-size:1rem}.experience-period{margin-top:.5rem;font-size:.9rem}.experience-responsibilities li{margin-bottom:.75rem;padding-left:1.25rem;font-size:.95rem}.experience-skills{gap:.5rem;margin-top:1.25rem}.skill-badge{padding:.4rem .875rem;font-size:.8rem}}@media (max-width:1024px) and (min-width:769px){.experience{padding:4.5rem 2rem}.timeline-item{padding-left:70px}.timeline-marker{left:10px}.timeline:before{left:26px}.experience-role{font-size:1.4rem}.experience-company{font-size:1.05rem}.experience-responsibilities li{font-size:.98rem}}@media (min-width:1440px){.experience-container{max-width:1200px}.timeline-item{padding-left:90px}.timeline-marker{width:40px;height:40px;font-size:1rem}.timeline:before{left:34px}.timeline-content{padding:2.5rem}.experience-role{font-size:1.65rem}.experience-company{font-size:1.15rem}.experience-responsibilities li{font-size:1.05rem}}.contact{background:var(--bg-secondary);align-items:center;min-height:100vh;padding:5rem 2rem;display:flex}[data-theme=light] .contact{min-height:auto;padding:4rem 2rem}.contact-container{width:100%;max-width:1200px;margin:0 auto}.contact-content{grid-template-columns:1fr 1.2fr;gap:3rem;margin-top:1rem;display:grid}.contact-info{flex-direction:column;display:flex}.contact-info-title{color:var(--text-primary);margin:0 0 2rem;font-size:1.75rem;font-weight:700}.contact-links{flex-direction:column;gap:1.5rem;display:flex}.contact-link{background:var(--bg-surface);border:2px solid var(--border-color);border-radius:12px;align-items:center;gap:1.25rem;padding:1.5rem;text-decoration:none;transition:all .3s;display:flex}.contact-link:hover{background:var(--bg-surface-light);border-color:var(--primary-color);box-shadow:var(--shadow-sm);transform:translate(10px)}.contact-icon{color:var(--primary-color);justify-content:center;align-items:center;font-size:2rem;transition:all .3s;display:flex}.contact-link.email .contact-icon{color:#ea4335}.contact-link.email:hover{border-color:#ea4335}.contact-link.github .contact-icon{color:var(--text-primary)}.contact-link.github:hover{border-color:var(--text-primary)}.contact-link.linkedin .contact-icon{color:#0a66c2}.contact-link.linkedin:hover{border-color:#0a66c2}.contact-link:hover .contact-icon{transform:scale(1.2)rotate(5deg)}.contact-details{flex-direction:column;gap:.25rem;display:flex}.contact-label{color:var(--text-light);text-transform:uppercase;letter-spacing:.05em;font-size:.875rem;font-weight:600}.contact-value{color:var(--text-secondary);font-size:1rem;font-weight:500}.social-media-section{border-top:1px solid var(--border-color);margin-top:2.5rem;padding-top:2rem}.social-media-title{color:var(--text-primary);margin:0 0 1.5rem;font-size:1.25rem;font-weight:600}.social-media-icons{align-items:center;gap:1.5rem;display:flex}.social-icon{color:#fffc;background:var(--bg-surface);border:2px solid var(--border-color);border-radius:12px;justify-content:center;align-items:center;width:50px;height:50px;font-size:1.5rem;text-decoration:none;transition:all .3s;display:flex;position:relative}[data-theme=light] .social-icon{color:#0f172acc}.social-icon:after{content:attr(data-tooltip);background:var(--bg-primary);color:var(--text-primary);white-space:nowrap;opacity:0;pointer-events:none;border:1px solid var(--border-color);z-index:10;border-radius:6px;padding:.5rem .75rem;font-size:.875rem;font-weight:500;transition:all .3s;position:absolute;bottom:100%;left:50%;transform:translate(-50%)translateY(-8px);box-shadow:0 4px 12px #00000080}.social-icon:before{content:"";border:6px solid #0000;border-top-color:var(--bg-primary);opacity:0;pointer-events:none;z-index:10;transition:all .3s;position:absolute;bottom:100%;left:50%;transform:translate(-50%)translateY(-2px)}.social-icon:hover:after,.social-icon:hover:before{opacity:1;transform:translate(-50%)translateY(0)}.social-icon:hover{color:var(--bg-primary);background:var(--primary-color);border-color:var(--primary-color);transform:translateY(-5px)scale(1.1);box-shadow:0 8px 20px #38bdf866,0 0 30px #38bdf84d,0 0 50px #38bdf833}.social-icon.facebook:hover{background:var(--brand-facebook);border-color:var(--brand-facebook);box-shadow:0 8px 20px #1877f280,0 0 30px #1877f266,0 0 50px #1877f24d}.social-icon.instagram:hover{background:linear-gradient(45deg,var(--brand-instagram-start),var(--brand-instagram-mid),var(--brand-instagram-end));border-color:var(--brand-instagram-mid);box-shadow:0 8px 20px #dd2a7b80,0 0 30px #dd2a7b66,0 0 50px #f585294d}.social-icon.whatsapp:hover{background:var(--brand-whatsapp);border-color:var(--brand-whatsapp);box-shadow:0 8px 20px #25d36680,0 0 30px #25d36666,0 0 50px #25d3664d}[data-theme=light] .social-icon:hover{color:#fff}[data-theme=light] .social-icon.facebook:hover{color:#fff;box-shadow:0 8px 20px #1877f299,0 0 30px #1877f280,0 0 50px #1877f266}[data-theme=light] .social-icon.instagram:hover{color:#fff;box-shadow:0 8px 20px #dd2a7b99,0 0 30px #dd2a7b80,0 0 50px #f5852966}[data-theme=light] .social-icon.whatsapp:hover{color:#fff;box-shadow:0 8px 20px #25d36699,0 0 30px #25d36680,0 0 50px #25d36666}.contact-form-wrapper{background:var(--bg-surface);box-shadow:var(--shadow-md);border:1px solid var(--border-color);border-radius:16px;padding:2.5rem}.contact-form-title{color:var(--text-primary);margin:0 0 2rem;font-size:1.75rem;font-weight:700}.contact-form{flex-direction:column;gap:1.5rem;display:flex}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-group label{color:var(--text-secondary);font-size:.95rem;font-weight:600}.form-group input,.form-group textarea{border:2px solid var(--border-color);background:var(--bg-surface-light);color:var(--text-primary);border-radius:8px;padding:.875rem 1rem;font-family:inherit;font-size:1rem;transition:all .3s}.form-group input:focus,.form-group textarea:focus{border-color:var(--primary-color);background:var(--bg-primary);outline:none;box-shadow:0 0 0 3px #38bdf81a}.form-group textarea{resize:vertical;min-height:120px}.submit-btn{color:var(--bg-primary);background:var(--primary-color);cursor:pointer;box-shadow:var(--shadow-accent);border:none;border-radius:8px;justify-content:center;align-items:center;gap:.75rem;padding:1rem 2rem;font-size:1rem;font-weight:600;transition:all .3s;display:flex}.submit-btn:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 6px 25px #38bdf866}.submit-btn svg{font-size:1.1rem}.submit-btn:disabled{cursor:not-allowed;opacity:.8}.submit-btn:disabled:hover{background:var(--primary-color);box-shadow:var(--shadow-accent);transform:none}.contact-success-modal{z-index:2000;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.contact-success-modal__backdrop{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0f172ab8;position:absolute;inset:0}.contact-success-modal__content{background:var(--bg-surface);border:1px solid var(--border-color);width:min(100%,520px);box-shadow:var(--shadow-lg);text-align:center;border-radius:20px;padding:2rem;position:relative}.contact-success-modal__message{color:var(--text-primary);margin:0 0 1.5rem;font-size:1.1rem;line-height:1.8}.contact-success-modal__button{background:var(--primary-color);min-width:140px;color:var(--bg-primary);cursor:pointer;box-shadow:var(--shadow-accent);border:none;border-radius:999px;padding:.875rem 1.5rem;font-size:1rem;font-weight:700;transition:all .3s}.contact-success-modal__button:hover{background:var(--primary-dark);transform:translateY(-2px)}@media (max-width:768px){.contact{min-height:auto;padding:4rem 1.5rem}.section-title{margin-bottom:2rem;font-size:2rem}.section-subtitle{margin:-1rem 0 2rem;font-size:1rem}.contact-content{grid-template-columns:1fr;gap:2rem;margin-top:.5rem}.contact-info-title,.contact-form-title{margin-bottom:1.5rem;font-size:1.5rem}.contact-links{gap:1rem}.contact-link{gap:1rem;padding:1.25rem}.contact-link:hover{transform:translate(5px)}.contact-icon{font-size:1.75rem}.contact-label{font-size:.8rem}.contact-value{font-size:.95rem}.contact-form-wrapper{padding:2rem 1.5rem}.form-group input,.form-group textarea{padding:.75rem .875rem;font-size:.95rem}.submit-btn{padding:.875rem 1.75rem;font-size:.95rem}.contact-success-modal__content{border-radius:16px;padding:1.5rem}.contact-success-modal__message{font-size:1rem}.contact-success-modal__button{width:100%}.social-media-section{margin-top:2rem;padding-top:1.5rem}.social-media-title{margin-bottom:1.25rem;font-size:1.15rem}.social-media-icons{justify-content:flex-start;gap:1.25rem}.social-icon{width:45px;height:45px;font-size:1.35rem}}@media (max-width:1024px) and (min-width:769px){.contact{padding:4.5rem 2rem}.contact-content{grid-template-columns:1fr;gap:2.5rem}.contact-info-title,.contact-form-title{font-size:1.65rem}.contact-icon{font-size:1.85rem}.social-media-section{margin-top:2.25rem}.social-icon{width:48px;height:48px;font-size:1.45rem}}@media (min-width:1440px){.contact-container{max-width:1400px}.contact-content{gap:4rem}.contact-info-title,.contact-form-title{font-size:2rem}.contact-form-wrapper{padding:3rem}.contact-link{padding:1.75rem}.contact-icon{font-size:2.25rem}.contact-value{font-size:1.05rem}.social-media-section{margin-top:3rem;padding-top:2.5rem}.social-media-title{font-size:1.35rem}.social-media-icons{gap:1.75rem}.social-icon{width:55px;height:55px;font-size:1.65rem}}.theme-toggle{background:var(--surface-color);border:2px solid var(--primary-color);color:var(--primary-color);cursor:pointer;z-index:1000;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;transition:all .3s;display:flex;position:relative}.theme-toggle:hover{background:var(--primary-color);color:var(--bg-color);transform:scale(1.1)rotate(15deg);box-shadow:0 0 20px #38bdf880}.theme-toggle:active{transform:scale(.95)}.theme-toggle svg{transition:transform .3s}.theme-toggle:hover svg{transform:rotate(30deg)}#root{width:100%;max-width:100%;min-height:100vh;overflow-x:hidden}main{width:100%;max-width:100%;padding-top:70px;animation:.4s ease-in-out fadeIn;overflow-x:hidden}@keyframes fadeIn{0%{opacity:.7}to{opacity:1}}.global-controls{z-index:1000;flex-direction:column;gap:15px;display:flex;position:fixed;bottom:30px;right:30px}[dir=rtl] .global-controls{left:30px;right:auto}@media (max-width:768px){.global-controls{gap:12px;bottom:20px;right:20px}[dir=rtl] .global-controls{left:20px;right:auto}}.section-title{color:var(--text-primary);text-align:center;margin-bottom:3rem;font-size:2.5rem;font-weight:700;position:relative}.section-title:after{content:"";background:var(--primary-color);border-radius:2px;width:60px;height:4px;position:absolute;bottom:-10px;left:50%;transform:translate(-50%)}.section-subtitle{text-align:center;color:var(--text-secondary);max-width:700px;margin:-1.5rem auto 3rem;font-size:1.1rem}@media (max-width:768px){main{padding-top:60px}.section-title{margin-bottom:2rem;font-size:2rem}.section-title:after{width:50px;height:3px}.section-subtitle{margin:-1rem 0 2rem;font-size:1rem}}@media (max-width:480px){.section-title{font-size:1.75rem}}.loading{color:#2563eb;justify-content:center;align-items:center;min-height:100vh;font-size:1.5rem;display:flex}
