:root{--bg:#fff;--bg-soft:#f6f7fb;--bg-elev:#fff;--text:#2a2d3a;--text-strong:#0b0d12;--text-muted:#6b6f7d;--border:#e7e8ee;--border-strong:#d6d8e1;--accent:#7c5cff;--accent-2:#22d3ee;--accent-3:#ff7ab8;--accent-bg:#7c5cff14;--ring:#7c5cff59;--shadow-sm:0 1px 2px #0f111c0a, 0 2px 6px #0f111c0d;--shadow-md:0 6px 20px #0f111c14;--shadow-lg:0 24px 60px #0f111c1f;--sans:"Inter", system-ui, "Segoe UI", Roboto, sans-serif;--mono:"JetBrains Mono", ui-monospace, Consolas, monospace;font:16px/1.6 var(--sans);--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}}html[data-theme=dark]{--bg:#0b0d12;--bg-soft:#10131b;--bg-elev:#141823;--text:#c8ccd6;--text-strong:#f5f7fb;--text-muted:#8a90a0;--border:#232735;--border-strong:#2e3346;--accent:#9d83ff;--accent-2:#22d3ee;--accent-3:#ff7ab8;--accent-bg:#9d83ff1f;--ring:#9d83ff73;--shadow-sm:0 1px 2px #0000004d, 0 2px 6px #00000040;--shadow-md:0 8px 24px #0006;--shadow-lg:0 30px 80px #0000008c}@media (prefers-color-scheme:dark){html:not([data-theme=light]){--bg:#0b0d12;--bg-soft:#10131b;--bg-elev:#141823;--text:#c8ccd6;--text-strong:#f5f7fb;--text-muted:#8a90a0;--border:#232735;--border-strong:#2e3346;--accent:#9d83ff;--accent-bg:#9d83ff1f;--ring:#9d83ff73;--shadow-sm:0 1px 2px #0000004d, 0 2px 6px #00000040;--shadow-md:0 8px 24px #0006;--shadow-lg:0 30px 80px #0000008c}}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);margin:0}#root{min-height:100svh}h1,h2,h3,h4{color:var(--text-strong);font-family:var(--sans);letter-spacing:-.02em;margin:0;font-weight:700}p{margin:0}a{color:inherit;text-decoration:none;transition:color .2s}a:hover{color:var(--accent)}::selection{background:var(--accent);color:#fff}.page{width:100%;max-width:1180px;margin:0 auto;padding:0 24px}main{flex-direction:column;gap:96px;display:flex}.section{padding:24px 0;scroll-margin-top:96px}.section-head{flex-direction:column;gap:6px;margin-bottom:32px;display:flex}.kicker{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-size:12px}.section h2{font-size:clamp(28px,4vw,40px)}.nav{z-index:50;background:color-mix(in oklab, var(--bg) 80%, transparent);-webkit-backdrop-filter:saturate(160%)blur(14px);border-bottom:1px solid #0000;justify-content:space-between;align-items:center;gap:16px;padding:16px 0;transition:border-color .3s;display:flex;position:sticky;top:0}.nav:after{content:"";background:var(--border);opacity:.6;height:1px;position:absolute;inset:auto 0 0}.brand{color:var(--text-strong);align-items:center;gap:10px;font-weight:700;display:inline-flex}.brand-mark{background:linear-gradient(135deg, var(--accent), var(--accent-2));color:#fff;width:34px;height:34px;font-family:var(--mono);box-shadow:var(--shadow-sm);border-radius:10px;place-items:center;font-size:13px;font-weight:700;display:inline-grid}.brand-name{letter-spacing:-.01em;font-size:15px}.nav-links{gap:4px;font-size:14px;display:flex}.nav-links a{color:var(--text-muted);border-radius:8px;padding:8px 12px;transition:all .2s}.nav-links a:hover,.nav-links a.active{color:var(--text-strong);background:var(--accent-bg)}.theme-toggle{border:1px solid var(--border);background:var(--bg-elev);width:36px;height:36px;color:var(--text-strong);cursor:pointer;border-radius:10px;place-items:center;font-size:16px;transition:all .2s;display:grid}.theme-toggle:hover{border-color:var(--accent);box-shadow:0 0 0 4px var(--ring)}@media (width<=860px){.hero-inner{flex-direction:column-reverse;align-items:center;gap:40px}.hero-content{max-width:100%}.hero-photo-wrap{width:220px;height:220px}}@media (width<=480px){.hero-photo-wrap{border-radius:20px;width:160px;height:160px}.hero-photo{border-radius:18px}}@media (width<=720px){.brand-name{display:none}.nav-links{gap:0}.nav-links a{padding:6px 8px;font-size:13px}}.hero{isolation:isolate;padding:80px 0 64px;position:relative;overflow:hidden}.hero-inner{justify-content:space-between;align-items:center;gap:60px;display:flex;position:relative}.hero-content{flex:1;min-width:0;max-width:600px}.hero-photo-wrap{background:linear-gradient(135deg, var(--accent), var(--accent-3) 50%, var(--accent-2));width:300px;height:300px;box-shadow:0 20px 60px -10px color-mix(in oklab, var(--accent) 50%, transparent);border-radius:28px;flex-shrink:0;padding:3px;animation:8s ease-in-out infinite heroFloat}.hero-photo{object-fit:cover;object-position:top;border-radius:26px;width:100%;height:100%;display:block}@keyframes heroFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-14px)}}.hero-bg{z-index:-1;pointer-events:none;position:absolute;inset:-120px -40px;overflow:hidden}.blob{filter:blur(80px);opacity:.55;border-radius:50%;animation:14s ease-in-out infinite float;position:absolute}.blob-1{background:var(--accent);width:420px;height:420px;top:-60px;left:-60px}.blob-2{background:var(--accent-2);width:360px;height:360px;animation-delay:-4s;top:40px;right:-40px}.blob-3{background:var(--accent-3);width:320px;height:320px;animation-delay:-8s;bottom:-120px;left:30%}.grid{background-image:linear-gradient(to right, var(--border) 1px, transparent 1px), linear-gradient(to bottom, var(--border) 1px, transparent 1px);opacity:.35;background-size:44px 44px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(#000 35%,#0000 75%);mask-image:radial-gradient(#000 35%,#0000 75%)}@keyframes float{0%,to{transform:translate(0)scale(1)}50%{transform:translate(20px,-20px)scale(1.08)}}.badge{font-size:13px;font-family:var(--mono);background:var(--bg-elev);border:1px solid var(--border);color:var(--text-muted);box-shadow:var(--shadow-sm);border-radius:999px;align-items:center;gap:8px;padding:6px 12px;display:inline-flex}.badge .dot{background:#22c55e;border-radius:50%;width:8px;height:8px;animation:2s ease-in-out infinite pulse;box-shadow:0 0 0 4px #22c55e2e}@keyframes pulse{0%,to{box-shadow:0 0 0 4px #22c55e2e}50%{box-shadow:0 0 0 8px #22c55e0d}}.hero h1{letter-spacing:-.035em;margin:24px 0 20px;font-size:clamp(40px,7vw,76px);line-height:1.02}.hero h1 .accent{background:linear-gradient(120deg, var(--accent) 0%, var(--accent-3) 60%, var(--accent-2) 100%);color:#0000;-webkit-background-clip:text;background-clip:text}.lede{color:var(--text-muted);max-width:640px;font-size:clamp(16px,1.6vw,19px)}.lede strong{color:var(--text-strong);font-weight:600}.cta-row{flex-wrap:wrap;gap:12px;margin-top:28px;display:flex}.btn{cursor:pointer;border:1px solid #0000;border-radius:12px;align-items:center;gap:8px;padding:12px 20px;font-size:14.5px;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--accent), #5e3dff);color:#fff;box-shadow:0 10px 24px -10px var(--accent)}.btn-primary:hover{color:#fff;box-shadow:0 18px 30px -12px var(--accent);transform:translateY(-2px)}.btn-ghost{background:var(--bg-elev);border-color:var(--border);color:var(--text-strong)}.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}.quick-meta{color:var(--text-muted);flex-wrap:wrap;gap:18px;margin:32px 0 0;padding:0;font-size:14px;list-style:none;display:flex}.quick-meta a{color:var(--text-muted);border-bottom:1px dashed var(--border-strong)}.quick-meta a:hover{color:var(--accent);border-color:var(--accent)}.about-grid{gap:24px;max-width:760px;font-size:17px;display:grid}.about-grid strong{color:var(--text-strong)}.stats{grid-template-columns:repeat(3,1fr);gap:16px;margin-top:16px;display:grid}.stat{background:var(--bg-elev);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:14px;flex-direction:column;gap:4px;padding:20px;display:flex}.stat strong{color:var(--text-strong);font-size:32px;font-weight:700}.stat span{color:var(--text-muted);font-size:13px}@media (width<=640px){.stats{grid-template-columns:1fr}}.timeline{flex-direction:column;gap:28px;margin:0;padding:0;list-style:none;display:flex;position:relative}.timeline:before{content:"";background:linear-gradient(to bottom, var(--accent), transparent);opacity:.4;width:2px;position:absolute;top:6px;bottom:6px;left:9px}.t-item{padding-left:40px;position:relative}.t-marker{background:var(--bg);border:2px solid var(--accent);width:20px;height:20px;box-shadow:0 0 0 4px var(--accent-bg);border-radius:50%;position:absolute;top:22px;left:0}.t-card{background:var(--bg-elev);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:16px;padding:22px 24px;transition:all .25s}.t-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong);transform:translateY(-2px)}.t-card header{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:14px;display:flex}.t-card h3{font-size:18px;font-weight:600}.t-card .at{color:var(--accent);font-weight:500}.t-meta{font-family:var(--mono);color:var(--text-muted);font-size:12.5px}.t-card ul{color:var(--text);flex-direction:column;gap:8px;margin:0 0 16px;padding-left:18px;display:flex}.t-card ul li::marker{color:var(--accent)}.chip-row{flex-wrap:wrap;gap:6px;display:flex}.chip{font-size:12px;font-family:var(--mono);background:var(--accent-bg);color:var(--accent);border:1px solid color-mix(in oklab, var(--accent) 30%, transparent);border-radius:999px;padding:4px 10px}.skills-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;display:grid}.skill-card{background:var(--bg-elev);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:16px;padding:20px;transition:all .25s}.skill-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-2px)}.skill-card h4{text-transform:uppercase;letter-spacing:.14em;color:var(--text-muted);margin-bottom:14px;font-size:13px;font-weight:600}.skill-card ul{flex-wrap:wrap;gap:6px;margin:0;padding:0;list-style:none;display:flex}.skill-card li{font-size:13px;font-family:var(--mono);background:var(--bg-soft);border:1px solid var(--border);color:var(--text-strong);border-radius:8px;padding:5px 10px}.edu-grid{grid-template-rows:auto auto;grid-template-columns:1.2fr 1fr;gap:16px;display:grid}.edu-card,.edu-list{background:var(--bg-elev);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:16px;padding:22px 24px}.edu-card.big{grid-area:1/1}.edu-list{grid-area:1/2/span 2}.edu-card:not(.big){grid-area:2/1}.edu-card h4,.edu-list h4{margin-bottom:10px;font-size:16px}.muted{color:var(--text-muted);font-size:14px}.edu-list ul{flex-direction:column;gap:12px;margin:0;padding:0;list-style:none;display:flex}.edu-list li{background:var(--bg-soft);border:1px solid var(--border);border-radius:10px;padding:10px 12px;font-size:14.5px}.lang-list{flex-direction:column;gap:14px;margin:0;padding:0;list-style:none;display:flex}.lang-row{color:var(--text-strong);justify-content:space-between;margin-bottom:6px;font-size:14px;display:flex}.bar{background:var(--bg-soft);border:1px solid var(--border);border-radius:999px;height:6px;overflow:hidden}.bar-fill{background:linear-gradient(90deg, var(--accent), var(--accent-2));border-radius:999px;height:100%;transition:width .6s}@media (width<=720px){.edu-grid{grid-template-columns:1fr}.edu-card.big,.edu-list,.edu-card:not(.big){grid-area:auto/1}}.contact{padding-bottom:64px}.contact-lede{color:var(--text-muted);max-width:640px;margin-bottom:28px;font-size:17px}.contact-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;display:grid}.contact-card{background:var(--bg-elev);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:16px;flex-direction:column;gap:4px;padding:22px;transition:all .25s;display:flex}.contact-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md);color:inherit;transform:translateY(-2px)}.c-label{font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--text-muted);font-size:12px}.c-value{color:var(--text-strong);word-break:break-all;font-size:16px;font-weight:600}.footer{border-top:1px solid var(--border);color:var(--text-muted);flex-wrap:wrap;justify-content:space-between;gap:12px;margin-top:64px;padding:28px 0 36px;font-size:13px;display:flex}.back-top{color:var(--text-muted)}.back-top:hover{color:var(--accent)}.section{opacity:0;animation:.6s forwards rise;animation-timeline:view();animation-range:entry cover 30%;transform:translateY(16px)}@keyframes rise{to{opacity:1;transform:none}}@supports not (animation-timeline:view()){.section{opacity:1;animation:none;transform:none}}
