@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg:#0c0c0d;--bg-subtle:#111113;--bg-elevated:#ffffff08;--bg-hover:#ffffff0e;--border:#ffffff12;--border-light:#ffffff0a;--border-focus:#ffffff2e;--text-1:#f2f2f3;--text-2:#9a9aa3;--text-3:#55555f;--accent:#7b7cf7;--accent-dim:#7b7cf71f;--accent-glow:#7b7cf740;--green:#34d399;--green-dim:#34d39914;--sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--mono:"JetBrains Mono", "Fira Code", monospace;--max-w:1040px;--nav-h:60px;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-std:cubic-bezier(.2, .8, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;background:var(--bg);color:var(--text-1);font-family:var(--sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:16px}body{background:var(--bg);min-height:100vh;overflow-x:hidden}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:99px}::-webkit-scrollbar-thumb:hover{background:#ffffff26}h1,h2,h3,h4,h5,h6{font-family:var(--sans);letter-spacing:-.025em;color:var(--text-1);font-weight:600;line-height:1.2}p{color:var(--text-2);line-height:1.65}code{font-family:var(--mono)}a{color:inherit}.container{max-width:var(--max-w);width:100%;margin:0 auto;padding:0 1.5rem}.section{border-top:1px solid var(--border-light);padding:7rem 0}@media (width<=768px){.section{padding:4rem 0}}#projects,#experience,#contact{scroll-margin-top:calc(var(--nav-h) + 20px)}.section-label{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--text-3);margin-bottom:.75rem;font-size:.7rem;font-weight:500}.section-title{color:var(--text-1);margin-bottom:2.5rem;font-size:1.1rem;font-weight:600}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeUp .65s var(--ease-out) forwards}.navbar{z-index:100;height:var(--nav-h);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border-light);background:#0c0c0dd1;align-items:center;transition:border-color .3s;display:flex;position:sticky;top:0}.navbar.scrolled{border-bottom-color:var(--border)}.navbar-inner{justify-content:space-between;align-items:center;width:100%;display:flex}.nav-logo{color:var(--text-1);letter-spacing:-.01em;opacity:.85;font-size:.9rem;font-weight:600;text-decoration:none;transition:opacity .2s}.nav-logo:hover{opacity:1}.nav-links{align-items:center;gap:1.75rem;display:flex}.nav-link{color:var(--text-3);letter-spacing:.01em;font-size:.85rem;font-weight:450;text-decoration:none;transition:color .2s;position:relative}.nav-link:hover{color:var(--text-2)}.nav-link.active{color:var(--text-1);font-weight:500}.nav-link.active:after{content:"";background:var(--text-1);opacity:.4;height:1px;position:absolute;bottom:-2px;left:0;right:0}.nav-status{font-family:var(--mono);color:var(--green);opacity:.75;align-items:center;gap:.4rem;font-size:.7rem;display:flex}.nav-status-dot{background:var(--green);border-radius:50%;width:5px;height:5px;animation:2.5s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}@media (width<=540px){.nav-logo,.nav-status{display:none}.nav-links{gap:1.25rem}}.hero-section{padding:10rem 0 8rem}.hero-eyebrow{font-family:var(--mono);color:var(--text-3);letter-spacing:.04em;align-items:center;gap:.5rem;margin-bottom:1.5rem;font-size:.75rem;display:inline-flex}.hero-eyebrow-sep{color:var(--border-focus)}.hero-name{letter-spacing:-.04em;color:var(--text-1);margin-bottom:1.25rem;font-size:clamp(2.6rem,6vw,4rem);font-weight:700;line-height:1.07}.hero-name-native{color:var(--text-3);letter-spacing:.01em;margin-left:.4em;font-size:.6em;font-weight:400}.hero-desc{color:var(--text-2);max-width:540px;margin-bottom:2.5rem;font-size:1rem;font-weight:400;line-height:1.7}.hero-cta-row{flex-wrap:wrap;align-items:center;gap:1.5rem;display:flex}.hero-cta-primary{color:var(--text-1);border:1px solid var(--border-focus);background:var(--bg-elevated);border-radius:6px;align-items:center;gap:.45rem;padding:.6rem 1.1rem;font-size:.85rem;font-weight:500;text-decoration:none;transition:background .2s,border-color .2s;display:inline-flex}.hero-cta-primary:hover{background:var(--bg-hover);border-color:#ffffff38}.hero-cta-link{color:var(--text-3);font-size:.85rem;text-decoration:none;transition:color .2s}.hero-cta-link:hover{color:var(--text-2)}@media (width<=768px){.hero-section{padding:6rem 0 5rem}}.projects-section{border-top:1px solid var(--border-light);padding:7rem 0}@media (width<=768px){.projects-section{padding:4rem 0}}.projects-grid{border:1px solid var(--border-light);border-radius:10px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1px;display:grid;overflow:hidden}.project-card{background:var(--bg-subtle);text-align:left;border-right:1px solid var(--border-light);border-bottom:1px solid var(--border-light);flex-direction:column;padding:1.5rem;transition:background .2s;display:flex;position:relative}.project-card:hover{background:var(--bg-elevated)}.project-card:hover .project-arrow{opacity:1;transform:translate(2px,-2px)}.project-header{justify-content:space-between;align-items:flex-start;margin-bottom:.6rem;display:flex}.project-name{color:var(--text-1);font-size:.9rem;font-weight:600;font-family:var(--mono);text-decoration:none;transition:color .2s}.project-name:hover{color:var(--accent)}.project-arrow{color:var(--text-3);opacity:0;transition:opacity .2s, transform .2s var(--ease-std);flex-shrink:0;margin-top:2px}.project-desc{color:var(--text-2);flex-grow:1;margin-bottom:1.25rem;font-size:.8rem;line-height:1.6}.project-lang{font-family:var(--mono);color:var(--text-3);align-items:center;gap:.35rem;margin-top:auto;font-size:.7rem;display:inline-flex}.project-lang-dot{background:var(--accent);border-radius:50%;flex-shrink:0;width:6px;height:6px}.show-more-container{margin-top:1.5rem;display:flex}.show-more-button{border:1px solid var(--border);color:var(--text-3);cursor:pointer;font-size:.78rem;font-family:var(--sans);background:0 0;border-radius:6px;padding:.5rem 1rem;transition:color .2s,border-color .2s}.show-more-button:hover{color:var(--text-2);border-color:var(--border-focus)}@media (width<=480px){.projects-grid{grid-template-columns:1fr}}.experience-section{border-top:1px solid var(--border-light);padding:7rem 0}@media (width<=768px){.experience-section{padding:4rem 0}}.timeline{flex-direction:column;gap:0;display:flex}.timeline-item{border-top:1px solid var(--border-light);text-align:left;grid-template-columns:120px 1fr;gap:1.5rem;padding:1.75rem 0;display:grid}.timeline-item:last-child{border-bottom:1px solid var(--border-light)}.timeline-period{font-family:var(--mono);color:var(--text-3);padding-top:2px;font-size:.72rem;line-height:1.5}.timeline-role{color:var(--text-1);margin-bottom:.2rem;font-size:.92rem;font-weight:600}.timeline-company{color:var(--text-3);font-size:.8rem;font-family:var(--mono);margin-bottom:.75rem}.timeline-desc{color:var(--text-2);max-width:580px;font-size:.8rem;line-height:1.7}@media (width<=600px){.timeline-item{grid-template-columns:1fr;gap:.4rem}.timeline-period{font-size:.68rem}}.contact-section{border-top:1px solid var(--border-light);padding:7rem 0}@media (width<=768px){.contact-section{padding:4rem 0}}.contact-inner{max-width:480px}.contact-tagline{color:var(--text-2);margin-bottom:2rem;font-size:.9rem;line-height:1.7}.contact-links{flex-wrap:wrap;gap:.5rem;display:flex}.contact-link{font-size:.8rem;font-family:var(--mono);color:var(--text-3);border:1px solid var(--border);border-radius:5px;align-items:center;gap:.35rem;padding:.45rem .85rem;text-decoration:none;transition:color .2s,border-color .2s,background .2s;display:inline-flex}.contact-link:hover{color:var(--text-1);border-color:var(--border-focus);background:var(--bg-elevated)}.contact-divider{background:var(--border-light);width:100%;height:1px;margin:2rem 0}.contact-form{flex-direction:column;gap:1.25rem;display:flex}.contact-field{flex-direction:column;gap:.35rem;display:flex}.contact-label{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);font-size:.68rem}.contact-input,.contact-textarea{border:none;border-bottom:1px solid var(--border);color:var(--text-1);font-size:.88rem;font-family:var(--sans);resize:none;background:0 0;outline:none;padding:.6rem 0;transition:border-color .2s}.contact-input::placeholder,.contact-textarea::placeholder{color:var(--text-3)}.contact-input:focus,.contact-textarea:focus{border-bottom-color:var(--border-focus)}.contact-submit{font-family:var(--sans);color:var(--text-2);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:5px;align-self:flex-start;margin-top:.25rem;padding:.5rem 1rem;font-size:.8rem;font-weight:500;transition:color .2s,border-color .2s,background .2s}.contact-submit:hover{color:var(--text-1);border-color:var(--border-focus);background:var(--bg-elevated)}.contact-status-msg{font-family:var(--mono);color:var(--text-3);margin-top:.25rem;font-size:.72rem}.contact-status-msg.ok{color:var(--green)}.contact-status-msg.err{color:#f87171}.site-footer{border-top:1px solid var(--border-light);padding:2rem 0}.footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.footer-copy{color:var(--text-3);font-size:.75rem}.footer-note{font-family:var(--mono);color:var(--text-3);opacity:.6;font-size:.7rem}.btn{font-family:var(--sans);cursor:pointer;border:1px solid #0000;border-radius:6px;align-items:center;gap:.5rem;padding:.6rem 1.1rem;font-size:.85rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{filter:brightness(1.12)}.btn-secondary{background:var(--bg-elevated);color:var(--text-2);border-color:var(--border)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-focus);color:var(--text-1)}.glass-card{background:var(--bg-subtle);border:1px solid var(--border-light);border-radius:8px;transition:border-color .2s,background .2s}.glass-card:hover{border-color:var(--border);background:var(--bg-elevated)}.badge{font-family:var(--mono);background:var(--bg-elevated);border:1px solid var(--border-light);color:var(--text-2);border-radius:99px;padding:.2rem .55rem;font-size:.7rem}.text-gradient{-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;background-image:linear-gradient(135deg, #fff 30%, var(--text-2) 100%)}.form-group{flex-direction:column;gap:.5rem;margin-bottom:1.25rem;display:flex}.form-label{font-size:.78rem;font-family:var(--mono);color:var(--text-2)}.form-input,.form-textarea{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-1);font-family:var(--sans);border-radius:6px;outline:none;padding:.65rem .9rem;font-size:.88rem;transition:border-color .2s}.form-input:focus,.form-textarea:focus{border-color:var(--border-focus)}.spinner{border:2px solid #ffffff0d;border-top-color:var(--accent);border-radius:50%;width:28px;height:28px;animation:.9s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}
