:root{--fondo:#0f172a;--fondo-card:#1e293b;--fondo-input:#1e293b;--borde:#334155;--texto:#e2e8f0;--texto-sub:#94a3b8;--texto-tenue:#64748b;--acento:#38bdf8;--navbar-bg:#0f172af2}[data-tema=claro]{--fondo:#f8fafc;--fondo-card:#fff;--fondo-input:#f1f5f9;--borde:#e2e8f0;--texto:#0f172a;--texto-sub:#475569;--texto-tenue:#94a3b8;--acento:#0284c7;--navbar-bg:#f8fafcf2}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background-color:var(--fondo);color:var(--texto);min-height:100vh;font-family:Segoe UI,system-ui,sans-serif;transition:background-color .3s,color .3s}a{color:inherit;text-decoration:none}.seccion-titulo{text-align:center;margin-bottom:3rem}.seccion-titulo h2{color:var(--texto);margin-bottom:.75rem;font-size:2rem;font-weight:700}.seccion-linea{background-color:var(--acento);border-radius:2px;width:60px;height:4px;margin:0 auto;display:block}.btn-primario{background-color:var(--acento);color:#0f172a;border-radius:8px;padding:.75rem 1.5rem;font-weight:600;transition:opacity .2s;display:inline-block}.btn-primario:hover{opacity:.85}.btn-secundario{border:2px solid var(--acento);color:var(--acento);border-radius:8px;padding:.75rem 1.5rem;font-weight:600;transition:all .2s;display:inline-block}.btn-secundario:hover{background-color:var(--acento);color:#0f172a}.navbar{z-index:100;background-color:var(--navbar-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--fondo-card);justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex;position:fixed;top:0;left:0;right:0}.navbar-logo{color:var(--texto);font-size:1.25rem;font-weight:700}.navbar-logo span{color:var(--acento)}.navbar-links{gap:2rem;list-style:none;display:flex}.navbar-links a{color:var(--texto-sub);font-size:.95rem;transition:color .2s}.navbar-links a:hover{color:var(--acento)}.navbar-hamburger{color:var(--texto);cursor:pointer;background:0 0;border:none;font-size:1.5rem;display:none}.navbar-menu-movil{background-color:var(--fondo);border-bottom:1px solid var(--fondo-card);flex-direction:column;align-items:center;gap:1rem;padding:1rem 0;list-style:none;display:flex;position:absolute;top:100%;left:0;right:0}.navbar-menu-movil a{color:var(--texto-sub);font-size:1rem;transition:color .2s}.navbar-menu-movil a:hover{color:var(--acento)}.navbar-acciones{align-items:center;gap:.75rem;display:flex}.tema-btn{border:2px solid var(--borde);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;font-size:1.1rem;transition:border-color .2s,transform .2s;display:flex}.tema-btn:hover{border-color:var(--acento);transform:rotate(20deg)}.hero{align-items:center;max-width:1100px;min-height:100vh;margin:0 auto;padding:6rem 2rem 4rem;display:flex}.hero-contenido{justify-content:space-between;align-items:center;gap:4rem;width:100%;display:flex}.hero-texto{flex-direction:column;flex:1;gap:1rem;display:flex}.hero-saludo{color:var(--acento);font-size:1.1rem}.hero-nombre{color:var(--texto);font-size:clamp(2rem,4vw,3rem);font-weight:800;line-height:1.2}.hero-titulo{color:var(--texto-sub);font-size:clamp(1rem,2.5vw,1.25rem);font-weight:400}.hero-titulo span{color:var(--acento)}.hero-descripcion{color:var(--texto-tenue);max-width:480px;font-size:1rem;line-height:1.8}.hero-botones{flex-wrap:wrap;gap:1rem;margin-top:.5rem;display:flex}.hero-redes{gap:1.5rem;margin-top:.5rem;display:flex}.hero-redes a{color:#475569;font-size:.9rem;transition:color .2s}.hero-redes a:hover{color:var(--acento)}.hero-foto-contenedor{flex-shrink:0}.hero-foto-anillo{background:linear-gradient(135deg, var(--acento), #0284c7, var(--fondo));border-radius:50%;width:320px;height:320px;padding:4px;box-shadow:0 0 40px #38bdf84d,0 0 80px #38bdf81a}.hero-foto{object-fit:cover;object-position:top;border:4px solid var(--fondo);border-radius:50%;width:100%;height:100%}@media (width<=768px){.hero-contenido{text-align:center;flex-direction:column-reverse}.hero-foto-anillo{width:220px;height:220px}.hero-botones,.hero-redes{justify-content:center}.hero-descripcion{max-width:100%}}.about{max-width:900px;margin:0 auto;padding:6rem 2rem}.about-contenido{align-items:flex-start;gap:3rem;display:flex}.about-avatar{background:linear-gradient(135deg, var(--acento), #0284c7);width:120px;min-width:120px;height:120px;color:var(--fondo);border-radius:50%;justify-content:center;align-items:center;font-size:2rem;font-weight:700;display:flex}.about-texto{flex-direction:column;gap:1rem;display:flex}.about-texto p{color:var(--texto-sub);line-height:1.8}.about-texto strong{color:var(--texto)}.about-datos{flex-direction:column;gap:.6rem;margin-top:.5rem;display:flex}.about-dato{color:var(--texto-sub);align-items:center;gap:.75rem;font-size:.95rem;display:flex}.dato-icono{font-size:1.1rem}.projects{max-width:900px;margin:0 auto;padding:6rem 2rem}.projects-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;display:grid}.project-card{background-color:var(--fondo-card);border:1px solid var(--borde);border-radius:16px;flex-direction:column;gap:1rem;padding:1.5rem;transition:border-color .2s,transform .2s;display:flex}.project-card:hover{border-color:var(--acento);transform:translateY(-4px)}.project-card-header{align-items:center;gap:.75rem;display:flex}.project-icono{font-size:1.5rem}.project-card-header h3{color:var(--texto);font-size:1.1rem}.project-descripcion{color:var(--texto-sub);flex:1;font-size:.95rem;line-height:1.7}.project-tecnologias{flex-wrap:wrap;gap:.5rem;display:flex}.project-tag{background-color:var(--fondo);border:1px solid var(--acento);color:var(--acento);border-radius:20px;padding:.25rem .75rem;font-size:.8rem}.project-links{flex-wrap:wrap;gap:.75rem;display:flex}.skills{max-width:900px;margin:0 auto;padding:6rem 2rem}.skills-instruccion{text-align:center;color:var(--texto-tenue);margin-bottom:2rem;font-size:.95rem}.skills-cards-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:3rem;display:grid}.skill-card-contenedor{cursor:pointer;perspective:1000px;height:180px}.skill-card-inner{width:100%;height:100%;transform-style:preserve-3d;transition:transform .6s;position:relative}.skill-card-inner.volteada{transform:rotateY(180deg)}.skill-card-frente,.skill-card-reverso{border:1px solid var(--borde);backface-visibility:hidden;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;width:100%;height:100%;padding:1.25rem;display:flex;position:absolute}.skill-card-frente{background-color:var(--fondo-card);transition:border-color .2s}.skill-card-contenedor:hover .skill-card-frente{border-color:var(--acento)}.skill-card-emoji{font-size:2.2rem}.skill-card-nombre{color:var(--texto);font-size:1.1rem;font-weight:600}.skill-card-hint{color:#475569;font-size:.75rem}.skill-card-reverso{background:linear-gradient(135deg, var(--fondo), var(--fondo-card));border-color:var(--acento);gap:.4rem;transform:rotateY(180deg)}.skill-card-nivel-num{color:var(--acento);font-size:2rem;font-weight:800}.skill-card-nivel-texto{color:var(--texto-sub);text-transform:uppercase;letter-spacing:1px;font-size:.85rem}.skill-card-barra-fondo{background-color:var(--borde);border-radius:3px;width:80%;height:6px;margin:.25rem 0;overflow:hidden}.skill-card-barra-progreso{background:linear-gradient(90deg, #0284c7, var(--acento));border-radius:3px;height:100%}.skill-card-descripcion{color:var(--texto-tenue);text-align:center;font-size:.8rem;line-height:1.5}.skills-aprendiendo{text-align:center}.skills-aprendiendo p{color:var(--texto-tenue);margin-bottom:1rem}.skills-tags{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.skill-tag-aprendiendo{color:var(--texto-tenue);border:1px dashed #475569;border-radius:20px;padding:.4rem 1rem;font-size:.85rem}@media (width<=768px){.skills-cards-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=480px){.skills-cards-grid{grid-template-columns:1fr}}.contact{max-width:700px;margin:0 auto;padding:6rem 2rem}.contact-mensaje{text-align:center;color:var(--texto-sub);margin-bottom:3rem;font-size:1.05rem;line-height:1.8}.contact-grid{flex-direction:column;gap:1rem;display:flex}.contact-card{background-color:var(--fondo-card);border:1px solid var(--borde);border-radius:12px;align-items:center;gap:1rem;padding:1.25rem 1.5rem;transition:border-color .2s,transform .2s;display:flex}.contact-card:hover{border-color:var(--acento);transform:translate(6px)}.contact-icono{font-size:1.75rem}.contact-titulo{color:var(--texto-tenue);margin-bottom:.2rem;font-size:.85rem}.contact-valor{color:var(--texto);word-break:break-all;font-weight:500}.footer{text-align:center;border-top:1px solid var(--fondo-card);color:#475569;flex-direction:column;gap:.5rem;padding:2rem;font-size:.9rem;display:flex}.footer strong{color:var(--texto-sub)}@media (width<=768px){.navbar-links{display:none}.navbar-hamburger{display:block}.about-contenido{text-align:center;flex-direction:column;align-items:center}.hero-botones{flex-direction:column;align-items:center}}.projects-filtros{flex-wrap:wrap;justify-content:center;gap:.75rem;margin-bottom:2rem;display:flex}.filtro-btn{border:2px solid var(--borde);color:var(--texto-sub);cursor:pointer;background-color:#0000;border-radius:20px;padding:.5rem 1.25rem;font-size:.9rem;transition:all .2s}.filtro-btn:hover{border-color:var(--acento);color:var(--acento)}.filtro-btn.activo{background-color:var(--acento);border-color:var(--acento);color:var(--fondo);font-weight:600}.modal-overlay{z-index:200;background-color:#000000bf;justify-content:center;align-items:center;padding:1rem;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-contenido{background-color:var(--fondo-card);border:1px solid var(--borde);border-radius:20px;flex-direction:column;align-items:center;gap:1rem;width:100%;max-width:500px;padding:2rem;animation:.3s slideUp;display:flex;position:relative}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-cerrar{border:1px solid var(--borde);color:var(--texto-sub);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.85rem;transition:all .2s;display:flex;position:absolute;top:1rem;right:1rem}.modal-cerrar:hover{border-color:var(--acento);color:var(--acento)}.modal-foto-contenedor{background:linear-gradient(135deg, var(--acento), #0284c7);border-radius:50%;width:120px;height:120px;padding:3px;box-shadow:0 0 25px #38bdf84d}.modal-foto{object-fit:cover;object-position:top;border:3px solid var(--fondo-card);border-radius:50%;width:100%;height:100%}.modal-info{text-align:center;flex-direction:column;align-items:center;gap:.5rem;display:flex}.modal-nombre{color:var(--texto);font-size:1.4rem;font-weight:700}.modal-titulo{color:var(--acento);font-size:1rem;font-weight:600}.modal-subtitulo{color:var(--texto-sub);font-size:.9rem}.modal-descripcion{color:var(--texto-tenue);max-width:380px;margin-top:.25rem;font-size:.9rem;line-height:1.7}.modal-redes{flex-wrap:wrap;justify-content:center;gap:.75rem;margin-top:.5rem;display:flex}.modal-red{border:1px solid var(--borde);color:var(--texto-sub);border-radius:20px;padding:.4rem 1rem;font-size:.85rem;transition:all .2s}.modal-red:hover{border-color:var(--acento);color:var(--acento)}.modal-cv-btn{background-color:var(--acento);color:#0f172a;border-radius:10px;margin-top:.5rem;padding:.75rem 2rem;font-size:.95rem;font-weight:700;transition:opacity .2s}.modal-cv-btn:hover{opacity:.85}.hero-foto-hint{text-align:center;color:var(--texto-tenue);margin-top:.75rem;font-size:.8rem}
