@font-face{font-family:JAi;src:url(/fonts/JAi_____.TTF) format("truetype");font-weight:400;font-style:normal}:root{--primary-color: #2563eb;--secondary-color: #1e40af;--text-color: #1f2937;--background-color: #ffffff;--section-padding: 5rem 0;font-family:JAi,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:JAi,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--text-color);line-height:1.5;margin:0;background-color:var(--background-color);min-width:320px;min-height:100vh}section{padding:var(--section-padding);width:100%;margin:0}.container{max-width:1200px;margin:0 auto;padding:0 1rem}h1,h2,h3,h4,h5,h6{margin-bottom:1rem}a{text-decoration:none;color:inherit}img{max-width:100%;height:auto}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:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.app{min-height:100vh;width:100%;background:var(--background-color)}main{width:100%;background:transparent;padding:0;margin:0;display:block}.cv-button{display:inline-block;padding:.8rem 2rem;background-color:var(--primary-color);color:#fff;border-radius:5px;font-weight:500;font-size:1rem;transition:background-color .3s ease}.contenedor-boton{position:relative;display:inline-block}.fondo-negro{position:absolute;top:0;right:0;bottom:0;left:0;background-color:#000;border-radius:.375rem;z-index:0}.boton{position:relative;display:inline-flex;align-items:center;padding:.5rem 1rem;background-color:#2563eb;border:none;border-radius:.375rem;font-weight:600;font-size:1rem;color:#fff;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;transform:translate(-.25rem,-.25rem);transition:transform .15s ease-in-out,background-color .15s ease-in-out;z-index:1}.boton:hover{transform:translate(0);background-color:#3b82f6;color:#000}.boton:active{background-color:#1d4ed8}.boton:focus{outline:none}.lang-btn{background:none;border:none;padding:0;margin-left:.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;outline:none;font-size:1rem}.lang-btn:focus{outline:none;box-shadow:none}.flag-img{width:1.5rem;height:1.5rem;object-fit:cover;border-radius:50%;transition:transform .2s;box-shadow:none;border:none}.lang-btn:hover .flag-img{transform:scale(1.25)}#root{width:100%;margin:0;padding:0}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.language-loader-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#fffc;display:flex;justify-content:center;align-items:center;z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.mobile-nav-buttons{display:none;position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:#000000b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:10px;border-radius:25px;gap:10px;z-index:1000}.mobile-nav-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:#ffffff1a;color:#fff;text-decoration:none;transition:all .3s ease}.mobile-nav-button:hover{background:#fff3;transform:scale(1.1)}.mobile-nav-button .material-icons{font-size:20px}@media (max-width: 768px){.mobile-nav-buttons{display:flex}}.navbar{position:fixed;top:0;left:0;width:100%;background-color:var(--background-color);box-shadow:0 2px 4px #0000001a;z-index:1000}.navbar-container{max-width:1200px;margin:0 auto;padding:1rem;display:flex;justify-content:space-between;align-items:center}.nav-logo{font-size:1.5rem;font-weight:700;color:var(--primary-color);cursor:pointer}.nav-menu{display:flex;list-style:none;gap:2rem}.nav-item{position:relative;padding:0;margin:0}.nav-item .boton{width:140px;justify-content:center}.nav-item .fondo-negro{width:140px}.nav-link{color:inherit!important;padding:0;margin:0;background:none;box-shadow:none}@media (max-width: 768px){.nav-menu{display:none}}.typewriter-text{display:inline-block;border-right:2px solid var(--primary-color);animation:blink .7s step-end infinite}@keyframes blink{0%,to{border-color:transparent}50%{border-color:var(--primary-color)}}.about-me-popup-container{position:relative;z-index:2000}.about-me-button{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;position:relative;box-shadow:0 0 20px #667eea80;animation:glow 2s ease-in-out infinite}.about-me-button:hover{transform:scale(1.1);box-shadow:0 0 30px #667eeacc}.about-me-icon{font-size:1.5rem;color:#fff}@keyframes glow{0%,to{box-shadow:0 0 20px #667eea80,0 0 40px #667eea4d,0 0 60px #667eea33}50%{box-shadow:0 0 30px #667eeacc,0 0 60px #667eea80,0 0 90px #667eea4d}}.about-me-panel{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:500px;max-width:90vw;max-height:80vh;background:linear-gradient(135deg,#1a1a1af2,#2d2d2df2);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:2rem;border-radius:12px;box-shadow:0 10px 40px #000000b3,0 0 20px #667eea66;animation:fadeSlideDown .3s ease-out;z-index:9999;border:1px solid rgba(102,126,234,.5)}.about-me-panel h3{color:#667eea;margin-bottom:1rem;font-size:1.3rem;text-align:center}.about-me-content{max-height:400px;overflow-y:auto;padding-right:.5rem}.about-me-content::-webkit-scrollbar{width:6px}.about-me-content::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.about-me-content::-webkit-scrollbar-thumb{background:#667eea80;border-radius:3px}.about-me-content::-webkit-scrollbar-thumb:hover{background:#667eeab3}.about-me-content p{color:#e0e0e0;line-height:1.6;margin-bottom:1rem;text-align:justify;font-size:.95rem}.about-me-content p:last-child{margin-bottom:0}@keyframes fadeSlideDown{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@media (max-width: 768px){.about-me-panel{width:90vw;max-height:70vh;padding:1.5rem}.about-me-button{width:45px;height:45px}.about-me-icon{font-size:1.3rem}.about-me-panel h3{font-size:1.1rem}.about-me-content p{font-size:.9rem}}.dynamic-background{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;z-index:1;pointer-events:none}.background-canvas{position:absolute;top:0;left:0;width:100%;height:100%;display:block;background:linear-gradient(135deg,#0f172a,#1e293b,#334155)}.background-gradient-bottom{position:absolute;bottom:0;left:0;width:100%;height:150px;background:linear-gradient(to bottom,#fff0 42%,#fafcff4d 54%,#f8fafcb3 70%,#f8fafc);pointer-events:none;z-index:2}@media (max-width: 768px){.background-gradient-bottom{height:100px}}.hero{min-height:100vh;display:flex;align-items:center;padding-top:80px;position:relative;overflow:hidden}.hero-container{max-width:1200px;margin:0 auto;padding:0 1rem;width:100%;display:flex;justify-content:flex-end;position:relative;z-index:10}.hero-content{display:flex;align-items:center;gap:4rem;min-height:300px;width:100%;max-width:800px}.hero-image-wrapper{position:absolute;left:6rem;top:50%;transform:translateY(-50%);z-index:100}.hero-image{width:300px;height:300px;border-radius:50%;overflow:hidden;position:relative;animation:shadow-flash 2s ease-in-out infinite}.about-me-button-wrapper{position:absolute;bottom:-10px;right:-10px;z-index:101}@keyframes shadow-flash{0%,to{box-shadow:0 10px 20px #312fbfcc,0 0 40px #667eea4d,0 0 60px #667eea33}50%{box-shadow:0 10px 20px #312fbfcc,0 0 60px #667eea80,0 0 90px #667eea4d}}.hero-image img{width:100%;height:100%;object-fit:cover;object-position:center 70%;position:absolute;top:0;left:0}.hero-text{flex:1;text-align:center}.hero-text h1{font-size:3.5rem;margin-bottom:1.5rem;color:#fff;white-space:nowrap;overflow:visible;line-height:1.2;padding-bottom:.5rem;text-shadow:2px 2px 8px rgba(0,0,0,.5)}.hero-text h2{font-size:1.5rem;color:#a5b4fc;margin-bottom:1.5rem;line-height:1.4;text-shadow:1px 1px 4px rgba(0,0,0,.5)}.hero-links{display:flex;gap:1rem;margin:1.5rem 0}.hero-links a{font-size:1.5rem;color:var(--text-color);transition:color .3s ease}.hero-links a:hover{color:var(--primary-color)}.cv-button{display:inline-block;padding:.8rem 2rem;background-color:var(--primary-color);color:#fff;border-radius:5px;font-weight:500;transition:background-color .3s ease}.cv-button:hover{background-color:var(--secondary-color)}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#dcdcdcd9;display:flex;align-items:center;justify-content:center;z-index:2000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;padding:2rem 1.5rem 1.5rem;max-width:350px;width:95vw;max-height:90vh;position:relative;display:flex;flex-direction:column;align-items:center;overflow-y:auto;overflow-x:auto}.close-modal{position:absolute;top:10px;right:18px;background:none;border:none;font-size:2rem;color:#888;cursor:pointer;z-index:10}.cv-download-modal{margin-top:1.5rem;display:inline-block;padding:.7rem 2rem;background-color:var(--primary-color);color:#fff;border-radius:5px;font-weight:500;transition:background-color .3s ease;text-align:center}.cv-download-modal:hover{background-color:var(--secondary-color)}.cv-preview-img{display:block;margin:0 auto 1.5rem;width:200%;min-width:700px;height:auto;border-radius:8px;box-shadow:0 2px 8px #00000014;object-fit:contain}.email-container{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1.5rem}.email-container p{margin:0;font-size:1.1rem;color:var(--text-color)}.copy-button{background:none;border:none;color:var(--primary-color);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;transition:transform .2s ease}.typewriter{border-right:3px solid var(--primary-color);white-space:nowrap;overflow:hidden;animation:typing 3.5s steps(40,end),blink-caret .75s step-end infinite}@keyframes typing{0%{width:0}to{width:100%}}@keyframes blink-caret{0%,to{border-color:transparent}50%{border-color:var(--primary-color)}}@media (max-width: 768px){.hero-text h1{font-size:1.4rem;margin-bottom:1rem;line-height:1.3}.hero-text h2{font-size:1.2rem;margin-bottom:1rem}.hero-content{flex-direction:column;gap:2rem}.hero-image-wrapper{position:relative;left:0;top:0;transform:none;margin:0 auto}.hero-image{width:200px;height:200px;margin:0 auto}.about-me-button-wrapper{bottom:5px;right:calc(50% - 110px)}.hero-links{justify-content:center}}@media (max-width: 700px){.modal-content{max-width:95vw;padding:1rem .5rem}.modal-content iframe{height:300px}}.news{padding:var(--section-padding);background-color:#f8fafc;overflow:hidden}.news h2{text-align:center;color:var(--primary-color);margin-bottom:3rem;font-size:2.5rem;text-shadow:1px 1px 2px rgba(0,0,0,.4)}.news-container{max-width:1400px;margin:0 auto;position:relative;padding:0 4rem}.news-carousel{position:relative;display:flex;align-items:center;justify-content:center;gap:2rem;margin-bottom:2rem}.carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);background:transparent;border:none;color:#667eea;font-size:3rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;z-index:10;padding:.5rem;opacity:.7}.carousel-arrow:hover{color:#4f46e5;opacity:1;transform:translateY(-50%) scale(1.15)}.carousel-arrow:active{transform:translateY(-50%) scale(.95)}.carousel-arrow-prev{left:-60px}.carousel-arrow-next{right:-60px}.carousel-viewport{width:100%;max-width:800px;overflow:visible}.carousel-content{display:flex;justify-content:center;gap:2rem;padding:.5rem}.news-card{width:350px;flex-shrink:0;background:#020202;border-radius:12px;overflow:hidden;box-shadow:0 8px 16px #0003;transition:all .3s ease;cursor:pointer;display:flex;flex-direction:column}.news-card:hover{transform:translateY(-8px);box-shadow:0 12px 28px #00000059}.news-image{width:100%;height:200px;overflow:hidden;background-color:#1a1a1a;display:flex;align-items:center;justify-content:center}.news-image img{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .3s ease}.news-card:hover .news-image img{transform:scale(1.08)}.news-content{padding:1.5rem;flex-grow:1;display:flex;flex-direction:column;justify-content:space-between}.news-content h3{color:#667eea;font-size:1.2rem;margin-bottom:.8rem;line-height:1.4;font-weight:600}.news-date{color:#999;font-size:.9rem;margin:0;font-weight:400}.carousel-indicators{display:flex;justify-content:center;gap:.8rem;margin-top:1.5rem}.indicator-dot{width:12px;height:12px;border-radius:50%;background:#cbd5e1;border:none;cursor:pointer;transition:all .3s ease;padding:0}.indicator-dot:hover{background:#94a3b8;transform:scale(1.2)}.indicator-dot.active{background:#667eea;width:32px;border-radius:6px}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@media (max-width: 1024px){.carousel-arrow{font-size:2.5rem}.carousel-arrow-prev{left:-40px}.carousel-arrow-next{right:-40px}.news-card{width:320px}}@media (max-width: 768px){.news-container{padding:0 2rem}.carousel-content{justify-content:center}.news-card{width:100%;max-width:400px}.carousel-arrow{font-size:2rem}.carousel-arrow-prev{left:-30px}.carousel-arrow-next{right:-30px}}@media (max-width: 640px){.news-container{padding:0 3rem}.news h2{font-size:2rem;margin-bottom:2rem}.news-card{width:100%;max-width:350px}.news-image{height:160px}.news-content{padding:1.2rem}.news-content h3{font-size:1rem}.news-date{font-size:.85rem}.carousel-arrow{font-size:1.8rem}.carousel-arrow-prev{left:-35px}.carousel-arrow-next{right:-35px}.indicator-dot{width:8px;height:8px}.indicator-dot.active{width:24px}}.projects{padding:var(--section-padding);background-color:#f8fafc}.projects h2{text-align:center;color:var(--primary-color);margin-bottom:2rem;font-size:2.5rem;text-shadow:1px 1px 2px rgba(0,0,0,.4)}.projects-container{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;max-width:1000px;margin:0 auto;padding:0 1rem}.projects-container>div:last-child{grid-column:1 / -1;justify-self:center}.project-card{background:#1a1a1a;border-radius:12px;overflow:hidden;box-shadow:0 8px 16px #0003;display:flex;flex-direction:column;width:100%;max-width:400px;height:450px;margin:0 auto;position:relative;z-index:1}.project-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#1a1a1a;border-radius:12px;z-index:-1;transition:transform .2s ease-out,box-shadow .2s ease-out;transform-origin:center;will-change:transform;box-shadow:0 8px 16px #0003}.project-card:hover:after{transform:translateY(-5px);box-shadow:0 12px 24px #0000004d}.project-card>*{z-index:2}.project-image{width:100%;height:300px;overflow:hidden;position:relative;background-color:#1a1a1a;display:flex;align-items:stretch;justify-content:stretch;margin:0;padding:0}.project-image{position:relative;z-index:1;background-color:#1a1a1a}.project-image:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;background-color:#1a1a1a;opacity:0;transition:opacity .2s ease-out}.project-card:hover .project-image:after{opacity:.1}.project-image img{width:100%;height:100%;object-fit:cover;transition:transform .2s ease-out;display:block;margin:0;padding:0;border:none;vertical-align:middle;will-change:transform;transform-origin:center}.project-card:hover .project-image img{transform:scale(1.05)}.project-info{padding:1.5rem;text-align:center;flex:1;display:flex;flex-direction:column;justify-content:space-between}.project-info h3{color:#fff;margin-bottom:1rem;font-size:1.5rem}.project-info p{color:#e5e7eb;line-height:1.4;font-size:1rem;margin-top:.5rem;margin-bottom:.8rem}.project-technologies{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center;margin-top:auto;padding-top:1rem}.tech-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background-color:#fff;border-radius:6px;padding:.25rem;transition:transform .2s ease}.tech-icon:hover{transform:scale(1.2)}.tech-icon img{width:100%;height:100%;object-fit:contain}@media (max-width: 768px){.projects-container{grid-template-columns:1fr;align-items:center}.projects-container>div:last-child{grid-column:auto}.project-card{width:100%;max-width:300px}}.experience{padding:var(--section-padding);background-color:var(--background-color)}.experience-section{padding:var(--section-padding);background:#f8fafc}.experience-section h2{text-align:center;color:var(--primary-color);margin-bottom:2rem;font-size:2.5rem;text-shadow:1px 1px 2px rgba(0,0,0,.4)}.experience-title{text-align:center;color:var(--primary-color);margin-bottom:2.5rem;font-size:2.2rem}.experience-columns{display:flex;gap:3rem;justify-content:center;align-items:flex-start;max-width:1200px;margin:0 auto}.experience-column{flex:1}.column-title{text-align:center;font-size:1.5rem;color:#1a1a1a;margin-bottom:2rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.exp-card{display:flex;align-items:center;background:#1a1a1a;border-radius:12px;box-shadow:0 4px 12px #00000012;margin-bottom:2rem;padding:1.2rem 1.5rem;gap:1.5rem;min-height:90px;color:#fff;transition:transform .3s ease,box-shadow .3s ease}.exp-card:hover{transform:scale(1.04);box-shadow:0 8px 24px #0000002e}.exp-logo{width:56px;height:56px;object-fit:contain;border-radius:8px;background:#fff;border:1px solid #e5e7eb}.exp-info{display:flex;flex-direction:column;gap:.2rem}.exp-main{font-weight:600;font-size:1.1rem;color:#fff}.exp-sub{font-weight:500;color:#e5e7eb;font-size:1rem}.exp-date{color:#bdbdbd;font-size:.95rem}.exp-grid{display:grid;gap:2rem;margin-bottom:2.5rem}.exp-grid-3{grid-template-columns:repeat(3,1fr)}.exp-grid-2{grid-template-columns:repeat(2,1fr)}@media (max-width: 900px){.experience-columns{flex-direction:column;gap:2.5rem}.experience-column{width:100%}.exp-grid-3,.exp-grid-2{grid-template-columns:1fr}}.exp-grid{align-items:stretch;justify-items:center}.exp-grid-1{grid-template-columns:1fr;justify-items:center}.exp-grid-1 .info-card{max-width:350px;width:100%}.info-card{height:120px;min-height:120px;max-height:120px;max-width:350px;width:100%;display:flex;align-items:center;justify-content:center;box-sizing:border-box;background:#1a1a1a;border-radius:12px;box-shadow:0 4px 12px #00000012;margin-bottom:2rem;padding:1rem 1.2rem;gap:1.2rem;color:#fff;position:relative;z-index:1}.info-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#1a1a1a;border-radius:12px;z-index:-1;transition:transform .2s ease-out;transform-origin:center;will-change:transform}.info-card:hover:after{transform:scale(1.04);box-shadow:0 8px 24px #0000002e}.info-card>*{z-index:2}.info-logo{width:48px;height:48px;object-fit:contain;border-radius:8px;background:#fff;border:1px solid #e5e7eb}.info-details{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;width:100%;gap:.1rem}.info-main,.info-sub{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin:0;padding:0}.info-main{font-weight:600;font-size:1rem;color:#fff}.info-sub{font-weight:500;color:#e5e7eb;font-size:.95rem}.info-date,.info-location{color:#bdbdbd;font-size:.9rem;white-space:nowrap;margin:0;padding:0}.info-card{height:140px;min-height:140px;max-height:140px}.tech-carousel-vertical{width:100%;max-width:600px;height:150px;background-color:#1a1a1a;border-radius:12px;overflow:hidden;position:relative;box-shadow:0 4px 6px #0000001a;margin-top:1rem}.tech-marquee-content{position:absolute;top:0;left:0;width:100%;height:100%;animation:tech-marquee-horizontal 30s linear infinite;display:flex;flex-direction:row;align-items:center;padding:1rem}.tech-carousel-item{margin:0 .8rem;width:80px;height:80px;display:flex;align-items:center;justify-content:center;background-color:#1a1a1a;border-radius:8px;padding:.5rem;transition:transform .3s ease;flex-shrink:0}.tech-carousel-item:hover{transform:scale(1.1)}.tech-carousel-item img{width:100%;height:100%;object-fit:contain;background-color:#fff;border-radius:4px;padding:.2rem}@keyframes tech-marquee-horizontal{0%{transform:translate(0)}to{transform:translate(-75%)}}@media (max-width: 768px){.tech-carousel-vertical{height:120px}.tech-carousel-item{width:70px;height:70px}}.contact{padding:var(--section-padding);background-color:var(--background-color);min-height:auto;display:flex;flex-direction:column;align-items:center;max-width:1200px;margin:0 auto}.contact h2{text-align:center;color:var(--primary-color);margin-bottom:2rem;font-size:2.5rem;text-shadow:1px 1px 2px rgba(0,0,0,.4);width:100%}.contact-content{display:flex;flex-direction:column;align-items:center;gap:2rem;width:100%}.contact-content p{font-size:1.1rem;color:var(--text-color);max-width:600px;line-height:1.6;text-align:center}.contact-info{display:flex;flex-direction:column;gap:1rem;align-items:center}.email-container{display:flex;align-items:center;gap:1rem;background-color:#1a1a1a;padding:1rem 1.5rem;border-radius:12px;box-shadow:0 4px 6px #0000001a;transition:transform .3s ease,box-shadow .3s ease;width:350px;justify-content:flex-start}.email-container:hover{transform:translateY(-2px);box-shadow:0 6px 8px #0003}.email-icon{font-size:1.5rem;color:var(--primary-color);width:24px;text-align:left}.email-container p{margin:0;font-size:1.1rem;color:#fff;white-space:nowrap;text-align:left}.copy-button{background:none;border:none;color:var(--primary-color);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:flex-start;transition:transform .2s ease;margin-left:auto}.copy-button:hover{transform:scale(1.1);color:var(--secondary-color)}.copy-button:active{transform:scale(.95)}.whatsapp-button{display:flex;align-items:center;gap:1rem;background-color:#25d366;color:#fff;padding:1rem 2rem;border-radius:50px;text-decoration:none;font-weight:600;font-size:1.1rem;transition:all .3s ease;box-shadow:0 4px 6px #25d36633}.whatsapp-button:hover{transform:translateY(-2px);box-shadow:0 6px 8px #25d3664d}.whatsapp-icon{font-size:2rem}.contact-form{width:100%;max-width:500px;background:var(--card-background);padding:1.5rem;border-radius:10px;box-shadow:0 4px 6px #0000001a}.form-group{margin-bottom:1rem;position:relative}.form-group label{display:block;margin-bottom:.3rem;color:var(--text-color);font-weight:500;font-size:.9rem}.form-group input,.form-group textarea{width:100%;padding:.6rem;border:1px solid var(--border-color);border-radius:5px;background:var(--input-background);color:var(--text-color);font-size:.9rem;transition:all .3s ease}.form-group input.error,.form-group textarea.error{border-color:var(--error-color);background-color:rgba(var(--error-color-rgb),.05)}.form-group textarea{min-height:100px;resize:vertical}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px rgba(var(--primary-color-rgb),.2)}.error-message{color:var(--error-color);font-size:.75rem;margin-top:.25rem;display:block;animation:fadeIn .3s ease}button[type=submit]{width:100%;padding:.8rem;background:var(--primary-color);color:#fff;border:none;border-radius:5px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;justify-content:center;align-items:center;gap:.5rem;margin-top:.5rem}button[type=submit]:hover{background:var(--primary-color-dark);transform:translateY(-1px)}button[type=submit]:disabled{background:var(--disabled-color);cursor:not-allowed;transform:none}.success,.error{margin-top:.8rem;padding:.8rem;border-radius:5px;text-align:center;animation:slideIn .3s ease;font-size:.9rem}.success{background:var(--success-color);color:#fff}.error{background:var(--error-color);color:#fff}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.contact-form{padding:1.2rem}.contact h2{font-size:1.8rem}.contact-content p{font-size:1rem}.whatsapp-button{padding:.8rem 1.5rem;font-size:1rem}.whatsapp-icon{font-size:1.5rem}.email-container{padding:.8rem 1.2rem;width:300px}.email-container p{font-size:1rem}}.social-icons{position:fixed;right:2rem;bottom:2rem;display:flex;flex-direction:column;gap:1rem;z-index:1000}.social-icon{width:3rem;height:3rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;text-decoration:none;transition:all .3s ease;opacity:.7;box-shadow:0 2px 5px #0003}.social-icon:hover{opacity:1;transform:translateY(-3px);box-shadow:0 4px 8px #0000004d}.github{background-color:#333}.linkedin{background-color:#0077b5}.whatsapp{background-color:#25d366}@media (max-width: 768px){.social-icons{right:1rem;bottom:1rem}.social-icon{width:2.5rem;height:2.5rem;font-size:1.2rem}}
