*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:Inter,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.6;color:#333;background-color:#fff}.app-container{min-height:100vh;display:flex;flex-direction:column;transition:all .3s ease}.main-content{flex:1}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2;margin-bottom:1rem}p{margin-bottom:1rem;line-height:1.6}a{color:#666;text-decoration:none;transition:color .3s ease}a:hover{color:#333}button{font-family:inherit;border:none;border-radius:6px;cursor:pointer;transition:all .3s ease;font-weight:500}button:focus{outline:2px solid #666;outline-offset:2px}section{position:relative}html.dark,html.dark body,html.dark .app-container{background-color:#1a1a1a;color:#fff}html.dark a{color:#ccc}html.dark a:hover{color:#fff}.container{max-width:1200px;margin:0 auto;padding:0 2rem}.text-center{text-align:center}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}@media (max-width: 768px){.container{padding:0 1rem}}@media (max-width: 480px){.container{padding:0 .5rem}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}.fade-in{animation:fadeIn .6s ease forwards}.slide-in-left{animation:slideInLeft .6s ease forwards}.slide-in-right{animation:slideInRight .6s ease forwards}*:focus{outline:2px solid #666;outline-offset:2px}@media print{.app-container{background:#fff;color:#000}button{display:none}a{color:#000;text-decoration:underline}}@media (prefers-contrast: high){.app-container{background:#fff;color:#000}.dark{background:#000;color:#fff}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}html{scroll-behavior:auto}}.NavBar{display:flex;align-items:center;justify-content:space-around;background-color:#fff;padding:25px 40px 25px 50px;transform:1s;position:fixed;top:0;left:0;width:100%;z-index:1000;box-shadow:0 2px 10px #0000001a}ul{flex:1;list-style:none;text-align:center}ul li{display:inline-block;margin:10px 20px;font-size:15px;cursor:pointer;font-weight:700;color:#333;transition:color .3s ease}ul li:hover{color:#666}.toggleImg{width:30;height:30px;cursor:pointer}.dark .NavBar{background-color:#1a1a1a;color:#fff}.dark ul li{color:#fff}.dark ul li:hover{color:#ccc}.dark .sideNavBar{background-color:#1a1a1a;color:#fff}.sideNavBar{position:relative;display:flex;flex-direction:column;align-items:center;width:200px;height:1080px;background-color:#fff;padding:2rem;z-index:2000;float:right;transition:ease-in-out 5s;font-size:30px;box-shadow:-2px 0 10px #0000001a}.hamburgerMenu{font-size:30px;cursor:pointer;height:30px;display:none}#NavBar{display:flex}@media (max-width:800px){.mainList{visibility:hidden}.hamburgerMenu{display:flex}}@media (max-width:453px){.mainList{display:none}}.Home{display:flex;justify-content:space-between;align-items:center;margin:0 7%;padding:150px 0;transition:.5s}.textContainer{display:flex;flex-direction:column;position:relative;justify-content:center;align-items:flex-start}.textContainer h1{margin:20px 2px;font-size:55px;max-height:455px;color:#333}.textContainer p{max-width:555px;letter-spacing:2px;line-height:1.6;color:#666}.textContainer span{cursor:pointer;display:flex;font-size:40px;gap:1.3rem;color:#333}.textContainer span:hover{color:#666}.textContainer a,.textContainer a :hover,.textContainer a :visited,.textContainer a :link{color:#333;transition:color .3s ease}.textContainer a:hover{color:#666}.smile{margin:-9px 10px}.profileImg{border-radius:79% 21% 52% 48%/28% 69% 31% 72%;height:300px;width:300px;background-image:url(/assets/profesional\ photo-WybQufVl.jpg);background-size:cover;border-color:#000;border:3px solid #333;animation:bolb 10s ease-in-out infinite}@keyframes bolb{25%{border-radius:62% 38% 85% 15%/19% 73% 27% 81%}50%{border-radius:98% 2% 56% 44%/32% 69% 31% 68%}75%{border-radius:51% 49% 94% 6%/81% 76% 24% 19%}to{border-radius:79% 21% 52% 48%/28% 69% 31% 72%}}.dark .textContainer h1{color:#fff}.dark .profileImg{border:3px solid #ccc}.dark .textContainer p{color:#ccc}.dark .textContainer span{color:#fff}.dark .textContainer a{color:#ccc}.dark .textContainer a:hover{color:#fff}@media (max-width:900px){.Home{justify-content:center;flex-direction:column-reverse;align-items:center}.textContainer{flex-direction:column;align-items:center;text-align:center;justify-content:center}}@media (max-width:584px){.profileImg{height:250px;width:250px}.textContainer h1{font-size:44px}.textContainer p{font-size:15px;letter-spacing:2px;display:flex;flex-wrap:wrap}.textContainer{display:flex}}.about-section{padding:6rem 0;background:#f8f9fa}.about-container{max-width:800px;margin:0 auto;padding:0 2rem}.about-content{text-align:center}.about-title{font-size:2.5rem;font-weight:700;color:#333;margin:0 0 3rem;position:relative}.about-title:after{content:"";width:60px;height:4px;background:#666;position:absolute;bottom:-15px;left:50%;transform:translate(-50%);border-radius:2px}.about-summary{max-width:700px;margin:0 auto}.about-summary p{font-size:1.1rem;line-height:1.8;color:#666;margin:0 0 1.5rem;text-align:left}.about-summary p:last-child{margin-bottom:0}html.dark .about-section{background:#2d2e32}html.dark .about-title{color:#fff}html.dark .about-title:after{background:#ccc}html.dark .about-summary p{color:#adb5bd}@media (max-width: 768px){.about-section{padding:4rem 0}.about-container{padding:0 1.5rem}.about-title{font-size:2rem;margin-bottom:2rem}.about-summary p{font-size:1rem;line-height:1.7}}@media (max-width: 480px){.about-section{padding:3rem 0}.about-container{padding:0 1rem}.about-title{font-size:1.8rem}.about-summary p{font-size:.95rem;line-height:1.6;text-align:center}}.skills{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;padding:6rem 2rem;background:#f8f9fa;max-width:1200px;margin:0 auto}.skills ul{list-style:none;text-align:center;display:inline-block;transition:.5px}.skills ul li{display:inline-block;margin:10px 20px;font-size:15px;cursor:pointer;font-weight:700;position:relative;transition:all .3s ease;border-radius:10px;padding:10px}.skills ul li:hover{transform:translateY(-10px);box-shadow:0 10px 25px #0000001a;background:linear-gradient(45deg,#ffffff1a,#ffffff0d)}.skills ul li img{transition:all .3s ease;border-radius:8px}.skills ul li:hover img{transform:scale(1.1);filter:brightness(1.2)}.skill-label{display:block;margin-top:8px;font-size:12px;color:#666;opacity:0;transition:opacity .3s ease;font-weight:600}.skills ul li:hover .skill-label{opacity:1}.dark .skill-label{color:#ccc}.skill-group{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;background:#ffffff1a;border-radius:12px;transition:all .3s ease}.tech-icon{width:32px;height:32px;transition:all .3s ease}.expo-icon{filter:invert(.2)}.dark .expo-icon{filter:invert(.8)}.skills ul li:hover .skill-group{background:#6666661a;transform:scale(1.05)}.skills ul li:hover .tech-icon{transform:scale(1.1)}.dark .skill-group{background:#ffffff0d}.dark .skills ul li:hover .skill-group{background:#cccccc1a}.skills h1{color:#333;text-align:center;width:100%;margin-bottom:3rem;font-size:2.5rem;font-weight:700;position:relative}.skills h1:after{content:"";width:60px;height:4px;background:#666;position:absolute;bottom:-15px;left:50%;transform:translate(-50%);border-radius:2px}html.dark .skills h1{color:#fff}html.dark .skills h1:after{background:#ccc}html.dark .skills{color:#fff;background-color:#2d2e32}@media (max-width:450px){.skills li{font-size:10px}.skills{display:flex;justify-content:space-between}}.projects-container{padding:6rem 2rem;background-color:#fff;min-height:auto}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem;max-width:1200px;margin:0 auto}.project-card{background:#fff;border-radius:15px;overflow:hidden;box-shadow:0 5px 20px #0000001a;transition:all .4s ease;position:relative;transform:translateY(0)}.project-card:hover{transform:translateY(-15px);box-shadow:0 20px 40px #00000026}.project-image{position:relative;overflow:hidden;height:250px}.project-image img{width:100%;height:100%;object-fit:cover;transition:all .4s ease}.project-card:hover .project-image img{transform:scale(1.1);filter:brightness(.8)}.project-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .4s ease}.project-card:hover .project-overlay{opacity:1}.project-links{display:flex;justify-content:center}.project-link{padding:12px 24px;border-radius:25px;text-decoration:none;font-weight:700;transition:all .3s ease;transform:translateY(20px)}.project-card:hover .project-link{transform:translateY(0)}.live-link{background:#333;color:#fff;box-shadow:0 4px 15px #0003}.live-link:hover{background:#555;transform:scale(1.05);box-shadow:0 6px 20px #0000004d}.project-content{padding:2rem}.project-name{font-size:1.5rem;color:#333;font-weight:700;margin-bottom:1rem;transition:color .3s ease}.project-card:hover .project-name{color:#666}.project-description{color:#777;line-height:1.6;margin-bottom:1.5rem;font-size:.95rem}.project-features{margin-bottom:1.5rem}.features-title{font-size:1rem;color:#444;font-weight:600;margin-bottom:.8rem;transition:color .3s ease}.features-list{list-style:none;padding:0;margin:0}.feature-item{color:#555;font-size:.9rem;position:relative;padding:.3rem 0 .3rem 1.2rem;transition:all .3s ease}.feature-item:before{content:"✓";position:absolute;left:0;color:#666;font-weight:700;font-size:1rem}.project-card:hover .feature-item{color:#333;transform:translate(5px)}.project-card:hover .features-title{color:#333}.project-technologies{display:flex;flex-wrap:wrap;gap:.5rem}.tech-badge{background:#e9ecef;color:#495057;padding:.5rem 1rem;border-radius:20px;font-size:.85rem;font-weight:500;transition:all .3s ease}.project-card:hover .tech-badge{background:#333;color:#fff;transform:scale(1.05)}html.dark .projects-container{background-color:#2d2e32}html.dark .project-card{background:#1a1a1a;border:1px solid #404040}html.dark .project-name{color:#f9f9f9}html.dark .project-card:hover .project-name{color:#61dafb}html.dark .project-description{color:#ccc}html.dark .features-title{color:#f9f9f9}html.dark .project-card:hover .features-title{color:#61dafb}html.dark .feature-item{color:#bbb}html.dark .project-card:hover .feature-item{color:#f9f9f9}html.dark .feature-item:before{color:#61dafb}html.dark .tech-badge{background:#404040;color:#f9f9f9}html.dark .project-card:hover .tech-badge{background:#61dafb;color:#222}@media (max-width: 768px){.projects-container{padding:4rem 1rem}.projects-grid{grid-template-columns:1fr;gap:1.5rem}.project-content{padding:1.5rem}}@media (max-width: 453px){.project-links{justify-content:center}.project-link{padding:10px 20px;font-size:.9rem}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.project-card{animation:fadeInUp .6s ease forwards}.project-card:nth-child(1){animation-delay:.1s}.project-card:nth-child(2){animation-delay:.2s}.project-card:nth-child(3){animation-delay:.3s}.contact-container{padding:6rem 2rem;max-width:1200px;margin:0 auto}.contact-header{text-align:center;margin-bottom:4rem}.contact-label{color:#666;font-weight:700;font-size:1.1rem;text-transform:uppercase;letter-spacing:2px;margin-bottom:1rem}.contact-header h1{color:#333;font-family:Poppins,sans-serif;font-size:2.5rem;font-weight:700;margin:0}.contact-content{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}.contact-info{display:flex;flex-direction:column;gap:2rem}.contact-item{display:flex;align-items:center;gap:1.5rem;padding:1.5rem;background:#fff;border-radius:15px;box-shadow:0 5px 20px #0000001a;transition:all .3s ease}.contact-item:hover{transform:translateY(-5px);box-shadow:0 10px 30px #00000026}.contact-icon{display:flex;align-items:center;justify-content:center;width:60px;height:60px;background:#333;color:#fff;border-radius:50%;font-size:1.5rem;flex-shrink:0}.contact-details h3{color:#333;font-size:1.2rem;font-weight:600;margin:0 0 .5rem}.contact-details p{margin:0;color:#666}.contact-details a{color:#666;text-decoration:none;font-weight:500;transition:color .3s ease}.contact-details a:hover{color:#333}.contact-download-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.2rem;background:#333;color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:.8rem}.contact-download-btn:hover{background:#555;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.contact-form-section{background:#fff;padding:2.5rem;border-radius:20px;box-shadow:0 10px 30px #0000001a}.contact-form h2{color:#333;font-size:1.8rem;font-weight:600;margin-bottom:2rem;text-align:center}.form-group{margin-bottom:1.5rem}.form-input,.form-textarea{width:100%;padding:1rem 1.5rem;border:2px solid #e9ecef;border-radius:10px;font-size:1rem;font-family:inherit;transition:all .3s ease;background:#f8f9fa}.form-input:focus,.form-textarea:focus{outline:none;border-color:#333;background:#fff;box-shadow:0 0 0 3px #3333331a}.form-textarea{resize:vertical;min-height:120px}.submit-btn{width:100%;padding:1rem 2rem;background:#333;color:#fff;border:none;border-radius:10px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.submit-btn:hover:not(:disabled){background:#555;transform:translateY(-2px);box-shadow:0 10px 25px #0003}.submit-btn:disabled{opacity:.8;cursor:not-allowed}.submit-btn.success{background:#666}.resume-download{margin-top:2rem;padding:2rem;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:15px;text-align:center;border:2px dashed #666}.resume-download h3{color:#333;font-size:1.3rem;margin-bottom:.5rem}.resume-download p{color:#666;margin-bottom:1.5rem}.download-btn{padding:.8rem 1.5rem;background:#333;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:.5rem}.download-btn:hover{background:#555;transform:translateY(-2px);box-shadow:0 8px 20px #0003}html.dark .contact-header h1{color:#fff}html.dark .contact-item{background:#2d2e32;border:1px solid #404040}html.dark .contact-details h3{color:#fff}html.dark .contact-details p{color:#ccc}html.dark .contact-form-section{background:#2d2e32;border:1px solid #404040}html.dark .contact-form h2{color:#fff}html.dark .form-input,html.dark .form-textarea{background:#1a1a1a;border-color:#404040;color:#fff}html.dark .form-input::placeholder,html.dark .form-textarea::placeholder{color:#888}html.dark .form-input:focus,html.dark .form-textarea:focus{background:#2d2e32;border-color:#147efb}html.dark .resume-download{background:linear-gradient(135deg,#1a1a1a,#2d2e32);border-color:#147efb}html.dark .resume-download h3{color:#fff}html.dark .resume-download p{color:#ccc}@media (max-width: 768px){.contact-container{padding:4rem 1rem}.contact-header h1{font-size:2rem}.contact-content{grid-template-columns:1fr;gap:2rem}.contact-form-section{padding:2rem}.contact-item{padding:1rem;gap:1rem}.contact-icon{width:50px;height:50px;font-size:1.2rem}}@media (max-width: 480px){.contact-header h1{font-size:1.5rem}.contact-form-section{padding:1.5rem}.contact-item{flex-direction:column;text-align:center}}.footer{background:#333;color:#fff;padding:3rem 0 1rem;margin-top:auto}.footer-container{max-width:1200px;margin:0 auto;padding:0 2rem}.footer-content{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:2rem}.footer-info{flex:1}.footer-name{font-size:1.5rem;font-weight:700;margin:0 0 .5rem;color:#fff}.footer-description{font-size:1rem;color:#adb5bd;margin:0;line-height:1.5}.footer-social{display:flex;gap:1rem;align-items:center}.social-link{display:flex;align-items:center;justify-content:center;width:45px;height:45px;background:#ffffff1a;color:#fff;border-radius:50%;font-size:1.2rem;text-decoration:none;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.social-link:hover{background:#666;transform:translateY(-3px);box-shadow:0 8px 20px #0000004d}.footer-bottom{padding-top:2rem;border-top:1px solid rgba(255,255,255,.1);text-align:center}.copyright{font-size:.9rem;color:#adb5bd;margin:0}html.dark .footer{background:#1a1a1a;border-top:1px solid #404040}html.dark .social-link{background:#cccccc1a}html.dark .social-link:hover{background:#ccc;color:#1a1a1a}@media (max-width: 768px){.footer{padding:2rem 0 1rem}.footer-container{padding:0 1.5rem}.footer-content{flex-direction:column;text-align:center;gap:1.5rem}.footer-name{font-size:1.3rem}.footer-description{font-size:.95rem}.footer-social{justify-content:center}}@media (max-width: 480px){.footer-container{padding:0 1rem}.footer-name{font-size:1.2rem}.footer-description{font-size:.9rem}.social-link{width:40px;height:40px;font-size:1.1rem}.copyright{font-size:.85rem}}*{margin:0;padding:0;box-sizing:border-box;font-family:Poppins,sans-serif}.container{min-height:100vh;width:100vw;background:#f4f2f2;transition:.5s}.container.dark{background-color:#222;color:#fff}
