:root{--bg:#0a0a0a;--text:#888897;--text-h:#f0f0f2;--border:#222226;--theme-amber:245 158 11;--theme-purple:168 85 247;--theme-green:34 197 94;--theme-cyan:6 182 212;--theme-rose:244 63 94;--theme:var(--theme-green);--accent:rgb(var(--theme));--accent-bg:rgba(var(--theme), .1);--accent-border:rgba(var(--theme), .4);--sans:"Hanken Grotesk", system-ui, sans-serif;--mono:"JetBrains Mono", ui-monospace, Consolas, monospace;--px:clamp(20px, 5vw, 72px);--nav-h:60px;--section-pad:clamp(64px, 9vw, 120px);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;font:17px/1.65 var(--sans);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html{scroll-behavior:smooth}::selection{background:var(--accent);color:#0a0a0a}*,:before,:after{box-sizing:border-box}body{margin:0;overflow-x:clip}h1,h2,h3{color:var(--text-h);font-family:var(--mono);margin:0}p{margin:0}a{color:inherit;text-decoration:none}button{font:inherit}#root{background-image:radial-gradient(60% 50% at 80% 10%,#f59e0b12 0%,#0000 70%);flex-direction:column;min-height:100dvh;display:flex}main{flex:1}.site-header{height:var(--nav-h);padding:0 var(--px);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);z-index:100;background:#0a0a0ad9;align-items:center;gap:32px;display:flex;position:fixed;top:0;left:0;right:0}.site-logo{flex-shrink:0;align-items:center;gap:10px;display:flex}.logo-img{width:30px;height:30px;display:block}.logo-name{font-family:var(--sans);color:var(--text-h);white-space:nowrap;font-size:15px;font-weight:500}.site-nav{flex:1;justify-content:center;align-items:center;gap:4px;display:flex}.nav-link{font-family:var(--sans);color:var(--text);white-space:nowrap;border-radius:4px;padding:6px 12px;font-size:14px;font-weight:500;transition:color .18s;position:relative}.nav-link:hover,.nav-link--active{color:var(--text-h)}.nav-link--active:after{content:"";background:var(--accent);height:1px;position:absolute;bottom:-2px;left:12px;right:12px}.lang-switcher{flex-shrink:0;align-items:center;gap:2px;display:flex}.lang-btn{font-family:var(--mono);letter-spacing:.08em;color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:5px 10px;font-size:12px;font-weight:500;transition:color .18s,background .18s}.lang-btn--active{background:var(--accent);color:#0a0a0a}.lang-btn:not(.lang-btn--active):hover{color:var(--text-h)}#hero{min-height:100svh;padding:calc(var(--nav-h) + 32px) var(--px) var(--section-pad);flex-direction:column;justify-content:center;align-items:center;width:100%;display:flex}.hero-inner{width:100%;max-width:900px}.hero-name{letter-spacing:-.03em;flex-direction:column;gap:0;margin-bottom:32px;font-size:clamp(56px,12vw,148px);font-weight:700;line-height:.92;display:flex}.name-first{color:var(--text-h)}.name-last{color:var(--accent)}.hero-title{font-family:var(--mono);color:var(--text-h);margin-bottom:16px;font-size:clamp(14px,1.8vw,18px);font-weight:500}.title-prefix{color:var(--accent)}.hero-description{font-family:var(--sans);color:var(--text);max-width:480px;margin-bottom:44px;font-size:clamp(15px,1.6vw,17px);line-height:1.7}.hero-cta{flex-wrap:wrap;gap:12px;display:flex}.btn{font-family:var(--mono);cursor:pointer;white-space:nowrap;border:1px solid #0000;border-radius:6px;align-items:center;gap:6px;padding:12px 24px;font-size:14px;font-weight:500;transition:background .2s,color .2s,border-color .2s;display:inline-flex}.btn-primary{background:var(--accent);color:#0a0a0a;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-bg);color:var(--accent)}.btn-ghost{color:var(--text-h);border-color:var(--border);background:0 0}.btn-ghost:hover{border-color:var(--accent-border);color:var(--accent)}#about{padding:var(--section-pad) var(--px);justify-content:center;display:flex}.about-inner{width:100%;max-width:900px}.section-label{align-items:center;gap:14px;margin-bottom:40px;display:flex}.label-num{font-family:var(--mono);color:var(--accent);font-size:13px;font-weight:700}.label-line{background:var(--border);flex:0 0 40px;height:1px}.label-text{font-family:var(--mono);letter-spacing:.2em;color:var(--text);font-size:11px;font-weight:500}.about-grid{grid-template-columns:1fr 1fr;align-items:start;gap:80px;display:grid}.about-headline{letter-spacing:-.02em;color:var(--text-h);font-size:clamp(36px,4.5vw,56px);font-weight:700;line-height:1.1;font-family:var(--mono);margin-bottom:36px}.about-p1{font-family:var(--sans);color:var(--text-h);margin-bottom:20px;font-size:16px;font-weight:500;line-height:1.7}.about-p2{font-family:var(--sans);color:var(--text);font-size:15px;line-height:1.7}.meta-block{margin-bottom:40px}.meta-label{font-family:var(--mono);letter-spacing:.2em;color:var(--text);margin-bottom:16px;font-size:10px;font-weight:600;display:block}.stack-chips{flex-wrap:wrap;gap:8px;display:flex}.chip{font-family:var(--mono);color:var(--text-h);border:1px solid var(--border);border-radius:6px;padding:5px 12px;font-size:12px;transition:border-color .2s,color .2s}.chip:hover{border-color:var(--accent-border);color:var(--accent)}.meta-text{font-family:var(--sans);color:var(--text);font-size:15px;line-height:1.65}#experience{padding:var(--section-pad) var(--px);justify-content:center;display:flex}.exp-inner{width:100%;max-width:900px}.exp-headline{letter-spacing:-.02em;color:var(--text-h);font-size:clamp(36px,4.5vw,56px);font-weight:700;line-height:1.1;font-family:var(--mono);margin-bottom:48px}.exp-list{border-top:1px solid var(--border);margin:0;padding:0;list-style:none}.exp-item{border-bottom:1px solid var(--border);grid-template-columns:160px 1fr;gap:48px;padding:40px 0;transition:background .2s;display:grid}.exp-item:hover{background:#f59e0b06}.exp-period{font-family:var(--mono);color:var(--text);white-space:nowrap;padding-top:5px;font-size:13px}.exp-title{flex-wrap:wrap;align-items:baseline;gap:10px;margin:0 0 14px;display:flex}.exp-role{font-family:var(--sans);color:var(--text-h);font-size:20px;font-weight:600}.exp-company{font-family:var(--mono);color:var(--accent);font-size:14px;transition:opacity .2s}.exp-company:hover{opacity:.75}.exp-desc{font-family:var(--sans);color:var(--text);margin:0 0 20px;font-size:15px;line-height:1.7}#education{padding:var(--section-pad) var(--px);justify-content:center;display:flex}.edu-inner{width:100%;max-width:900px}.edu-headline{letter-spacing:-.02em;color:var(--text-h);font-size:clamp(36px,4.5vw,56px);font-weight:700;line-height:1.1;font-family:var(--mono);margin-bottom:56px}.edu-timeline{padding-left:28px;position:relative}.edu-timeline:before{content:"";background:var(--border);width:1px;position:absolute;top:10px;bottom:10px;left:0}.edu-item{grid-template-columns:1fr 1fr;align-items:center;gap:40px;padding-bottom:52px;display:grid;position:relative}.edu-item:last-child{padding-bottom:0}.edu-item:before{content:"";background:var(--accent);width:8px;height:8px;box-shadow:0 0 0 3px var(--bg);outline:1px solid var(--border);border-radius:50%;position:absolute;top:10px;left:-32px}.edu-period{font-family:var(--mono);color:var(--accent);letter-spacing:.05em;margin-bottom:10px;font-size:12px;display:block}.edu-title{font-family:var(--mono);color:var(--text-h);margin:0 0 6px;font-size:16px;font-weight:600;line-height:1.4}.edu-institution{font-family:var(--mono);color:var(--text);letter-spacing:.05em;font-size:12px}.edu-keywords{flex-wrap:wrap;align-content:center;gap:8px 14px;display:flex}.edu-kw{font-family:var(--mono);line-height:1.4;transition:color .2s}.edu-kw--1{color:var(--text);opacity:.5;font-size:11px}.edu-kw--2{color:var(--text);font-size:14px}.edu-kw--3{color:var(--text-h);font-size:19px;font-weight:600}.edu-item:hover .edu-kw--3{color:var(--accent)}#projects{padding:var(--section-pad) var(--px);justify-content:center;display:flex}.proj-inner{width:100%;max-width:900px}.proj-headline{letter-spacing:-.02em;color:var(--text-h);font-size:clamp(36px,4.5vw,56px);font-weight:700;line-height:1.1;font-family:var(--mono);margin-bottom:48px}.proj-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.proj-card{border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:14px;padding:28px 24px;transition:border-color .2s,background .2s;display:flex}.proj-card:hover{border-color:var(--accent-border);background:var(--accent-bg)}.proj-num{font-family:var(--mono);color:var(--accent);letter-spacing:.1em;font-size:12px;font-weight:700}.proj-name{font-family:var(--mono);color:var(--text-h);margin:0;font-size:20px;font-weight:700;line-height:1.2}.proj-desc{font-family:var(--sans);color:var(--text);flex:1;margin:0;font-size:14px;line-height:1.65}.proj-chips{margin-top:auto}.proj-links{border-top:1px solid var(--border);gap:16px;padding-top:4px;display:flex}.proj-link{font-family:var(--mono);color:var(--text);letter-spacing:.05em;font-size:12px;transition:color .2s}.proj-link:hover{color:var(--accent)}#contact{padding:var(--section-pad) var(--px) calc(var(--section-pad) + 40px);justify-content:center;display:flex}.contact-inner{width:100%;max-width:900px}.contact-grid{grid-template-columns:1fr 1fr;align-items:start;gap:80px;display:grid}.contact-headline{font-family:var(--mono);letter-spacing:-.02em;color:var(--text-h);margin:0 0 24px;font-size:clamp(36px,4.5vw,56px);font-weight:700;line-height:1.1}.contact-desc{font-family:var(--sans);color:var(--text);max-width:380px;font-size:15px;line-height:1.7}.contact-email-box{border:1px solid var(--border);border-radius:10px;margin-top:32px;padding:20px 24px;transition:border-color .2s;display:block}.contact-email-box:hover{border-color:var(--accent-border)}.contact-cv-btn{justify-content:center;width:100%;margin-top:14px}.email-label{font-family:var(--mono);color:var(--accent);letter-spacing:.05em;margin-bottom:10px;font-size:12px;display:block}.email-addr{font-family:var(--mono);color:var(--text-h);font-size:18px;font-weight:500;display:block}.social-list{border-top:1px solid var(--border);margin:16px 0 0;padding:0;list-style:none}.social-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 0;transition:color .2s;display:flex}.social-name{font-family:var(--sans);color:var(--text-h);font-size:16px;font-weight:600;transition:transform .2s}.social-item:hover .social-name{transform:translate(6px)}.social-handle{font-family:var(--mono);color:var(--text);font-size:13px;transition:color .2s}.social-item:hover .social-handle{color:var(--accent)}.type-block{display:inline-block;position:relative}.type-ghost{visibility:hidden}.type-live{position:absolute;inset:0}.sr-only{clip-path:inset(50%);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}.terminal-cursor{background:var(--accent);vertical-align:text-bottom;width:8px;height:1.1em;margin-left:3px;display:inline-block}@media (prefers-reduced-motion:no-preference){.terminal-cursor{animation:1.1s step-end infinite cursor-blink}}@keyframes cursor-blink{50%{opacity:0}}@media (prefers-reduced-motion:no-preference){[data-reveal]{opacity:0;transition:opacity .5s ease var(--reveal-delay,0s), transform .5s ease var(--reveal-delay,0s);transform:translateY(14px)}[data-reveal].is-revealed{opacity:1;transform:none}.proj-card[data-reveal]{transition:border-color .2s, background .2s, opacity .5s ease var(--reveal-delay,0s), transform .5s ease var(--reveal-delay,0s)}}@media (width<=768px){.site-nav,.logo-name{display:none}.lang-switcher{margin-left:auto}.about-grid{grid-template-columns:1fr;gap:48px}.exp-item{grid-template-columns:1fr;gap:12px}.edu-item{grid-template-columns:1fr;gap:20px}.proj-grid{grid-template-columns:1fr}.contact-grid{grid-template-columns:1fr;gap:48px}}
