:root{--menu-bg: rgba(0, 0, 0, .5);--menu-border: .1rem solid rgba(86, 86, 86, .5);--menu-link: #ffffff;--menu-link-hover: #c90c0f;--color-acento: #c90c0f;--nav-h: 50px}.nav-scope{position:fixed;top:0;left:0;width:100%;z-index:1000;box-shadow:0 2px 8px #0000004d}.nav-scope .menu{margin:0;padding:.5rem;background:var(--menu-bg);border-top:var(--menu-border);border-bottom:var(--menu-border);display:grid;grid-template-columns:10% auto 10%;align-items:center;min-height:var(--nav-h);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.nav-scope .menu .foto{width:100%;height:100%;display:flex;align-items:center;text-align:center}.nav-scope .menu .foto img{width:2.5rem;border-radius:50%;margin-right:1.25rem}.nav-scope .menu .contenedor-menu{width:100%;display:flex;align-items:center;justify-content:space-around;padding:0}.nav-scope .menu .contenedor-menu a{text-align:center;text-decoration:none;color:var(--menu-link);font-size:.9rem;line-height:1rem;text-transform:uppercase;transition:color .2s ease}.nav-scope .menu .contenedor-menu a:hover{color:var(--menu-link-hover)}.nav-scope .menu .idiomas{display:grid;grid-template-columns:repeat(auto-fit,minmax(1.5625rem,1fr));align-items:center;text-align:center}.nav-scope .menu .idiomas img{width:1.5rem;cursor:pointer}.nav-scope .menu .idiomas img.active,.nav-scope .menu .idiomas img:hover{opacity:.5}@media (max-width: 767px){.nav-scope .menu{grid-template-columns:100%;text-align:center;padding-bottom:1rem}.nav-scope .menu .contenedor-menu{flex-direction:column;gap:12px}.nav-scope .menu .foto{display:none}.nav-scope .menu .idiomas{margin-top:.5rem}}@media (min-width: 48rem){.nav-scope .menu .contenedor-menu a{font-size:1.1rem}}.seccion{padding:2rem 1rem;max-width:1000px;margin:0 auto}body{font-family:Oswald,sans-serif;background:url(/assets/prism1.png) repeat;background-attachment:fixed;color:#fff}html{scroll-behavior:smooth;scroll-padding-top:calc(var(--nav-h) + 12px)}.hero{min-height:30vh;display:grid;place-items:center;text-align:center;padding:1rem 1rem .6rem;position:relative}.hero:before{content:"";position:absolute;inset:0;pointer-events:none}.hero-inner{position:relative;z-index:1}.hero-title{margin:0 0 .5rem;font-weight:900;letter-spacing:.03em;line-height:1.05;font-size:clamp(2.2rem,6vw + .8rem,5rem);color:#fff;text-shadow:0 0 0 #000,2px 2px 0 #000,-2px 2px 0 #000,2px -2px 0 #000,-2px -2px 0 #000,0 6px 14px rgba(0,0,0,.6)}.hero-subtitle{margin:0;font-weight:700;line-height:1.2;font-size:clamp(1.2rem,3vw + .4rem,2.4rem);color:#fff;text-shadow:-1px -1px 0 #111,1px -1px 0 #111,-1px 1px 0 #111,1px 1px 0 #111,0 10px 18px rgba(0,0,0,.45)}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.hero-title,.hero-subtitle{animation:fadeUp .6s ease both}.hero-subtitle{animation-delay:.08s}@media (min-width: 992px){.hero{min-height:68vh}}.hero-title{font-family:Rock Salt,cursive;margin:0 0 .5rem;font-weight:900;letter-spacing:.03em;line-height:1.05;font-size:clamp(2.2rem,6vw + .8rem,5rem);color:#fff;text-shadow:0 0 0 #000,2px 2px 0 #000,-2px 2px 0 #000,2px -2px 0 #000,-2px -2px 0 #000,0 6px 14px rgba(0,0,0,.6)}.hero-subtitle{font-family:Caveat,cursive;margin:0;font-weight:700;line-height:1.2;font-size:clamp(1.2rem,3vw + .4rem,2.4rem);color:#fff;text-shadow:-1px -1px 0 #111,1px -1px 0 #111,-1px 1px 0 #111,1px 1px 0 #111,0 10px 18px rgba(0,0,0,.45)}.sobre-mi{padding:2rem 1rem;max-width:900px;margin:0 auto;font-family:Fira Code,monospace}.contenedor-sobre-mi{background:#0f0f0f;padding:1.5rem;border-radius:10px;box-shadow:0 4px 20px #00000080}.titulo{font-size:2rem;margin-bottom:1.5rem;text-align:center;color:#fff}.texto{color:#ccc;line-height:1.6}.direccion{margin-bottom:1rem;color:#ff4d4d;font-weight:700}.dir{color:#ff4d4d}.descripcion{background-color:#1a1a1a;padding:1.5rem;border-radius:8px;color:#e0e0e0;box-shadow:inset 0 0 10px #0009}.descripcion .simbolo{color:#3f3;font-weight:700;margin-right:6px}.resaltar{color:#7aa2ff;font-weight:700}.proyectos-seccion .titulo.centrado{text-align:center;margin-bottom:1.5rem}.grid-proyectos{display:grid;gap:1.25rem;grid-template-columns:repeat(1,minmax(0,1fr));margin-top:1rem}@media (min-width: 620px){.grid-proyectos{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 980px){.grid-proyectos{grid-template-columns:repeat(4,minmax(0,1fr))}}.card-proyecto{position:relative;border-radius:12px;overflow:hidden;background:#111;border:1px solid rgba(255,255,255,.08);transition:transform .2s ease,box-shadow .2s ease}.card-proyecto:hover{transform:translateY(-4px);box-shadow:0 10px 28px #00000073}.card-link{display:grid;place-items:center;position:relative}.card-img{display:block;width:100%;aspect-ratio:1 / 1;object-fit:contain;padding:8px;background:radial-gradient(120% 120% at 50% 60%,#ffffff0a,#0000 60%),#0b0b0b;filter:none;image-rendering:auto;transition:transform .35s ease,filter .25s ease}.card-proyecto:hover .card-img{transform:scale(1.015);filter:brightness(1)}.card-overlay{position:absolute;inset:0;display:grid;place-items:center;text-align:center;padding:1rem;background:linear-gradient(to top,#000000a6,#00000040);opacity:0;transition:opacity .25s ease}.card-proyecto:hover .card-overlay{opacity:1}.card-title{margin:0;font-size:1.05rem;font-weight:800;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.6)}.card-tags{margin-top:.25rem;color:#cfd8ff;font-size:.9rem;opacity:.95}.card-cta{display:inline-block;margin-top:.5rem;font-weight:700;font-size:.9rem;padding:.4rem .75rem;border-radius:8px;background:var(--color-acento);color:#fff;box-shadow:0 4px 14px #00000059}.card-repo{display:inline-block;margin-top:.5rem;font-size:.85rem;color:#7aa2ff;text-decoration:none}.card-repo:hover{text-decoration:underline}.habilidades-seccion .titulo.centrado{text-align:center;margin-bottom:1.5rem}.grid-habilidades{display:grid;gap:1.25rem;grid-template-columns:repeat(2,minmax(0,1fr))}@media (min-width: 768px){.grid-habilidades{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width: 1100px){.grid-habilidades{grid-template-columns:repeat(5,minmax(0,1fr))}}.skill-card{background:#111;border:1px solid rgba(255,255,255,.08);border-radius:16px;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.skill-card:hover{transform:translateY(-4px);box-shadow:0 10px 24px #00000073}.skill-media{position:relative}.skill-img{width:100%;height:180px;object-fit:contain;display:block;background:#0b0b0b;padding:16px;filter:drop-shadow(0 10px 18px rgba(0,0,0,.35))}.skill-overlay{position:absolute;inset:0;display:grid;place-items:center;background:radial-gradient(ellipse at center,#0000,#0000008c);opacity:0;transition:opacity .25s ease;text-align:center;padding:.5rem}.skill-overlay h3{margin:0;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.5)}.skill-overlay p{margin:.25rem 0 0;color:#cfd8ff;font-size:.9rem}.skill-plus{position:absolute;right:12px;bottom:12px;width:36px;height:36px;border-radius:999px;border:none;cursor:pointer;background:#fff;color:#000;font-weight:900;font-size:18px;box-shadow:0 8px 18px #00000059;transition:transform .15s ease}.skill-plus:hover{transform:scale(1.06)}.skill-modal{position:fixed;inset:0;z-index:2000;background:#0009;display:grid;place-items:center;padding:1rem}.skill-modal-dialog{width:min(520px,96vw);background:#121212;color:#eee;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:1rem 1rem 1.25rem;box-shadow:0 20px 60px #0009;position:relative}.skill-modal-close{position:absolute;top:8px;right:10px;width:36px;height:36px;border-radius:999px;border:none;font-size:24px;line-height:1;cursor:pointer;background:#1e1e1e;color:#fff}.skill-modal-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.skill-modal-header img{width:42px;height:42px;object-fit:contain}.skill-modal-header h3{margin:0}.badge{display:inline-block;margin-top:.25rem;font-size:.8rem;color:#cfd8ff;opacity:.9}.skill-modal-desc{margin:.5rem 0 1rem;color:#ddd;line-height:1.6}.progress{width:100%;height:10px;border-radius:999px;background:#ffffff14;overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,var(--color-acento),#ff7a7a);border-radius:999px}.progress-label{margin-top:.35rem;font-size:.9rem;color:#cfcfcf;text-align:right}.btn-docs{display:inline-block;margin-top:.75rem;padding:.5rem .9rem;border-radius:10px;background:var(--color-acento);color:#fff;text-decoration:none;font-weight:700;box-shadow:0 8px 16px #00000059}.btn-docs:hover{filter:brightness(1.05)}.skill-media{position:relative;display:grid;place-items:center;width:100%;aspect-ratio:1 / 1;background:#0b0b0b;border-radius:16px;overflow:hidden}.skill-img{display:block;max-width:72%;max-height:72%;width:auto;height:auto;object-fit:contain;object-position:center;filter:drop-shadow(0 6px 14px rgba(0,0,0,.35));margin:0 auto}.skill-overlay{position:absolute;inset:0;display:grid;place-items:center;text-align:center;padding:.5rem;background:radial-gradient(ellipse at center,#0000,#0000008c);opacity:0;transition:opacity .25s ease}.skill-card:hover .skill-overlay{opacity:1}.skill-plus{position:absolute;right:12px;bottom:12px;width:36px;height:36px;border-radius:999px;border:none;background:#fff;color:#000;font-weight:900;font-size:18px;box-shadow:0 8px 18px #00000059;cursor:pointer}.chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}.chip{padding:6px 14px;border-radius:20px;font-size:.85rem;font-weight:600;color:#fff;box-shadow:0 3px 6px #0000004d;transition:transform .2s,box-shadow .2s}.chip:hover{transform:translateY(-2px);box-shadow:0 6px 12px #00000073}.chip-frontend{background:#2563eb}.chip-backend{background:#15803d}.chip-base-de-datos{background:#0891b2}.chip-herramientas{background:#374151}.chip-deploy{background:#7c3aed}.footer{background:#fff;color:#000;padding:2rem 0 0;position:relative}.footer .redes-sociales{display:flex;justify-content:center;margin-bottom:1rem;text-align:center}.footer .redes-sociales .social{width:4.375rem;height:4.375rem;background:#f1f1f1;margin:0 .625rem;border-radius:30%;box-shadow:0 .3125rem .9375rem -.3125rem #00000070;overflow:hidden;position:relative;display:inline-block}.footer .linkedin{color:#0e76a8}.footer .instagram{color:#bc2a8d}.footer .twitter{color:#00acee}.footer .youtube{color:#c4302b}.footer .github{color:#333}.footer .redes-sociales .social{position:relative;overflow:hidden}.footer .redes-sociales .social:before{z-index:0}.footer .redes-sociales .social svg{position:relative;z-index:1;width:24px;height:24px;display:block;color:currentColor;fill:currentColor;transform-origin:center;transition:transform .2s linear,color .2s linear}.footer .redes-sociales .social:hover svg{transform:scale(1.3);color:#fff}.footer .redes-sociales .social:hover svg path{fill:currentColor}.footer .redes-sociales .social:before{content:"";position:absolute;width:120%;height:120%;transform:rotate(45deg);left:-110%;top:90%}.footer .linkedin:before{background:#0e76a8}.footer .instagram:before{background:#bc2a8d}.footer .youtube:before{background:#c4302b}.footer .github:before{background:#333}.footer .redes-sociales .social:hover:before{animation:sweep .7s 1 forwards;top:-10%;left:-10%}@keyframes sweep{0%{left:-110%;top:90%}50%{left:10%;top:-30%}to{left:-10%;top:-10%}}.footer .autor,.footer p.autor{background:#d1d1d1;padding:.5rem 0;text-align:center;font-weight:700;margin:0}.footer .redes-sociales .social{display:grid;place-items:center}.footer .redes-sociales .social svg{width:24px;height:24px;display:block;color:currentColor;fill:currentColor}.contacto{max-width:800px;margin:3rem auto;padding:2rem;text-align:center;background:#ffffff0d;border-radius:16px;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.contacto h2{margin-bottom:1rem}.contacto__texto{margin-bottom:1.5rem;font-size:1rem;opacity:.85}.contacto__email-card{display:inline-flex;align-items:center;gap:.7rem;padding:.8rem 1.2rem;border-radius:12px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#fff;text-decoration:none;font-size:1rem;font-weight:500;box-shadow:0 8px 24px #00000059;transition:transform .2s ease,box-shadow .3s ease}.contacto__email-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px #00000073;border-color:#ffffff40}.contacto__email-card .icon{flex-shrink:0;color:#00bcd4}.contacto__hint{margin-top:1rem;font-size:.9rem;opacity:.6}
