*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg:#0f0800;--color-surface:#1a0c00;--color-surface-2:#231400;--color-text:#ffedd5;--color-text-muted:#9a7a5a;--color-accent:#fbbf24;--color-accent-hover:#f59e0b;--color-accent-dim:#fbbf241f;--color-accent-2:#b45309;--color-border:#fbbf241a;--font-sans:"Inter", system-ui, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--radius:8px;--max-width:1100px}html{scroll-behavior:smooth}body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text);background-image:linear-gradient(var(--color-border) 1px, transparent 1px), linear-gradient(90deg, var(--color-border) 1px, transparent 1px);background-size:48px 48px;line-height:1.6}main{padding-top:64px}[data-reveal]{opacity:0;transition:opacity .55s,transform .55s;transform:translateY(28px)}[data-reveal=left]{transform:translate(-28px)}[data-reveal=right]{transform:translate(28px)}[data-reveal].revealed{opacity:1;transform:translate(0)}[data-reveal][data-delay="100"]{transition-delay:.1s}[data-reveal][data-delay="200"]{transition-delay:.2s}[data-reveal][data-delay="300"]{transition-delay:.3s}[data-reveal][data-delay="400"]{transition-delay:.4s}.section{max-width:var(--max-width);margin:0 auto;padding:6rem 2rem}.section__label{font-family:var(--font-mono);color:var(--color-accent);letter-spacing:.15em;text-transform:uppercase;align-items:center;gap:.75rem;margin-bottom:1rem;font-size:.8rem;display:flex}.section__label:before{content:"//";opacity:.5}.section__title{color:var(--color-text);margin-bottom:3rem;font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700}.navbar{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border);z-index:100;background-color:#0f0800e0;justify-content:space-between;align-items:center;width:100%;padding:.875rem 2rem;display:flex;position:fixed;top:0;left:0}.navbar__brand{flex-shrink:0;align-items:center;gap:.625rem;text-decoration:none;display:flex}.navbar__mark{border-radius:6px;width:28px;height:28px}.navbar__name{font-family:var(--font-mono);color:var(--color-accent);letter-spacing:-.02em;font-size:1.05rem;font-weight:700}.navbar__links{gap:2rem;list-style:none;display:flex}.navbar__link{font-family:var(--font-mono);color:var(--color-text-muted);padding-bottom:2px;font-size:.85rem;text-decoration:none;transition:color .2s;position:relative}.navbar__link:after{content:"";background-color:var(--color-accent);width:0;height:1px;transition:width .2s;position:absolute;bottom:-2px;left:0}.navbar__link:hover,.navbar__link--active{color:var(--color-accent)}.navbar__link--active:after,.navbar__link:hover:after{width:100%}.navbar__hamburger{cursor:pointer;background:0 0;border:none;flex-direction:column;gap:5px;padding:4px;display:none}.navbar__hamburger span{background-color:var(--color-text-muted);border-radius:2px;width:22px;height:2px;transition:all .25s;display:block}.navbar--open .navbar__hamburger span:first-child{transform:translateY(7px)rotate(45deg)}.navbar--open .navbar__hamburger span:nth-child(2){opacity:0;transform:scaleX(0)}.navbar--open .navbar__hamburger span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.navbar__mobile{border-bottom:1px solid var(--color-border);background-color:#0f0800f7;flex-direction:column;width:100%;padding:.5rem 0;animation:.2s slideDown;display:flex;position:absolute;top:100%;left:0}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.navbar__mobile-link{font-family:var(--font-mono);color:var(--color-text-muted);border-bottom:1px solid var(--color-border);padding:.85rem 2rem;font-size:.9rem;text-decoration:none;transition:color .2s,background-color .2s}.navbar__mobile-link:last-child{border-bottom:none}.navbar__mobile-link:hover,.navbar__mobile-link.navbar__link--active{color:var(--color-accent);background-color:var(--color-surface)}@media (width<=700px){.navbar__links{display:none}.navbar__hamburger{display:flex}}.footer{border-top:1px solid var(--color-border);background-color:var(--color-surface)}.footer__inner{max-width:var(--max-width);justify-content:space-between;align-items:center;gap:1.5rem;margin:0 auto;padding:1.5rem 2rem;display:flex}.footer__brand{align-items:center;gap:.5rem;display:flex}.footer__mark{opacity:.8;border-radius:5px;width:22px;height:22px}.footer__name{font-family:var(--font-mono);color:var(--color-accent);opacity:.8;font-size:.9rem;font-weight:700}.footer__copy{font-family:var(--font-mono);color:var(--color-text-muted);text-align:center;font-size:.75rem}.footer__links{align-items:center;gap:1rem;display:flex}.footer__links a{color:var(--color-text-muted);align-items:center;transition:color .2s;display:flex}.footer__links a:hover{color:var(--color-accent)}.footer__links svg{width:18px;height:18px}@media (width<=600px){.footer__inner{text-align:center;flex-direction:column;gap:1rem}}.hero{min-height:100vh;max-width:var(--max-width);align-items:center;margin:0 auto;padding:0 2rem;display:flex;position:relative}.hero__terminal{border:1px solid var(--color-border);background-color:var(--color-surface);border-radius:10px;max-width:560px;margin-bottom:2rem;overflow:hidden}.hero__terminal-bar{background-color:var(--color-surface-2);border-bottom:1px solid var(--color-border);align-items:center;gap:6px;padding:.6rem 1rem;display:flex}.hero__dot{border-radius:50%;width:12px;height:12px}.hero__dot--red{background:#ff5f57}.hero__dot--yellow{background:#ffbd2e}.hero__dot--green{background:#28c840}.hero__terminal-title{font-family:var(--font-mono);color:var(--color-text-muted);margin-left:auto;margin-right:auto;font-size:.78rem}.hero__terminal-body{padding:1.5rem 1.75rem}.hero__prompt{font-family:var(--font-mono);color:var(--color-text-muted);margin-bottom:.5rem;font-size:.9rem}.hero__prompt-symbol{color:var(--color-accent);margin-right:.5rem}.hero__name{font-family:var(--font-mono);color:var(--color-accent);align-items:center;gap:4px;margin-bottom:.6rem;font-size:clamp(2rem,5vw,3.25rem);font-weight:700;line-height:1.1;display:flex}.hero__cursor{background-color:var(--color-accent);width:.55em;height:1em;margin-left:4px;animation:1.1s step-end infinite blink;display:inline-block}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero__comment{font-family:var(--font-mono);color:var(--color-text-muted);font-size:.95rem}.hero__description{max-width:520px;color:var(--color-text-muted);margin-bottom:2rem;font-size:1.05rem;line-height:1.7}.hero__actions{flex-wrap:wrap;gap:1rem;display:flex}.btn{border-radius:var(--radius);font-family:var(--font-mono);cursor:pointer;border:2px solid #0000;padding:.7rem 1.5rem;font-size:.85rem;font-weight:600;text-decoration:none;transition:all .2s}.btn--primary{background-color:var(--color-accent);color:#1a0c00}.btn--primary:hover{background-color:var(--color-accent-hover)}.btn--outline{border-color:var(--color-border);color:var(--color-text-muted)}.btn--outline:hover{border-color:var(--color-accent);color:var(--color-accent)}.hero__scroll{color:var(--color-text-muted);opacity:.5;transition:opacity .2s;animation:2s ease-in-out infinite bounce;position:absolute;bottom:2.5rem;left:50%;transform:translate(-50%)}.hero__scroll:hover{opacity:1}.hero__scroll svg{width:24px;height:24px}@keyframes bounce{0%,to{transform:translate(-50%)translateY(0)}50%{transform:translate(-50%)translateY(8px)}}.proyectos__grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem;display:grid}.proyecto__card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);flex-direction:column;transition:border-color .2s,transform .2s;display:flex;position:relative;overflow:hidden}.proyecto__card:before,.proyecto__card:after{content:"";border-color:var(--color-accent);opacity:0;z-index:2;border-style:solid;width:12px;height:12px;transition:opacity .2s;position:absolute}.proyecto__card:before{border-width:2px 0 0 2px;border-radius:2px 0 0;top:-1px;left:-1px}.proyecto__card:after{border-width:0 2px 2px 0;border-radius:0 0 2px;bottom:-1px;right:-1px}.proyecto__card:hover{border-color:#fbbf244d;transform:translateY(-3px)}.proyecto__card:hover:before,.proyecto__card:hover:after{opacity:1}.proyecto__imagen{aspect-ratio:16/9;background-color:var(--color-surface-2);border-bottom:1px solid var(--color-border);width:100%;overflow:hidden}.proyecto__imagen img{object-fit:cover;object-position:top;filter:brightness(.9);width:100%;height:100%;transition:transform .4s;display:block}.proyecto__card:hover .proyecto__imagen img{filter:brightness();transform:scale(1.03)}.proyecto__imagen--placeholder{color:var(--color-border);background-image:linear-gradient(var(--color-border) 1px, transparent 1px), linear-gradient(90deg, var(--color-border) 1px, transparent 1px);background-size:24px 24px;justify-content:center;align-items:center;display:flex}.proyecto__body{flex-direction:column;flex:1;gap:.875rem;padding:1.5rem;display:flex}.proyecto__card-header{justify-content:space-between;align-items:center;gap:1rem;display:flex}.proyecto__nombre{font-family:var(--font-mono);color:var(--color-text);font-size:1.1rem;font-weight:700}.proyecto__badge{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;border-radius:4px;padding:.2rem .6rem;font-size:.68rem;font-weight:600}.proyecto__badge--lanzado{color:var(--color-accent);background-color:#fbbf241a;border:1px solid #fbbf2440}.proyecto__badge--en-desarrollo{color:#f97316;background-color:#b453091f;border:1px solid #f9731640}.proyecto__descripcion{color:var(--color-text-muted);flex:1;font-size:.9rem;line-height:1.65}.proyecto__stack{flex-wrap:wrap;gap:.35rem;display:flex}.proyecto__tech{font-family:var(--font-mono);color:var(--color-text-muted);background-color:var(--color-surface-2);border:1px solid var(--color-border);border-radius:4px;padding:.18rem .5rem;font-size:.7rem}.proyecto__links{border-top:1px solid var(--color-border);gap:1rem;margin-top:auto;padding-top:.75rem;display:flex}.proyecto__link{font-family:var(--font-mono);color:var(--color-text-muted);align-items:center;gap:.4rem;font-size:.78rem;text-decoration:none;transition:color .2s;display:flex}.proyecto__link:hover{color:var(--color-accent)}@media (width<=480px){.proyectos__grid{grid-template-columns:1fr}}.stack__grid{grid-template-columns:repeat(4,1fr);gap:1.5rem;display:grid}.stack__categoria{flex-direction:column;gap:.75rem;display:flex}.stack__categoria-label{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--color-accent);border-bottom:1px solid var(--color-border);padding-bottom:.5rem;font-size:.72rem;font-weight:600}.stack__lista{flex-direction:column;gap:.4rem;list-style:none;display:flex}.stack__item{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);cursor:default;align-items:center;gap:.6rem;padding:.5rem .75rem;transition:border-color .2s,background-color .2s;display:flex}.stack__item:hover{background-color:var(--color-surface-2);border-color:#fbbf244d}.stack__item:hover .stack__icon{color:var(--color-accent)}.stack__icon{color:var(--color-text-muted);flex-shrink:0;align-items:center;transition:color .2s;display:flex}.stack__icon svg{width:16px;height:16px}.stack__nombre{font-family:var(--font-mono);color:var(--color-text-muted);font-size:.82rem;transition:color .2s}.stack__item:hover .stack__nombre{color:var(--color-text)}@media (width<=900px){.stack__grid{grid-template-columns:repeat(2,1fr)}}@media (width<=480px){.stack__grid{grid-template-columns:1fr}}.sobre-mi__layout{grid-template-columns:1fr 420px;align-items:start;gap:3rem;display:grid}.sobre-mi__bio{flex-direction:column;gap:1.25rem;display:flex}.sobre-mi__bio p{color:var(--color-text-muted);font-size:1rem;line-height:1.8}.sobre-mi__marca{font-family:var(--font-mono);color:var(--color-accent);font-weight:600}.sobre-mi__panel{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden}.sobre-mi__terminal-header{background-color:var(--color-surface-2);border-bottom:1px solid var(--color-border);align-items:center;gap:6px;padding:.6rem 1rem;display:flex}.sobre-mi__dot{background-color:var(--color-border);border-radius:50%;width:10px;height:10px}.sobre-mi__terminal-title{font-family:var(--font-mono);color:var(--color-text-muted);margin-left:auto;margin-right:auto;font-size:.75rem}.sobre-mi__json{font-family:var(--font-mono);color:var(--color-text-muted);white-space:pre;margin:0;padding:1.25rem 1.5rem;font-size:.82rem;line-height:1.8;overflow-x:auto}.sobre-mi__stats{border-top:1px solid var(--color-border);grid-template-columns:repeat(3,1fr);display:grid}.sobre-mi__stat{border-right:1px solid var(--color-border);text-align:center;flex-direction:column;align-items:center;gap:.2rem;padding:1rem .5rem;display:flex}.sobre-mi__stat:last-child{border-right:none}.sobre-mi__stat-valor{font-family:var(--font-mono);color:var(--color-accent);font-size:1.4rem;font-weight:700}.sobre-mi__stat-label{font-family:var(--font-mono);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.65rem;line-height:1.3}@media (width<=900px){.sobre-mi__layout{grid-template-columns:1fr}}.contacto__layout{grid-template-columns:1fr 1fr;align-items:center;gap:4rem;display:grid}.contacto__texto{flex-direction:column;gap:2rem;display:flex}.contacto__texto p{color:var(--color-text-muted);max-width:440px;font-size:1.05rem;line-height:1.8}.contacto__prompt{font-family:var(--font-mono);color:var(--color-text-muted);align-items:center;gap:.6rem;font-size:1.1rem;display:flex}.contacto__symbol{color:var(--color-accent)}.contacto__lista{flex-direction:column;gap:.75rem;list-style:none;display:flex}.contacto__link{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);align-items:center;gap:1rem;padding:1rem 1.25rem;text-decoration:none;transition:border-color .2s,transform .2s;display:flex;position:relative}.contacto__link:hover{border-color:#fbbf244d;transform:translate(4px)}.contacto__link:hover .contacto__link-icon{color:var(--color-accent)}.contacto__link:hover .contacto__link-arrow{color:var(--color-accent);transform:translate(4px)}.contacto__link-icon{color:var(--color-text-muted);flex-shrink:0;align-items:center;transition:color .2s;display:flex}.contacto__link-icon svg{width:20px;height:20px}.contacto__link-info{flex-direction:column;flex:1;gap:.1rem;display:flex}.contacto__link-label{font-family:var(--font-mono);color:var(--color-accent);text-transform:uppercase;letter-spacing:.1em;font-size:.7rem}.contacto__link-valor{font-family:var(--font-mono);color:var(--color-text);font-size:.85rem}.contacto__link-arrow{font-family:var(--font-mono);color:var(--color-text-muted);font-size:1rem;transition:color .2s,transform .2s}@media (width<=768px){.contacto__layout{grid-template-columns:1fr;gap:2.5rem}}
