body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}*{box-sizing:border-box;margin:0;padding:0}.app{background:linear-gradient(135deg,#39457c 0%,#6b4492 100%);min-height:100vh;font-family:Segoe UI,Roboto,Oxygen,sans-serif;display:flex}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:#ffffff1a;border-radius:10px}::-webkit-scrollbar-thumb{background:#8b5cf699;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#8b5cf6cc}@media (width<=768px){.app{flex-direction:column}}.menu{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#1a1a2e 0%,#16213e 100%);flex-direction:column;width:300px;padding:2rem 1.5rem;display:flex;position:relative;box-shadow:8px 0 20px #0000004d,inset -1px 0 #ffffff0d}.logo-container{justify-content:center;margin-bottom:4rem;display:flex}.logo-3d{perspective:500px;cursor:pointer}.logo-inner{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:30px;justify-content:center;align-items:center;width:120px;height:120px;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;position:relative;transform:rotateX(10deg)rotateY(-10deg)rotate(5deg);box-shadow:0 20px 30px -10px #0006,inset 0 -5px #0003,inset 0 2px 10px #ffffff4d}.logo-inner:hover{transform:rotateX(5deg)rotateY(-5deg)rotate(2deg)translateY(-5px);box-shadow:0 30px 40px -15px #00000080}.logo-text{color:#fff;text-shadow:2px 2px 4px #0000004d;letter-spacing:2px;font-size:2.8rem;font-weight:700}.logo-sparkle{color:gold;animation:2s ease-in-out infinite sparkle;position:absolute;top:-10px;right:-10px}@keyframes sparkle{0%,to{opacity:.7;transform:scale(1)rotate(0)}50%{opacity:1;transform:scale(1.2)rotate(15deg)}}.nav-buttons{flex-direction:column;flex:1;gap:1.2rem;display:flex}.nav-button-3d{cursor:pointer;perspective:500px;background:0 0;border:none;min-height:56px;padding:0;position:relative}.button-front{transform-style:preserve-3d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#b1b1b1;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:16px;align-items:center;gap:14px;padding:14px 20px;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden;transform:translateZ(0)}.button-front:before{content:"";background:linear-gradient(90deg,#0000,#fff3,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.nav-button-3d:hover .button-front:before{left:100%}.button-icon{z-index:1;flex-shrink:0;transition:transform .3s}.button-front span{letter-spacing:.5px;z-index:1;font-size:1rem;font-weight:600;position:relative}.button-glow{opacity:0;pointer-events:none;background:radial-gradient(circle,#ffffff1a,#0000);transition:opacity .3s;position:absolute;inset:0}.nav-button-3d:hover .button-glow{opacity:1}.button-back{z-index:-1;filter:blur(2px);background:#0003;border-radius:16px;transition:all .25s;position:absolute;inset:4px 0 -4px}.nav-button-3d:hover{transform:translateY(-2px)}.nav-button-3d:hover .button-back{filter:blur(4px);background:#0000004d;transform:translateY(2px)}.nav-button-3d:active{transform:translateY(2px)}.nav-button-3d:active .button-back{transform:translateY(-1px)}.nav-button-3d.gradient-1 .button-front{background:linear-gradient(135deg,#667eea33,#764ba233)}.nav-button-3d.gradient-2 .button-front{background:linear-gradient(135deg,#f5576c33,#ff8a6533)}.nav-button-3d.gradient-3 .button-front{background:linear-gradient(135deg,#4cc9f033,#00acc133)}.nav-button-3d.gradient-4 .button-front{background:linear-gradient(135deg,#667eea33,#764ba233)}.nav-button-3d.active .button-front{background:linear-gradient(135deg,#667eeae6,#764ba2e6);border:1px solid #ffffff4d;box-shadow:0 8px 20px #667eea4d,inset 0 1px #fff3}.nav-button-3d.active .button-icon{filter:drop-shadow(0 0 5px #ffffff80);transform:scale(1.1)}.nav-button-3d.active .button-front span{text-shadow:0 0 8px #ffffff80}.nav-button-3d.active .button-back{filter:blur(6px);background:#667eea66}.nav-button-3d.active:hover .button-front{transform:translateY(-2px);box-shadow:0 12px 30px #667eea66}.menu-footer{border-top:1px solid #ffffff1a;margin-top:auto;padding-top:2rem}.tech-stack{color:#ffffff80;background:#ffffff08;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:10px;font-size:.8rem;transition:all .3s;display:flex}.tech-stack:hover{color:#fffc;background:#ffffff14}@keyframes slideIn{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}.nav-button-3d{opacity:0;animation:.5s forwards slideIn}.nav-button-3d:first-child{animation-delay:.1s}.nav-button-3d:nth-child(2){animation-delay:.2s}.nav-button-3d:nth-child(3){animation-delay:.3s}@media (width<=768px){.menu{width:100%;padding:1rem}.nav-buttons{flex-direction:row;gap:.8rem}.nav-button-3d{flex:1}.button-front{justify-content:center}.logo-container{margin-bottom:2rem}.logo-inner{width:80px;height:80px}.logo-text{font-size:2rem}}.logo-image{object-fit:cover;border-radius:30px;width:100%;height:100%;transition:transform .3s}.logo-inner:hover .logo-image{transform:scale(1.05)}.logo-inner:after{content:"";pointer-events:none;background:linear-gradient(135deg,#667eea33,#764ba233);border-radius:30px;position:absolute;inset:0}.perfil-container{background:#2d2d2d;border-radius:24px;width:fit-content;min-width:300px;max-width:1200px;margin:0 auto;padding:2rem;box-shadow:0 20px 40px #0003}.perfil-row{grid-template-columns:1fr 1fr;align-items:stretch;gap:3rem;display:grid}.perfil-col{flex-direction:column;justify-content:center;display:flex}.izquierda{gap:1.5rem}.derecha{align-items:center;gap:1.5rem}.sobre-mi{background:#3a3a3a;border-radius:20px;padding:2rem;box-shadow:0 5px 15px #0003}.seccion-titulo{color:#fff;margin-bottom:1.5rem;font-size:2rem;display:inline-block;position:relative}.descripcion p{color:#e0e0e0;text-align:justify;margin-bottom:1rem;font-size:1rem;line-height:1.8}.foto-wrapper{justify-content:center;width:100%;display:flex}.foto-circulo{background:linear-gradient(135deg,#8b5cf6,#6d28d9);border-radius:50%;width:200px;height:200px;padding:4px;animation:2s ease-in-out infinite pulse;position:relative}@keyframes pulse{0%,to{box-shadow:0 0 #8b5cf666}50%{box-shadow:0 0 0 15px #8b5cf600}}.foto-perfil{object-fit:cover;border:3px solid #fff;border-radius:50%;width:100%;height:100%;transition:transform .3s}.foto-circulo:hover .foto-perfil{transform:scale(1.05)}.foto-glow{opacity:0;pointer-events:none;background:radial-gradient(circle,#8b5cf64d,#0000);border-radius:50%;transition:opacity .3s;position:absolute;inset:-10px}.foto-circulo:hover .foto-glow{opacity:1}.info-personal{text-align:center;width:100%}.nombre{color:#fff;letter-spacing:-.5px;margin:0 0 .5rem;font-size:1.8rem;font-weight:700}.profesion{color:#c4b5fd;margin:0;font-size:1rem;font-weight:500}.contactos{background:#3a3a3a;border-radius:20px;width:100%;padding:1.5rem;box-shadow:0 5px 15px #0003}.contactos-titulo{color:#fff;text-align:center;margin-bottom:1.5rem;font-size:1.5rem;position:relative}.contactos-titulo:after{content:"";background:linear-gradient(90deg,#8b5cf6,#6d28d9);border-radius:2px;width:50px;height:3px;position:absolute;bottom:-8px;left:50%;transform:translate(-50%)}.contactos-lista{flex-direction:column;gap:1rem;display:flex}.contacto-item{cursor:pointer;background:#2d2d2d;border:1px solid #4a4a4a;border-radius:12px;align-items:center;gap:1rem;padding:1rem;text-decoration:none;transition:all .3s;display:flex}.contacto-item:hover{border-color:var(--hover-color);transform:translate(10px);box-shadow:0 5px 15px #0000004d}.contacto-icon{color:#e0e0e0;background:#3a3a3a;border-radius:12px;justify-content:center;align-items:center;width:45px;height:45px;transition:all .3s;display:flex}.contacto-item:hover .contacto-icon{background:var(--hover-color);color:#fff;transform:scale(1.05)}.contacto-item:hover .contacto-icon svg{color:#fff}.contacto-info{flex-direction:column;flex:1;gap:4px;display:flex}.contacto-label{text-transform:uppercase;letter-spacing:1px;color:#a0a0a0;font-size:.75rem;font-weight:600}.contacto-valor{color:#e0e0e0;font-size:.9rem;font-weight:500}@media (width<=968px){.perfil-row{grid-template-columns:1fr;gap:2rem}.perfil-container{width:auto;padding:1.5rem}.derecha{order:-1}.foto-circulo{width:160px;height:160px}.nombre{font-size:1.5rem}}@media (width<=768px){.perfil-container{padding:1rem}.sobre-mi{padding:1.5rem}.seccion-titulo{font-size:1.5rem}.descripcion p{font-size:.9rem}.contactos{padding:1rem}.contacto-item{padding:.8rem}.contacto-icon{width:40px;height:40px}.contacto-valor{font-size:.85rem}.nombre{font-size:1.3rem}.profesion{font-size:.9rem}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.perfil-container,.sobre-mi{animation:.6s ease-out fadeInUp}.derecha>*{animation:.6s ease-out both fadeInUp}.foto-wrapper{animation-delay:.1s}.info-personal{animation-delay:.15s}.contactos{animation-delay:.2s}.habilidades-container{background:#2d2d2d;border-radius:24px;width:fit-content;min-width:300px;max-width:1200px;margin:0 auto;padding:2rem;box-shadow:0 20px 40px #0003}.habilidades-row{grid-template-columns:1fr 1fr;align-items:start;gap:3rem;display:grid}.habilidades-col{flex-direction:column;gap:1.5rem;display:flex}.hard-skills{background:#3a3a3a;border-radius:20px;padding:2rem;box-shadow:0 5px 15px #0003}.seccion-titulo{color:#fff;align-items:center;gap:12px;margin-bottom:1.5rem;font-size:1.8rem;display:inline-block;position:relative}.seccion-titulo svg{vertical-align:middle;margin-right:8px;display:inline-block}.categoria-skills{margin-bottom:2rem}.categoria-skills:last-child{margin-bottom:0}.categoria-header{border-bottom:1px solid #4a4a4a;align-items:center;gap:10px;margin-bottom:1rem;padding-bottom:.5rem;display:flex}.categoria-header svg{color:#8b5cf6}.categoria-header h3{color:#c4b5fd;margin:0;font-size:1.1rem;font-weight:600}.tech-grid{grid-template-columns:repeat(3,1fr);gap:.8rem;display:grid}.tech-item{color:#e0e0e0;background:#2d2d2d;border:1px solid #4a4a4a;border-radius:8px;align-items:center;gap:8px;padding:8px 12px;font-size:.85rem;transition:all .3s;display:flex}.tech-item:hover{background:#8b5cf61a;border-color:#8b5cf6;transform:translate(5px)}.tech-item svg{color:#8b5cf6;flex-shrink:0}.soft-skills{background:#3a3a3a;border-radius:20px;padding:2rem;box-shadow:0 5px 15px #0003}.soft-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;display:grid}.soft-item{color:#e0e0e0;background:#2d2d2d;border:1px solid #4a4a4a;border-radius:10px;align-items:center;gap:10px;padding:10px 15px;font-size:.9rem;transition:all .3s;display:flex}.soft-item:hover{background:#8b5cf61a;border-color:#8b5cf6;transform:translate(5px)}.soft-dot{color:#8b5cf6;font-size:1.2rem;font-weight:700}.idiomas{background:#3a3a3a;border-radius:20px;padding:2rem;box-shadow:0 5px 15px #0003}.idiomas-lista{flex-direction:column;gap:1rem;display:flex}.idioma-item{background:#2d2d2d;border:1px solid #4a4a4a;border-radius:12px;align-items:center;gap:15px;padding:15px;transition:all .3s;display:flex}.idioma-item:hover{background:#8b5cf61a;border-color:#8b5cf6;transform:translate(5px)}.idioma-bandera{font-size:2rem}.idioma-info{flex-direction:column;gap:4px;display:flex}.idioma-nombre{color:#fff;font-size:1.1rem;font-weight:600}.idioma-nivel{color:#c4b5fd;font-size:.85rem}@media (width<=968px){.habilidades-row{grid-template-columns:1fr;gap:2rem}.habilidades-container{width:auto;padding:1.5rem}.tech-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}@media (width<=768px){.habilidades-container{padding:1rem}.hard-skills,.soft-skills,.idiomas{padding:1.5rem}.seccion-titulo{font-size:1.5rem}.categoria-header h3{font-size:1rem}.tech-grid,.soft-grid{grid-template-columns:1fr}.tech-item,.soft-item{font-size:.85rem}}.habilidades-container{animation:.6s ease-out fadeInUp}.hard-skills,.soft-skills,.idiomas{animation:.6s ease-out both fadeInUp}.hard-skills{animation-delay:.1s}.soft-skills{animation-delay:.15s}.idiomas{animation-delay:.2s}@media (width<=768px){.tech-grid{grid-template-columns:1fr}}@media (width<=968px) and (width>=769px){.tech-grid{grid-template-columns:repeat(2,1fr)}}.experiencias-container{background:#2d2d2d;border-radius:24px;width:fit-content;min-width:300px;max-width:1000px;margin:0 auto;padding:2rem;box-shadow:0 20px 40px #0003}.experiencias-content{width:100%}.timeline-navegacion{background:#3a3a3a;border:1px solid #4a4a4a;border-radius:20px;margin-bottom:2rem;padding:1.5rem;position:relative;overflow-x:auto}.timeline-linea{background:linear-gradient(90deg,#8b5cf6,#6d28d9,#8b5cf6);border-radius:2px;height:3px;position:absolute;top:50%;left:2rem;right:2rem;transform:translateY(-50%)}.timeline-puntos{justify-content:space-between;align-items:center;gap:1rem;min-width:max-content;display:flex;position:relative}.timeline-item{cursor:pointer;z-index:2;flex-direction:column;align-items:center;transition:all .3s;display:flex;position:relative}.timeline-item:hover{transform:translateY(-5px)}.timeline-punto{background:#2d2d2d;border:2px solid #8b5cf6;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:all .3s;display:flex;box-shadow:0 0 #8b5cf666}.timeline-item:hover .timeline-punto{background:#8b5cf6;transform:scale(1.1);box-shadow:0 0 0 8px #8b5cf633}.punto-interior{background:#8b5cf6;border-radius:50%;width:12px;height:12px;transition:all .3s}.timeline-item:hover .punto-interior{background:#fff}.timeline-etiqueta{text-align:center;flex-direction:column;gap:4px;margin-top:12px;display:flex}.empresa-timeline{color:#fff;white-space:nowrap;background:#4a4a4a;border-radius:12px;padding:4px 10px;font-size:.85rem;font-weight:600;transition:all .3s}.timeline-item:hover .empresa-timeline{background:#8b5cf6;transform:scale(1.05)}.periodo-timeline{color:#a0a0a0;white-space:nowrap;font-size:.7rem}.timeline-navegacion::-webkit-scrollbar{height:6px}.timeline-navegacion::-webkit-scrollbar-track{background:#3a3a3a;border-radius:3px}.timeline-navegacion::-webkit-scrollbar-thumb{background:#8b5cf6;border-radius:3px}.timeline-navegacion::-webkit-scrollbar-thumb:hover{background:#6d28d9}.experiencias-lista{flex-direction:column;gap:1.8rem;display:flex}.experiencia-card{background:#3a3a3a;border:1px solid #4a4a4a;border-radius:20px;scroll-margin-top:100px;transition:all .3s;overflow:hidden}.experiencia-card:hover{border-color:#8b5cf6;transform:translateY(-5px);box-shadow:0 10px 25px #8b5cf633}.experiencia-card:target{animation:1s ease-out highlight}@keyframes highlight{0%{border-color:#8b5cf6;box-shadow:0 0 0 4px #8b5cf64d}to{box-shadow:none;border-color:#4a4a4a}}.experiencia-header{background:#0003;border-bottom:1px solid #4a4a4a;gap:1.5rem;padding:1.5rem;display:flex}.empresa-logo{background:#2d2d2d;border:1px solid #4a4a4a;border-radius:12px;justify-content:center;align-items:center;width:70px;height:70px;padding:4px;display:flex}.empresa-logo img{object-fit:contain;width:100%;height:100%}.empresa-info{flex:1}.empresa-cargo{color:#c4b5fd;margin:0 0 .8rem;font-size:1rem;font-weight:500}.empresa-detalles{flex-wrap:wrap;gap:1.5rem;display:flex}.detalle{color:#a0a0a0;align-items:center;gap:6px;font-size:.85rem;display:flex}.detalle svg{color:#8b5cf6}.experiencia-body{padding:1.5rem}.logros-lista{margin:0;padding:0;list-style:none}.logros-lista li{color:#e0e0e0;gap:12px;margin-bottom:1rem;font-size:.95rem;line-height:1.6;display:flex}.logros-lista li:last-child{margin-bottom:0}.logros-lista li svg{color:#8b5cf6;flex-shrink:0;margin-top:3px}.logros-lista li span{flex:1}@media (width<=768px){.experiencias-container{padding:1rem}.seccion-titulo{font-size:1.5rem}.timeline-navegacion{padding:1rem}.timeline-punto{width:32px;height:32px}.punto-interior{width:8px;height:8px}.empresa-timeline{padding:2px 8px;font-size:.7rem}.periodo-timeline{font-size:.6rem}.experiencia-header{text-align:center;flex-direction:column;align-items:center}.empresa-logo{width:50px;height:50px}.empresa-nombre{font-size:1.1rem}.empresa-cargo{font-size:.9rem}.empresa-detalles{justify-content:center}.experiencia-body{padding:1rem}.logros-lista li{font-size:.85rem}}.experiencias-container{animation:.6s ease-out fadeInUp}.experiencia-card{animation:.6s ease-out both fadeInUp}.experiencia-card:first-child{animation-delay:.1s}.experiencia-card:nth-child(2){animation-delay:.2s}.experiencia-card:nth-child(3){animation-delay:.3s}.experiencia-card:nth-child(4){animation-delay:.4s}.experiencia-card:nth-child(5){animation-delay:.5s}.experiencia-card:nth-child(6){animation-delay:.6s}.empresa-header-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.5rem;display:flex}.empresa-nombre{color:#fff;margin:0;font-size:1.3rem;font-weight:700}.btn-volver-timeline{color:#c4b5fd;cursor:pointer;background:#8b5cf633;border:1px solid #8b5cf6;border-radius:20px;align-items:center;gap:8px;padding:6px 14px;font-size:.8rem;font-weight:500;transition:all .3s;display:flex}.btn-volver-timeline:hover{color:#fff;background:#8b5cf6;transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf64d}.btn-volver-timeline svg{transition:transform .3s}.btn-volver-timeline:hover svg{transform:rotate(-90deg)}@media (width<=768px){.empresa-header-row{flex-direction:column;align-items:flex-start}.btn-volver-timeline{align-self:flex-start}}.proyectos-container{background:#2d2d2d;border-radius:24px;min-width:300px;max-width:1200px;margin:0 auto;padding:2rem;box-shadow:0 20px 40px #0003}.proyectos-content{width:100%}.seccion-titulo{color:#fff;align-items:center;gap:12px;margin-bottom:2rem;padding-bottom:12px;font-size:2rem;display:flex;position:relative}.seccion-titulo:after{content:"";background:linear-gradient(90deg,#8b5cf6,#6d28d9);border-radius:2px;width:60px;height:4px;position:absolute;bottom:0;left:0}.proyectos-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem;animation:.6s ease-out fadeInUp;display:grid}.proyecto-card{cursor:pointer;background:#3a3a3a;border:1px solid #4a4a4a;border-radius:20px;transition:all .3s;animation:.6s ease-out both fadeInUp;overflow:hidden}.proyecto-card:hover{border-color:#8b5cf6;transform:translateY(-8px);box-shadow:0 15px 30px #8b5cf633}.proyecto-imagen-container{height:200px;position:relative;overflow:hidden}.proyecto-imagen{object-fit:cover;width:100%;height:100%;transition:transform .5s}.proyecto-card:hover .proyecto-imagen{transform:scale(1.1)}.proyecto-overlay{opacity:0;background:#8b5cf6e6;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:absolute;inset:0}.proyecto-card:hover .proyecto-overlay{opacity:1}.ver-detalle{color:#fff;border:2px solid #fff;border-radius:30px;padding:8px 16px;font-size:1rem;font-weight:600;transition:all .3s}.proyecto-card:hover .ver-detalle{transform:scale(1.05)}.proyecto-info{padding:1.5rem}.proyecto-nombre{color:#fff;margin:0 0 .75rem;font-size:1.3rem;font-weight:700}.proyecto-descripcion{color:silver;margin:0 0 1rem;font-size:.9rem;line-height:1.5}.proyecto-categoria{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.categoria-badge{color:#c4b5fd;white-space:nowrap;background:#8b5cf633;border:1px solid #8b5cf6;border-radius:20px;padding:4px 12px;font-size:.75rem;font-weight:500;transition:all .3s}.categoria-badge:hover{color:#fff;background:#8b5cf6;transform:translateY(-2px)}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#000000d9;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.modal-container{background:#2d2d2d;border:1px solid #4a4a4a;border-radius:24px;width:90%;max-width:900px;max-height:85vh;animation:.3s slideUp;position:relative;overflow-y:auto;box-shadow:0 25px 50px #00000080}.modal-container::-webkit-scrollbar{width:8px}.modal-container::-webkit-scrollbar-track{background:#3a3a3a;border-radius:4px}.modal-container::-webkit-scrollbar-thumb{background:#8b5cf6;border-radius:4px}.modal-btn-volver{color:#fff;cursor:pointer;z-index:10;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#8b5cf6e6;border:none;border-radius:30px;align-items:center;gap:8px;width:fit-content;margin:20px;padding:10px 20px;font-size:.9rem;font-weight:500;transition:all .3s;display:flex;position:sticky;top:20px;left:20px}.modal-btn-volver:hover{background:#6d28d9;transform:translate(-5px);box-shadow:0 4px 12px #8b5cf666}.modal-close{float:right;color:#fff;cursor:pointer;background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;margin:20px;padding:8px;transition:all .3s;display:flex;position:sticky;top:20px;right:20px}.modal-close:hover{background:#fff3;transform:rotate(90deg)}.modal-content{clear:both;padding:0 2rem 2rem}.modal-imagen-section{border-radius:16px;width:100%;margin-bottom:1.5rem;overflow:hidden}.modal-imagen{object-fit:cover;border-radius:16px;width:100%;max-height:300px}.modal-info{color:#e0e0e0}.modal-titulo{color:#fff;background:linear-gradient(135deg,#fff,#c4b5fd);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 1rem;font-size:2rem}.modal-descripcion{color:#d0d0d0;margin-bottom:1.5rem;font-size:1rem;line-height:1.6}.modal-metadatos{background:#3a3a3a;border-radius:12px;flex-wrap:wrap;gap:1.5rem;margin-bottom:1.5rem;padding:1rem;display:flex}.meta-item{color:#c4b5fd;align-items:center;gap:8px;font-size:.9rem;display:flex}.meta-item svg{color:#8b5cf6}.modal-tecnologias,.modal-objetivos,.modal-resultados{margin-bottom:2rem}.modal-tecnologias h4,.modal-objetivos h4,.modal-resultados h4{color:#fff;border-bottom:2px solid #4a4a4a;align-items:center;gap:8px;margin:0 0 1rem;padding-bottom:8px;font-size:1.1rem;display:flex}.modal-tecnologias h4 svg,.modal-objetivos h4 svg,.modal-resultados h4 svg{color:#8b5cf6}.tecnologias-lista{flex-wrap:wrap;gap:10px;display:flex}.tecnologia-badge{color:#c4b5fd;background:#8b5cf633;border:1px solid #8b5cf6;border-radius:20px;padding:6px 14px;font-size:.85rem;font-weight:500;transition:all .3s}.tecnologia-badge:hover{color:#fff;background:#8b5cf6;transform:translateY(-2px)}.modal-objetivos ul,.modal-resultados ul{margin:0;padding:0;list-style:none}.modal-objetivos li,.modal-resultados li{color:#e0e0e0;gap:12px;margin-bottom:.75rem;font-size:.9rem;line-height:1.5;display:flex}.modal-objetivos li svg,.modal-resultados li svg{color:#8b5cf6;flex-shrink:0;margin-top:3px}.modal-categorias{margin-bottom:1.5rem}.modal-categorias h4{color:#fff;align-items:center;gap:8px;margin:0 0 .75rem;font-size:1rem;display:flex}.categorias-lista{flex-wrap:wrap;gap:10px;display:flex}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}@media (width<=768px){.proyectos-container{padding:1rem}.seccion-titulo{font-size:1.5rem}.proyectos-grid{grid-template-columns:1fr;gap:1.5rem}.proyecto-nombre{font-size:1.1rem}.proyecto-descripcion{font-size:.85rem}.modal-container{width:95%;max-height:90vh}.modal-content{padding:0 1rem 1rem}.modal-titulo{font-size:1.5rem}.modal-btn-volver{padding:6px 14px;font-size:.8rem;top:10px;left:10px}.modal-close{top:10px;right:10px}.modal-metadatos{flex-direction:column;gap:.75rem}}.modal-galera{background:#1a1a1a;border-radius:16px;width:100%;margin-bottom:1.5rem;overflow:hidden}.galeria-principal{background:#1a1a1a;justify-content:center;align-items:center;min-height:400px;display:flex;position:relative}.galeria-imagen{object-fit:contain;border-radius:8px;width:100%;max-height:400px}.galeria-nav{color:#fff;cursor:pointer;z-index:10;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:all .3s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.galeria-nav:hover:not(:disabled){background:#8b5cf6;transform:translateY(-50%)scale(1.1)}.galeria-nav:disabled{opacity:.3;cursor:not-allowed}.galeria-prev{left:16px}.galeria-next{right:16px}.galeria-miniaturas{background:#2d2d2d;border-top:1px solid #4a4a4a;gap:10px;padding:1rem;display:flex;overflow-x:auto}.galeria-miniaturas::-webkit-scrollbar{height:6px}.galeria-miniaturas::-webkit-scrollbar-track{background:#3a3a3a;border-radius:3px}.galeria-miniaturas::-webkit-scrollbar-thumb{background:#8b5cf6;border-radius:3px}.miniatura{cursor:pointer;border:2px solid #0000;border-radius:8px;flex-shrink:0;width:80px;height:60px;transition:all .3s;overflow:hidden}.miniatura:hover{transform:translateY(-2px)}.miniatura.activa{border-color:#8b5cf6;box-shadow:0 0 0 2px #8b5cf64d}.miniatura img{object-fit:cover;width:100%;height:100%}@media (width<=768px){.galeria-principal{min-height:250px}.galeria-imagen{max-height:250px}.galeria-nav{width:32px;height:32px}.miniatura{width:60px;height:45px}}.proyecto-descripcion strong,.modal-descripcion strong{color:#bf94f1;background:linear-gradient(120deg,#3b82f61a 0%,#8b5cf61a 100%);border-radius:4px;padding:0 4px;font-weight:700;display:inline-block}.contenido-principal{flex:1;padding:2.5rem;animation:.5s fadeIn;overflow-y:auto}.language-switcher{z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#2d2d2de6;border:1px solid #8b5cf64d;border-radius:40px;padding:4px;position:fixed;top:20px;right:20px;box-shadow:0 4px 15px #0000004d}.lang-option:hover{color:#c4b5fd;background:#8b5cf61a}.lang-flag{font-size:1.2rem}@media (width<=768px){.language-switcher{top:10px;right:10px}.lang-option{padding:6px 12px}.lang-text{display:none}.lang-option{gap:0}.lang-flag{font-size:1rem}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.language-switcher{z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#2d2d2de6;border:1px solid #8b5cf64d;border-radius:40px;padding:4px;animation:.3s slideDown;position:fixed;top:20px;right:20px;box-shadow:0 4px 15px #0000004d}.switch-container{gap:4px;display:flex}.lang-option{cursor:pointer;color:#a0a0a0;background:0 0;border:none;border-radius:32px;align-items:center;gap:8px;padding:8px 16px;font-size:.9rem;font-weight:600;transition:all .3s;display:flex}.lang-option:hover{color:#c4b5fd;background:#8b5cf61a;transform:translateY(-2px)}.lang-option.active{color:#fff;background:linear-gradient(135deg,#667eea4d,#764ba24d);box-shadow:0 2px 8px #8b5cf633}.lang-flag{filter:drop-shadow(0 1px 2px #0003);font-size:1.3rem;transition:transform .3s}.lang-flag-img{object-fit:cover;border-radius:4px;width:24px;height:18px;transition:transform .3s;box-shadow:0 1px 3px #0003}.lang-option:hover .lang-flag,.lang-option:hover .lang-flag-img{transform:scale(1.1)}.lang-text{font-size:.85rem;font-weight:500}.lang-option:active{transform:scale(.95)}@media (width<=768px){.language-switcher{top:10px;right:10px}.lang-option{padding:6px 12px}.lang-text{display:none}.lang-option{gap:0}.lang-flag{font-size:1.2rem}.lang-flag-img{width:20px;height:15px}}.language-switcher{animation:.3s slideDown}
