*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0a0a;--surface: #111111;--border: #1e1e1e;--text: #e8e8e8;--text-muted: rgba(255,255,255,.65);--accent: #ffffff;--tag-bg: #1a1a1a;--tag-border: #2a2a2a;--font-mono: "Geist Mono", monospace;--font-sans: "Geist", sans-serif;--cursor-dot: rgba(255, 255, 255, .85);--cursor-ring: rgba(255, 255, 255, .35)}body.light{--bg: #f9f9f7;--surface: #ffffff;--border: #e5e5e5;--text: #111111;--text-muted: #666;--accent: #000000;--tag-bg: #f0f0ee;--tag-border: #e0e0de;--cursor-dot: rgba(20, 20, 20, .9);--cursor-ring: rgba(20, 20, 20, .35)}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:15px;line-height:1.7;-webkit-font-smoothing:antialiased;transition:background .3s,color .3s}a{color:inherit;text-decoration:none}@media(pointer:fine){body,a,button,[role=button],input,textarea{cursor:none!important}}.mc-dot,.mc-ring{position:fixed;left:0;top:0;z-index:9999;pointer-events:none;will-change:transform}.mc-dot{width:6px;height:6px;border-radius:999px;background:var(--cursor-dot)}.mc-ring{width:34px;height:34px;border-radius:999px;border:1px solid var(--cursor-ring)}@media(pointer:coarse){.mc-dot,.mc-ring{display:none}body{cursor:auto}}.floating-banner{position:fixed;bottom:2rem;right:2rem;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.25rem 1.5rem;max-width:280px;z-index:100;box-shadow:0 8px 32px #00000080;animation:slideIn .6s ease 1s both}@keyframes slideIn{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.floating-banner.closing{animation:slideOut .3s ease forwards;pointer-events:none}@keyframes slideOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(20px)}}.floating-banner p{font-size:13px;color:var(--text-muted);margin-bottom:.75rem;line-height:1.5}.floating-banner p strong{color:var(--text);display:block;margin-bottom:.25rem}.banner-cta{font-size:13px;font-weight:500;color:var(--accent);border-bottom:1px solid var(--border);padding-bottom:1px;transition:border-color .2s}.banner-cta:hover{border-color:var(--accent)}.banner-close{position:absolute;top:8px;right:10px;background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;transition:color .2s ease}.banner-close:hover{color:var(--accent)}.navbar{position:fixed;top:0;left:0;right:0;z-index:99;display:flex;align-items:center;justify-content:space-between;padding:1.25rem 3rem;background:var(--surface);background:color-mix(in srgb,var(--surface) 90%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);transition:background .3s,border-color .3s}body.light .navbar{background:color-mix(in srgb,var(--surface) 90%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.nav-logo{font-family:var(--font-mono);font-size:1rem;font-weight:600;letter-spacing:-.02em;color:var(--accent)}.nav-right{display:flex;align-items:center;gap:2rem}.nav-links{display:flex;gap:2rem;list-style:none}.nav-links a.nav-active{font-weight:700}.nav-links a{font-size:14px;color:var(--text-muted);transition:color .2s}.nav-links a:hover{color:var(--text)}.nav-actions{display:flex;align-items:center;gap:.75rem}.nav-icon{display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:color .2s;width:32px;height:32px;border-radius:6px}.nav-icon:hover{color:var(--accent)}.theme-toggle{background:transparent;border:none;padding:5px;border-radius:8px;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease,color .2s ease}.theme-toggle:hover{background:var(--border);color:var(--accent)}.hero{display:flex;flex-direction:column;justify-content:center;padding:8rem 3rem 4rem;max-width:900px;margin:0 auto}.hero-letters{display:flex;flex-wrap:wrap;margin-bottom:2.5rem}.hero-letter{font-size:clamp(3.5rem,7vw,6rem);font-weight:700;line-height:1;letter-spacing:-.04em;opacity:0;transform:translateY(30px);animation:letterReveal .5s ease forwards;color:var(--accent)}.hero-letter.space{width:.35em}@keyframes letterReveal{to{opacity:1;transform:translateY(0)}}.hero-description{max-width:600px}.hero-description p{font-size:1.4rem;color:var(--text-muted);line-height:1.8}.content{max-width:900px;margin:0 auto;padding:0 3rem 6rem}.section{border-bottom:1px solid transparent}.section h2{font-size:1.7rem;font-weight:600;letter-spacing:-.02em;margin-bottom:1.25rem;color:var(--accent)}.section>p{color:var(--text-muted);max-width:680px;margin-bottom:1.7rem}.timeline{display:flex;flex-direction:column;gap:0}.job{position:relative;padding:2rem 0 1rem;border-bottom:1px solid var(--border);padding-left:18px}#experiencia>p{margin-bottom:0rem}.job:last-child{border-bottom:none}.job-header{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:.75rem;flex-wrap:wrap}.job-header h3{font-size:1.05rem;font-weight:600;letter-spacing:-.01em;color:var(--accent)}.job:before{content:"";position:absolute;left:0;top:2.7rem;width:6px;height:6px;border-radius:999px;background:var(--accent);opacity:.6}.job:after{content:"";position:absolute;left:-4px;top:calc(2.7rem - 4px);width:14px;height:14px;border-radius:999px;background:color-mix(in srgb,var(--accent) 12%,transparent);pointer-events:none}.job-role{font-weight:400;color:var(--text-muted)}.job-date{opacity:.8;font-size:13px;font-family:var(--font-mono);color:var(--text-muted);white-space:nowrap}.job p{font-size:14px;color:var(--text-muted);margin-bottom:1rem;max-width:640px}.projects-grid{display:flex;flex-direction:column;gap:0}.project-card{display:grid;grid-template-columns:180px 1fr;gap:1.5rem;padding:1.75rem 0;border-bottom:1px solid var(--border);align-items:start;transition:background .2s}.project-card:last-child{border-bottom:none}.project-img{width:180px;height:110px;border-radius:8px;overflow:hidden;background:var(--surface);border:1px solid var(--border);flex-shrink:0}.project-img img{width:100%;height:100%;object-fit:cover}.placeholder-img{display:flex;align-items:center;justify-content:center}.img-placeholder{font-family:var(--font-mono);font-size:1.5rem;font-weight:700;color:var(--border);letter-spacing:.1em}.project-info h3{font-size:.95rem;font-weight:600;color:var(--accent);margin-bottom:.5rem;letter-spacing:-.01em}.project-info p{font-size:13.5px;color:var(--text-muted);line-height:1.65;margin-bottom:.75rem}.project-link{font-size:13px;font-family:var(--font-mono);color:var(--text-muted);border-bottom:1px solid transparent;padding-bottom:1px;transition:color .2s,border-color .2s}.project-link:hover{color:var(--accent);border-color:var(--accent)}.view-all{margin-top:2rem;text-align:center}.view-all a{font-size:14px;font-family:var(--font-mono);color:var(--text-muted);border-bottom:1px solid var(--border);padding-bottom:2px;transition:color .2s,border-color .2s}.view-all a:hover{color:var(--accent);border-color:var(--accent)}.footer{border-top:1px solid var(--border);padding:3rem;max-width:900px;margin:0 auto;text-align:right}.footer-logo{font-family:var(--font-mono);font-size:1rem;font-weight:600;color:var(--text-muted)}@media(max-width:768px){.navbar{padding:1rem 1.5rem}.nav-links,.nav-right{gap:1rem}.hero{padding:7rem 1.5rem 3rem}.content{padding:0 1.5rem 4rem}.footer{padding:2rem 1.5rem}.project-card{grid-template-columns:1fr}.project-img{width:100%;height:160px}.job-header{flex-direction:column;gap:.25rem}}@media(max-width:480px){.hero-letter{font-size:2.75rem}.nav-links{gap:1.25rem}}.contact-main{min-height:100vh;display:flex;align-items:center;padding:8rem 3rem 4rem}.contact-container{width:100%;max-width:560px;margin:0 auto}.contact-header h1{font-size:1.5rem;font-weight:600;letter-spacing:-.02em;color:var(--accent);margin-bottom:.75rem}.contact-subtitle{font-size:14.5px;color:var(--text-muted);line-height:1.75;margin-bottom:.75rem}.contact-time{font-size:13px;color:var(--text-muted);display:flex;align-items:center;gap:.25rem;flex-wrap:wrap}.time-value{font-family:var(--font-mono);color:var(--text);font-size:13px;letter-spacing:.03em}.contact-form{display:flex;flex-direction:column;gap:1.5rem}.form-field{display:flex;flex-direction:column;gap:.4rem}.form-field label{font-size:13.5px;font-weight:500;color:var(--text);letter-spacing:-.01em}.form-field input,.form-field textarea{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:.7rem .9rem;font-size:14px;font-family:var(--font-sans);color:var(--text);outline:none;resize:none;transition:border-color .2s,box-shadow .2s;width:100%}.form-field input::placeholder,.form-field textarea::placeholder{color:var(--text-muted);opacity:.7}.form-field input:focus,.form-field textarea:focus{border-color:var(--text-muted);box-shadow:0 0 0 3px #80808014}.form-field input.error,.form-field textarea.error{border-color:#e05252}.field-hint{font-size:12px;color:var(--text-muted);opacity:.75}.field-error{font-size:12px;color:#e05252;min-height:16px}.submit-btn{align-self:flex-end;background:var(--accent);color:var(--bg);border:none;border-radius:8px;padding:.65rem 1.4rem;font-size:14px;font-weight:500;font-family:var(--font-sans);cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:opacity .2s,transform .15s}.submit-btn:hover{opacity:.88}.submit-btn:active{transform:scale(.98)}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.btn-loading{display:flex;align-items:center;gap:.5rem}.spinner{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.form-success{display:flex;align-items:center;gap:.5rem;font-size:14px;color:#5bac7a;padding:.75rem 1rem;background:#5bac7a14;border:1px solid rgba(91,172,122,.2);border-radius:8px;opacity:0;transform:translateY(8px);pointer-events:none;transition:opacity .3s ease,transform .3s ease}.form-success.show{opacity:1;transform:translateY(0);pointer-events:auto}.form-success.hide{opacity:0;transform:translateY(-6px)}@keyframes fadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.nav-active{color:var(--text)!important}@media(max-width:768px){.contact-main{padding:7rem 1.5rem 3rem;align-items:flex-start}.submit-btn{width:100%;justify-content:center}}#stack{margin-bottom:2rem}#stack h2{font-size:1.7rem;font-weight:600;letter-spacing:-.02em;margin-bottom:1.25rem;color:var(--accent)}#stack>p{color:var(--text-muted);max-width:680px;margin-bottom:1.7rem}.stack-chips{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.5rem}.tech-chip{font-size:13px;padding:.45rem .9rem;border-radius:999px;background:var(--tag-bg);border:1px solid var(--tag-border);color:var(--text-muted);font-family:var(--font-mono);transition:all .2s ease;cursor:default}.tech-chip:hover{color:var(--accent);border-color:var(--accent)}.contact-email{display:inline-block;font-family:var(--font-mono);font-size:14px;color:var(--text);margin-bottom:2rem;border-bottom:1px solid var(--border);padding-bottom:2px;transition:color .2s,border-color .2s}.contact-email:hover{color:var(--accent);border-color:var(--accent)}
