.navbar{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-height);background:transparent;border-bottom:1px solid transparent;transition:transform .28s ease,border-color .2s ease,background .2s ease}.navbar--scrolled{background:#0a0a0ae6;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom-color:var(--border);box-shadow:0 1px #ffffff08}.navbar--hidden{transform:translateY(-100%)}.navbar-inner{max-width:var(--container);margin:0 auto;padding:0 32px;height:100%;display:flex;align-items:center;gap:0}.navbar-logo{display:flex;align-items:center;gap:10px;margin-right:auto;text-decoration:none;color:var(--fg);transition:opacity .15s ease}.navbar-logo:hover{opacity:.75}.navbar-logo-mark{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--fg);color:var(--bg);font-size:11px;font-weight:700;letter-spacing:.04em;border-radius:5px;flex-shrink:0;font-family:var(--font-sans)}.navbar-logo-name{font-size:14px;font-weight:600;letter-spacing:-.02em;color:var(--fg)}.navbar-links{display:flex;align-items:center;gap:2px;margin-left:32px}.navbar-link{position:relative;font-size:13.5px;font-weight:500;color:var(--fg-2);padding:6px 10px;border-radius:var(--radius);transition:color .15s ease,background .15s ease;letter-spacing:-.01em;white-space:nowrap}.navbar-link:hover{color:var(--fg);background:var(--surface-2)}.navbar-link--active{color:var(--fg)}.navbar-link--active:after{content:"";position:absolute;bottom:2px;left:50%;transform:translate(-50%);width:16px;height:2px;background:var(--accent);border-radius:2px}.navbar-right{display:flex;align-items:center;gap:4px;margin-left:20px}.navbar-resume{font-size:13px;font-weight:500;color:var(--fg-2);border:1px solid var(--border-2);padding:5px 12px;border-radius:var(--radius);transition:color .15s ease,border-color .15s ease,background .15s ease;white-space:nowrap;letter-spacing:-.01em}.navbar-resume:hover{color:var(--fg);border-color:var(--fg-3);background:var(--surface-2)}.navbar-divider{display:block;width:1px;height:18px;background:var(--border-2);margin:0 8px;flex-shrink:0}.navbar-icon-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius);color:var(--fg-2);transition:color .15s ease,background .15s ease}.navbar-icon-btn:hover{color:var(--fg);background:var(--surface-2)}.navbar-icon-btn svg{width:17px;height:17px}.navbar-hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:32px;height:32px;padding:7px;border-radius:var(--radius);color:var(--fg-2);background:none;border:none;cursor:pointer;margin-left:8px;transition:background .15s ease,color .15s ease}.navbar-hamburger:hover{background:var(--surface-2);color:var(--fg)}.navbar-hamburger span{display:block;width:100%;height:1.5px;background:currentColor;border-radius:1px;transition:transform .22s ease,opacity .22s ease;transform-origin:center}.navbar-hamburger.is-open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}.navbar-hamburger.is-open span:nth-child(2){opacity:0;transform:scaleX(0)}.navbar-hamburger.is-open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}.navbar-drawer{display:none;position:fixed;top:var(--nav-height);left:0;right:0;background:var(--surface);border-bottom:1px solid var(--border);z-index:99;flex-direction:column;padding:8px 16px 16px;gap:2px}.navbar-drawer.is-open{display:flex}.navbar-drawer-link{font-size:15px;font-weight:500;color:var(--fg-2);padding:10px 12px;border-radius:var(--radius);transition:color .15s ease,background .15s ease}.navbar-drawer-link:hover,.navbar-drawer-link--active{color:var(--fg);background:var(--surface-2)}.navbar-drawer-bottom{border-top:1px solid var(--border);margin-top:8px;padding-top:8px;display:flex;flex-direction:column;gap:2px}.navbar-drawer-socials{display:flex;gap:4px;padding:4px 0 0 12px}.navbar-drawer-socials a{font-size:13px;color:var(--fg-3);padding:4px 8px;border-radius:4px;transition:color .15s ease}.navbar-drawer-socials a:hover{color:var(--fg)}@media (max-width: 900px){.navbar-links{margin-left:16px;gap:0}.navbar-link{padding:6px 8px;font-size:13px}.navbar-right{margin-left:12px}}@media (max-width: 768px){.navbar-links,.navbar-right{display:none}.navbar-hamburger{display:flex;margin-left:auto}.navbar-inner{padding:0 20px}}.home{padding-top:var(--nav-height)}.section-label{display:flex;align-items:center;gap:var(--space-5);margin-bottom:var(--space-12)}.section-label span{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:var(--fg-2);white-space:nowrap;-webkit-user-select:none;user-select:none}.section-label:after{content:"";flex:1;height:1px;background:var(--border)}.hero{position:relative;background:var(--bg);min-height:calc(100vh - var(--nav-height));display:flex;align-items:center;padding:var(--space-16) 0 100px;overflow:hidden}.hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle,rgba(255,255,255,.04) 1px,transparent 1px);background-size:28px 28px;pointer-events:none;z-index:0}.hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 65% 55% at 12% 55%,rgba(37,99,235,.08) 0%,transparent 60%),radial-gradient(ellipse 40% 35% at 85% 75%,rgba(37,99,235,.04) 0%,transparent 55%);pointer-events:none;z-index:0}.hero .container{position:relative;z-index:1}.hero-inner{display:grid;grid-template-columns:1fr 288px;gap:72px;align-items:center}.hero-label{font-family:var(--font-mono);font-size:12.5px;color:var(--fg-3);margin-bottom:var(--space-5);letter-spacing:.02em;display:flex;align-items:center;gap:var(--space-3)}.hero-label:before{content:"";display:inline-block;width:6px;height:6px;background:var(--accent);border-radius:50%;flex-shrink:0}.hero-name{font-size:clamp(52px,7.5vw,84px);font-weight:700;letter-spacing:-.04em;line-height:1.02;color:var(--fg);margin-bottom:var(--space-5)}.hero-roles{display:flex;flex-wrap:wrap;align-items:center;gap:0;font-family:var(--font-mono);font-size:clamp(13px,1.6vw,15px);color:var(--fg-2);margin-bottom:var(--space-8);line-height:1.5}.hero-roles .sep{color:var(--fg-3);padding:0 10px}.hero-bio{font-size:15.5px;color:var(--fg-2);max-width:500px;line-height:1.72;margin-bottom:var(--space-10)}.hero-ctas{display:flex;gap:var(--space-3);flex-wrap:wrap}.btn-primary{display:inline-flex;align-items:center;gap:var(--space-2);height:42px;padding:0 20px;font-size:13.5px;font-weight:600;background:var(--fg);color:var(--bg);border-radius:var(--radius);border:1px solid transparent;letter-spacing:-.01em;transition:background .15s ease,color .15s ease,transform .08s ease,box-shadow .15s ease;cursor:pointer;white-space:nowrap}.btn-primary:hover{background:var(--accent);color:#fff;box-shadow:0 0 0 3px var(--accent-dim)}.btn-primary:active{transform:scale(.97)}.btn-ghost{display:inline-flex;align-items:center;gap:var(--space-2);height:42px;padding:0 20px;font-size:13.5px;font-weight:500;background:transparent;color:var(--fg-2);border:1px solid var(--border-2);border-radius:var(--radius);letter-spacing:-.01em;transition:border-color .15s ease,color .15s ease,background .15s ease,transform .08s ease;white-space:nowrap}.btn-ghost:hover{border-color:var(--fg-3);color:var(--fg);background:var(--surface-2)}.btn-ghost:active{transform:scale(.97)}.hero-photo{width:100%;aspect-ratio:4 / 5;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-2);background:var(--surface);box-shadow:var(--shadow-lg);box-shadow:var(--shadow-lg),inset 0 1px #ffffff0f}.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;filter:grayscale(20%) contrast(1.02);transition:filter .35s ease}.hero-photo:hover img{filter:grayscale(0%) contrast(1)}.projects-section{background:var(--bg);padding:var(--section-pad) 0;border-top:1px solid var(--border)}.project-list{display:flex;flex-direction:column}.project-item{position:relative;display:grid;grid-template-columns:48px 1fr 28px;gap:0 24px;align-items:start;border-bottom:1px solid var(--border);transition:background .14s ease;margin:0 -4px;padding:28px 4px;border-radius:4px}.project-item:first-child{border-top:1px solid var(--border)}a.project-item--linked{cursor:pointer;text-decoration:none;color:inherit}.project-item--linked:hover{background:var(--surface-raised);box-shadow:inset 3px 0 0 var(--accent)}.project-item--linked:hover .project-title{color:var(--accent-hover)}.project-item--linked:hover .project-arrow{color:var(--accent-hover);transform:translate(3px,-3px)}.project-item:not(.project-item--linked):hover{background:var(--surface)}.project-num{font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--fg-3);padding-top:4px;letter-spacing:.02em;-webkit-user-select:none;user-select:none}.project-body{display:flex;flex-direction:column;gap:var(--space-2)}.project-title{font-size:16.5px;font-weight:600;color:var(--fg);letter-spacing:-.02em;line-height:1.3;transition:color .14s ease}.project-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:2px}.tag{font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--fg-2);background:var(--surface);border:1px solid var(--border);padding:2px 8px;border-radius:4px;letter-spacing:.01em;transition:color .14s ease,border-color .14s ease,background .14s ease;white-space:nowrap}.project-item--linked:hover .tag{border-color:var(--border-2);background:var(--surface-2)}.project-desc{font-size:14px;color:var(--fg-2);line-height:1.68;max-width:680px;margin-top:2px}.project-arrow{font-size:15px;color:var(--fg-3);padding-top:4px;transition:color .14s ease,transform .14s ease;line-height:1;-webkit-user-select:none;user-select:none}.experience-section{background:var(--surface-raised);padding:var(--section-pad) 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.experience-list{display:flex;flex-direction:column}.exp-item{display:grid;grid-template-columns:44px 1fr auto;gap:0 var(--space-5);padding:30px 0;border-bottom:1px solid var(--border);align-items:start;transition:background .14s ease}.exp-item:first-child{border-top:1px solid var(--border)}.exp-item--current{box-shadow:inset 3px 0 0 var(--green);padding-left:var(--space-4);margin-left:-var(--space-4)}.exp-item--current{box-shadow:inset 3px 0 0 var(--green);padding-left:16px;margin-left:-16px}.exp-date-col{display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-2);padding-top:2px;text-align:right}.exp-logo{width:44px;height:44px;object-fit:contain;border-radius:6px;padding-top:2px}.exp-date{font-family:var(--font-mono);font-size:12px;color:var(--fg-2);line-height:1.45;letter-spacing:.01em}.exp-upcoming-badge{display:inline-flex;align-items:center;font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--accent-hover);background:var(--accent-dim);border:1px solid var(--accent-border);border-radius:20px;padding:2px 8px;letter-spacing:.04em;text-transform:uppercase;width:fit-content}.exp-item--upcoming{box-shadow:inset 3px 0 0 var(--accent);padding-left:16px;margin-left:-16px}.exp-current{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:11px;color:var(--green);font-weight:500;background:var(--green-dim);border:1px solid rgba(34,197,94,.2);border-radius:20px;padding:2px 8px 2px 6px;width:fit-content}.exp-current-dot{width:6px;height:6px;background:var(--green);border-radius:50%;animation:pulse 2.5s ease infinite;flex-shrink:0}@keyframes pulse{0%,to{opacity:1}50%{opacity:.25}}.exp-content{display:flex;flex-direction:column;gap:5px}.exp-role{font-size:15.5px;font-weight:600;color:var(--fg);letter-spacing:-.02em;line-height:1.35}.exp-company{font-size:13.5px;color:var(--fg-2);font-weight:400}.exp-desc{font-size:14px;color:var(--fg-2);line-height:1.68;margin-top:var(--space-1)}.exp-desc a{color:var(--accent-hover);border-bottom:1px solid transparent;transition:border-color .14s ease}.exp-desc a:hover{border-bottom-color:var(--accent-hover)}.exp-tech-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:var(--space-2)}.skills-section{background:var(--bg);padding:var(--section-pad) 0;border-top:1px solid var(--border)}.skills-grid{display:flex;flex-direction:column}.skill-row{display:grid;grid-template-columns:148px 1fr;gap:0 var(--space-8);padding:22px 0;border-bottom:1px solid var(--border);align-items:center}.skill-row:first-child{border-top:1px solid var(--border)}.skill-label{font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.09em;text-transform:uppercase;color:var(--fg-3)}.skill-chips{display:flex;flex-wrap:wrap;gap:var(--space-2)}.chip{font-family:var(--font-mono);font-size:12.5px;font-weight:400;color:var(--fg-2);background:var(--surface);border:1px solid var(--border-2);padding:5px 12px;border-radius:var(--radius);transition:color .14s ease,border-color .14s ease,background .14s ease,box-shadow .14s ease;cursor:default;letter-spacing:.01em}.chip:hover{color:var(--fg);border-color:var(--fg-3);background:var(--surface-2);box-shadow:var(--shadow-sm)}.contact-section{background:var(--surface-raised);padding:var(--section-pad) 0 88px;border-top:1px solid var(--border)}.contact-inner{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}.contact-info{display:flex;flex-direction:column;gap:var(--space-5)}.contact-heading{font-size:clamp(24px,3.5vw,32px);font-weight:700;letter-spacing:-.03em;line-height:1.15;color:var(--fg)}.contact-subtext{font-size:14.5px;color:var(--fg-2);line-height:1.72;max-width:340px}.contact-email-wrap{display:flex;flex-direction:column;gap:4px;padding:var(--space-4) var(--space-5);background:var(--surface-2);border:1px solid var(--border-2);border-radius:var(--radius-lg);transition:border-color .14s ease}.contact-email-wrap:hover{border-color:var(--accent-border)}.contact-email-label{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-3)}.contact-email{font-family:var(--font-mono);font-size:14px;font-weight:500;color:var(--accent-hover);transition:color .14s ease}.contact-email-wrap:hover .contact-email{color:var(--fg)}.contact-links{display:flex;gap:var(--space-3);flex-wrap:wrap}.contact-link{display:inline-flex;align-items:center;gap:5px;font-size:13.5px;font-weight:500;color:var(--fg-3);padding:7px 14px;border:1px solid var(--border);border-radius:var(--radius);transition:color .14s ease,border-color .14s ease,background .14s ease}.contact-link:hover{color:var(--fg);border-color:var(--border-2);background:var(--surface-2)}.contact-form{display:flex;flex-direction:column;gap:var(--space-3);background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:inset 0 1px #ffffff0a,var(--shadow-sm)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.form-input{width:100%;background:var(--surface-2);border:1px solid var(--border-2);color:var(--fg);border-radius:var(--radius);padding:10px 13px;font-size:14px;line-height:1.5;transition:border-color .15s ease,box-shadow .15s ease;outline:none;-webkit-appearance:none}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1f}.form-input::placeholder{color:var(--fg-3)}.form-textarea{resize:vertical;min-height:148px}.form-submit{align-self:flex-end;display:inline-flex;align-items:center;gap:var(--space-2);height:40px;padding:0 20px;font-size:13.5px;font-weight:600;background:var(--fg);color:var(--bg);border-radius:var(--radius);border:none;letter-spacing:-.01em;cursor:pointer;transition:background .15s ease,color .15s ease,transform .08s ease,box-shadow .15s ease;margin-top:var(--space-1)}.form-submit:hover{background:var(--accent);color:#fff;box-shadow:0 0 0 3px var(--accent-dim)}.form-submit:active{transform:scale(.97)}.footer{background:var(--bg);padding:40px 0;border-top:1px solid var(--border)}.footer-inner{display:flex;justify-content:space-between;align-items:center;gap:var(--space-5);flex-wrap:wrap}.footer-brand{display:flex;align-items:center;gap:var(--space-3)}.footer-mark{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;background:var(--surface-2);border:1px solid var(--border-2);color:var(--fg-2);font-size:10px;font-weight:700;letter-spacing:.04em;border-radius:5px;font-family:var(--font-sans);flex-shrink:0}.footer-text{font-size:13px;color:var(--fg-3)}.footer-links{display:flex;gap:var(--space-5)}.footer-links a{font-size:13px;color:var(--fg-3);transition:color .14s ease}.footer-links a:hover{color:var(--fg-2)}@media (max-width: 900px){.hero-inner{grid-template-columns:1fr;gap:var(--space-12)}.hero-photo{width:180px;height:225px;aspect-ratio:auto}.exp-item{grid-template-columns:40px 1fr;gap:var(--space-2) var(--space-4)}.exp-date-col{grid-column:1 / -1;align-items:flex-start;text-align:left;order:-1}.exp-logo{width:40px;height:40px}.exp-item--current{margin-left:-16px}.skill-row{grid-template-columns:1fr;gap:var(--space-3)}.contact-inner{grid-template-columns:1fr;gap:var(--space-12)}}@media (max-width: 640px){:root{--section-pad: 80px}.hero{padding:var(--space-12) 0 80px}.project-item{grid-template-columns:36px 1fr 22px;gap:0 var(--space-4)}.form-row{grid-template-columns:1fr}.contact-form{padding:var(--space-5)}.form-submit{align-self:stretch;justify-content:center}.footer-inner{flex-direction:column;align-items:flex-start;gap:var(--space-4)}}:root{--bg: #0a0a0a;--surface: #111111;--surface-2: #181818;--surface-raised: #141414;--border: #262626;--border-2: #333333;--border-accent: rgba(37, 99, 235, .3);--fg: #ebebeb;--fg-2: #9a9a9a;--fg-3: #6b6b6b;--accent: #2563eb;--accent-hover: #3b82f6;--accent-dim: rgba(37, 99, 235, .08);--accent-border: rgba(37, 99, 235, .28);--green: #22c55e;--green-dim: rgba(34, 197, 94, .1);--font-sans: "Inter", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--nav-height: 64px;--container: 1100px;--section-pad: 112px;--radius: 6px;--radius-lg: 12px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .6), 0 1px 2px rgba(0, 0, 0, .4);--shadow: 0 4px 16px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .6)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;height:100%;scroll-behavior:smooth;background:var(--bg)}body{background:var(--bg);color:var(--fg);font-family:var(--font-sans);font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;min-height:100%}::selection{background:var(--accent);color:#fff}img,svg{display:block;max-width:100%}a{color:inherit;text-decoration:none}ul,ol{list-style:none}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit;background:transparent;border:none;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}#root{background:var(--bg);display:flex;flex-direction:column;min-height:100vh}.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 var(--space-8)}@media (max-width: 640px){.container{padding:0 var(--space-5)}}.reveal{opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease}.reveal.is-visible{opacity:1;transform:translateY(0)}
