:root{--text:#6b6b6b;--text-h:#0a0a0a;--bg:#f8f8f6;--bg-card:#fff;--border:#e2e2de;--accent:#aa3bff;--accent-bg:#aa3bff12;--accent-border:#aa3bff4d;--shadow:#0000000f 0 8px 24px -4px, #00000008 0 2px 6px -1px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--display:Helvetica, Arial, sans-serif;--mono:ui-monospace, Consolas, monospace;font:16px/1.6 var(--sans);letter-spacing:.1px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial;--text:#888;--text-h:#f0f0ee;--bg:#0e0e0c;--bg-card:#161614;--border:#242420;--accent:#c084fc;--accent-bg:#c084fc14;--accent-border:#c084fc4d;--shadow:#0006 0 8px 24px -4px, #0003 0 2px 6px -1px}}*,:before,:after{box-sizing:border-box}body{background:var(--bg);margin:0}#root{min-height:100svh}h1,h2,h3{font-family:var(--display);color:var(--text-h);margin:0;font-weight:700}p{margin:0}a{color:inherit}html{scroll-behavior:smooth}.footer{border-top:1px solid var(--border);text-align:center;letter-spacing:2px;text-transform:uppercase;color:var(--text);padding:24px 64px;font-size:12px}@media (width<=768px){.footer{padding:20px 24px}}.app{flex-direction:column;min-height:100svh;display:flex}main{flex:1}section{box-sizing:border-box;width:100%;max-width:1100px;margin:0 auto;padding:100px 64px}@media (width<=768px){section{padding:72px 24px}}.section-label{letter-spacing:3px;text-transform:uppercase;color:var(--text);margin-bottom:20px;font-size:11px;font-weight:500;display:block}.section-label:before{content:"//";color:var(--accent);margin-right:6px;font-weight:700}.section-title{font-family:var(--display);color:var(--text-h);letter-spacing:-.03em;margin:0 0 56px;font-size:clamp(40px,6vw,64px);font-weight:700;line-height:1}.divider{border:none;border-top:1px solid var(--border);margin:0}[data-animate]{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(28px)}[data-animate].in-view{opacity:1;transform:translateY(0)}.navbar{z-index:100;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(14px);box-sizing:border-box;background:#f8f8f6e0;justify-content:space-between;align-items:center;height:60px;padding:0 64px;display:flex;position:sticky;top:0}@media (prefers-color-scheme:dark){.navbar{background:#0e0e0ce0}}.navbar-logo{font-family:var(--display);letter-spacing:2px;color:var(--text-h);text-transform:uppercase;font-size:15px;font-weight:700;text-decoration:none}.navbar-links{gap:36px;display:flex}.navbar-link{color:var(--text);letter-spacing:2px;text-transform:uppercase;padding-bottom:2px;font-size:11px;font-weight:600;text-decoration:none;transition:color .2s;position:relative}.navbar-link:after{content:"";background:var(--accent);width:0;height:1.5px;transition:width .25s;position:absolute;bottom:-2px;left:0}.navbar-link:hover,.navbar-link.active{color:var(--text-h)}.navbar-link.active:after{width:100%}.navbar-right{align-items:center;gap:16px;display:flex}.navbar-resume{letter-spacing:1.5px;text-transform:uppercase;color:var(--text-h);border:1.5px solid var(--border);border-radius:4px;padding:7px 16px;font-size:11px;font-weight:700;text-decoration:none;transition:border-color .2s,background .2s}.navbar-resume:hover{border-color:var(--text-h)}.hamburger{cursor:pointer;background:0 0;border:none;flex-direction:column;justify-content:center;gap:5px;width:32px;height:32px;padding:4px;display:none}.hamburger span{background:var(--text-h);transform-origin:50%;border-radius:2px;height:1.5px;transition:transform .25s,opacity .25s;display:block}.hamburger.open span:first-child{transform:translateY(6.5px)rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:translateY(-6.5px)rotate(-45deg)}.mobile-menu{background:var(--bg);z-index:99;opacity:0;pointer-events:none;flex-direction:column;padding:40px 24px;transition:opacity .2s,transform .2s;display:none;position:fixed;inset:60px 0 0;transform:translateY(-8px)}.mobile-menu.open{opacity:1;pointer-events:auto;transform:translateY(0)}.mobile-menu nav{flex-direction:column;gap:0;display:flex}.mobile-link{font-family:var(--display);letter-spacing:-.02em;color:var(--text-h);border-bottom:1px solid var(--border);text-transform:uppercase;padding:16px 0;font-size:28px;font-weight:700;text-decoration:none;transition:color .15s}.mobile-link:hover{color:var(--accent)}.mobile-resume{color:var(--accent);letter-spacing:2px;border-bottom:none;margin-top:24px;font-size:13px;font-weight:700}@media (width<=768px){.navbar{padding:0 24px}.navbar-links,.navbar-resume{display:none}.hamburger,.mobile-menu{display:flex}}.hero-section{box-sizing:border-box;grid-template-columns:1fr 380px;align-items:center;gap:80px;max-width:1100px;min-height:calc(100svh - 60px);margin:0 auto;padding:80px 64px;display:grid}.hero-content{flex-direction:column;display:flex}.hero-eyebrow{letter-spacing:3px;text-transform:uppercase;color:var(--text);margin:0 0 28px;font-size:11px}.hero-name{font-family:var(--display);letter-spacing:-.04em;color:var(--text-h);flex-direction:column;margin:0 0 36px;font-size:clamp(72px,10vw,130px);font-weight:700;line-height:.9;display:flex}.hero-name-line{display:block;position:relative}.hero-name-ghost{visibility:hidden;-webkit-user-select:none;user-select:none;display:block}.hero-name-typed{white-space:nowrap;position:absolute;top:0;left:0}.hero-cursor{color:var(--accent);margin-left:2px;font-weight:300;animation:.7s step-end infinite blink;display:inline-block}.hero-cursor.hidden{opacity:0;animation:none}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-tagline{color:var(--text);max-width:400px;margin:0 0 40px;font-size:16px;line-height:1.7}.hero-actions{gap:12px;margin-bottom:60px;display:flex}.hero-btn{letter-spacing:.5px;text-transform:uppercase;border-radius:6px;padding:13px 30px;font-size:13px;font-weight:700;text-decoration:none;transition:all .2s;display:inline-block}.hero-btn-primary{background:var(--text-h);color:var(--bg)}.hero-btn-primary:hover{opacity:.8}.hero-btn-secondary{border:1.5px solid var(--border);color:var(--text-h);background:0 0}.hero-btn-secondary:hover{border-color:var(--text-h)}.hero-stats{gap:40px;display:flex}.hero-stat{flex-direction:column;gap:4px;display:flex}.hero-stat-num{font-family:var(--display);color:var(--accent);letter-spacing:-.03em;font-size:30px;font-weight:700;line-height:1}.hero-stat-label{text-transform:uppercase;letter-spacing:2px;color:var(--text);font-size:10px}.hero-photo-col{justify-content:center;align-self:stretch;align-items:center;display:flex}.hero-photo-wrap{justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative}.hero-photo{object-fit:cover;object-position:top;border:3px solid var(--accent);background:0 0;border-radius:50%;width:380px;height:380px;display:block}.hero-photo-tags{flex-direction:column;align-items:flex-end;gap:6px;display:flex;position:absolute;bottom:-14px;right:-8px}.hero-photo-tag{letter-spacing:2.5px;text-transform:uppercase;color:var(--text);background:var(--bg);border:1px solid var(--border);white-space:nowrap;border-radius:3px;padding:6px 12px;font-size:10px}@media (width<=900px){.hero-section{grid-template-columns:1fr;gap:56px;min-height:auto;padding:64px 24px 80px}.hero-photo-col{order:-1;align-self:auto}.hero-photo{width:220px;height:220px}.hero-photo-tags{bottom:-12px;right:0}.hero-name{font-size:clamp(56px,14vw,90px)}}@media (width<=480px){.hero-stats{gap:28px}}.about-section{text-align:left}.about-content{grid-template-columns:2fr 3fr;align-items:start;gap:80px;display:grid}.about-text{color:var(--text);flex-direction:column;gap:20px;font-size:16px;line-height:1.7;display:flex}.about-skills{margin-top:12px}.skills-label{letter-spacing:2px;text-transform:uppercase;color:var(--text);margin-bottom:16px;font-size:11px;font-weight:600}.skills-list{flex-wrap:wrap;gap:8px;margin:0;padding:0;list-style:none;display:flex}.skill-tag{font-size:12px;font-family:var(--mono);color:var(--accent);background:var(--accent-bg);border:1px solid var(--accent-border);border-radius:3px;padding:4px 10px}.about-photos{grid-template-rows:auto auto;grid-template-columns:1fr 1fr;align-items:start;gap:8px;display:grid}.about-photo{object-fit:cover;border-radius:4px;width:100%;display:block}@media (width<=768px){.about-content{grid-template-columns:1fr;gap:48px}.about-photos{order:-1}}.about-carousel{aspect-ratio:1;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;position:relative;overflow:hidden}.about-carousel-track{height:100%;transition:transform .5s cubic-bezier(.4,0,.2,1);display:flex}.about-carousel-slide{flex:0 0 100%;height:100%}.about-carousel-img{object-fit:cover;object-position:center;width:100%;height:100%;display:block}.about-carousel-btn{background:var(--bg);border:1px solid var(--border);color:var(--text-h);cursor:pointer;opacity:0;z-index:2;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;transition:opacity .2s,background .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.about-carousel:hover .about-carousel-btn{opacity:1}.about-carousel-btn:hover{background:var(--bg-card)}.about-carousel-btn--prev{left:10px}.about-carousel-btn--next{right:10px}.about-carousel-dots{z-index:2;gap:6px;display:flex;position:absolute;bottom:12px;left:50%;transform:translate(-50%)}.about-carousel-dot{cursor:pointer;background:#ffffff80;border:none;border-radius:50%;width:6px;height:6px;padding:0;transition:background .25s,transform .25s}.about-carousel-dot.active{background:var(--accent);transform:scale(1.4)}.experience-section{text-align:left}.experience-list{flex-direction:column;gap:2px;display:flex}.experience-card{border-top:1px solid var(--border);gap:28px;padding:36px 0;transition:all .2s;display:flex}.experience-card:last-child{border-bottom:1px solid var(--border)}.experience-logo{background:var(--bg-card);border:1px solid var(--border);letter-spacing:1px;width:44px;height:44px;color:var(--text-h);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:800;display:flex}.experience-logo-img{object-fit:contain;width:100%;height:100%;padding:6px;display:block}.experience-body{flex:1;min-width:0}.experience-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.experience-role{color:var(--text-h);letter-spacing:-.02em;margin:0 0 4px;font-size:18px;font-weight:800}.experience-company{letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);margin:0;font-size:13px;font-weight:600}.experience-meta{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:4px;display:flex}.experience-period,.experience-location{color:var(--text);white-space:nowrap;letter-spacing:.5px;font-size:12px}.experience-content{grid-template-columns:3fr 3fr;align-items:start;gap:48px;display:grid}.experience-text{min-width:0}.screenshot-btn{cursor:zoom-in;background:0 0;border:none;border-radius:6px;width:100%;padding:0;transition:opacity .15s;display:block}.experience-image{border-radius:6px;width:100%;height:auto;display:block}.experience-description{color:var(--text);margin:0;font-size:15px;line-height:1.7}.experience-bullets{color:var(--text);flex-direction:column;gap:10px;margin:0;padding-left:18px;font-size:15px;line-height:1.65;display:flex}@media (width<=768px){.experience-card{flex-direction:column;gap:16px;padding:28px 0}.experience-meta{align-items:flex-start}.experience-content{grid-template-columns:1fr;gap:24px}}.lightbox-backdrop{z-index:1000;cursor:zoom-out;background:#000000d9;justify-content:center;align-items:center;padding:24px;animation:.15s lb-fade-in;display:flex;position:fixed;inset:0}.lightbox-img{object-fit:contain;cursor:default;border-radius:8px;max-width:100%;max-height:90vh;animation:.15s lb-scale-in;box-shadow:0 24px 80px #0009}.lightbox-close{color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #fff3;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;padding:0;transition:background .15s;display:flex;position:fixed;top:20px;right:24px}.lightbox-close:hover{background:#fff3}.lightbox-close svg{width:18px;height:18px}@keyframes lb-fade-in{0%{opacity:0}to{opacity:1}}@keyframes lb-scale-in{0%{transform:scale(.94)}to{transform:scale(1)}}.projects-section{text-align:left}.featured-projects{border:1px solid var(--border);background:var(--border);border-radius:8px;flex-direction:column;gap:1px;display:flex;overflow:hidden}.featured-project{background:var(--bg-card);grid-template-columns:1fr 1fr;min-height:360px;transition:background .2s;display:grid}.featured-project:hover{background:var(--bg)}.featured-project--reverse{direction:rtl}.featured-project--reverse>*{direction:ltr}.featured-text{flex-direction:column;justify-content:center;padding:40px 44px;display:flex}.featured-footer{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-top:24px;display:flex}.featured-images{background:var(--bg);justify-content:center;align-items:center;gap:10px;padding:32px 28px;display:flex;overflow:hidden}.featured-images--stacked{flex-direction:column;align-items:stretch;padding:20px 24px}.featured-images--stacked .screenshot-btn{flex-shrink:0;width:100%}.featured-images--stacked .featured-screenshot{width:100%;height:auto;max-height:none}.screenshot-btn{cursor:zoom-in;background:0 0;border:none;border-radius:6px;flex-shrink:1;min-width:0;padding:0;transition:opacity .15s;display:flex}.screenshot-btn:hover{opacity:.85}.featured-screenshot{object-fit:contain;border-radius:6px;width:auto;max-width:100%;max-height:300px;display:block;box-shadow:0 4px 24px #0000002e}.project-name{color:var(--text-h);letter-spacing:-.02em;margin:0 0 10px;font-size:17px;font-weight:800}.project-description{color:var(--text);flex:1;margin:0;font-size:15px;line-height:1.7}.project-tags{flex-wrap:wrap;gap:6px;margin:0;padding:0;list-style:none;display:flex}.project-tag{font-size:12px;font-family:var(--mono);color:var(--accent);background:var(--accent-bg);border:1px solid var(--accent-border);border-radius:3px;padding:4px 10px}.project-links{flex-shrink:0;gap:14px;display:flex}.project-links a{color:var(--text);transition:color .2s;display:flex}.project-links a:hover{color:var(--text-h)}.project-links svg{width:18px;height:18px}@media (width<=768px){.featured-project{direction:ltr;grid-template-columns:1fr}.featured-project--reverse{direction:ltr}.featured-images{background:0 0;order:-1;padding:24px 20px 0}.featured-text{padding:24px 28px 32px}.featured-screenshot{max-height:220px}}.contact-section{text-align:left}.contact-description{color:var(--text);max-width:480px;margin-bottom:48px;font-size:16px;line-height:1.75}.contact-links{border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:0;max-width:480px;display:flex;overflow:hidden}.contact-link{border-bottom:1px solid var(--border);background:var(--bg-card);justify-content:space-between;align-items:center;padding:20px 24px;text-decoration:none;transition:background .15s;display:flex;position:relative}.contact-link:last-child{border-bottom:none}.contact-link:hover{background:var(--bg)}.contact-link-label{letter-spacing:2.5px;color:var(--accent);text-transform:uppercase;flex-shrink:0;width:80px;font-size:10px;font-weight:700}.contact-link-value{color:var(--text-h);font-size:14px;font-family:var(--mono);flex:1}.contact-link.copyable .contact-link-copy-hint{letter-spacing:1px;text-transform:uppercase;color:var(--accent);opacity:0;flex-shrink:0;font-size:11px;transition:opacity .15s}.contact-link.copyable:hover .contact-link-copy-hint{opacity:1}.toast{background:var(--text-h);color:var(--bg);letter-spacing:2px;text-transform:uppercase;opacity:0;pointer-events:none;white-space:nowrap;z-index:200;border-radius:4px;padding:12px 24px;font-size:12px;font-weight:700;transition:opacity .2s,transform .2s;position:fixed;bottom:32px;left:50%;transform:translate(-50%)translateY(12px)}.toast.visible{opacity:1;transform:translate(-50%)translateY(0)}
