*,*:before,*:after{box-sizing:border-box}body{margin:0}#root{width:100%}:root{--bg: #0f1117;--bg-card: #161b24;--border: rgba(255, 255, 255, .07);--border-card: rgba(255, 255, 255, .09);--accent: #5b9bd5;--accent-dim: rgba(91, 155, 213, .12);--text: #b8c4cf;--text-muted: #5e6e7d;--text-bright: #dde4ea;--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--font-sans: "Inter", "Segoe UI", system-ui, sans-serif;--radius: 6px;--radius-lg: 10px;--transition: .2s ease;--max-w: 720px}[data-theme=light]{--bg: #fafbfc;--bg-card: #ffffff;--border: rgba(0, 0, 0, .07);--border-card: rgba(0, 0, 0, .1);--accent: #2563a8;--accent-dim: rgba(37, 99, 168, .08);--text: #3a4452;--text-muted: #8292a0;--text-bright: #1a2330}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;background:var(--bg);color:var(--text);transition:background .3s ease,color .3s ease;font-family:var(--font-sans);font-size:16px;line-height:1.75;-webkit-font-smoothing:antialiased}body{background:var(--bg);overflow-x:hidden;transition:background .3s ease}a{color:inherit;text-decoration:none}.bg-grid{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background-image:radial-gradient(circle,var(--border) 1px,transparent 1px);background-size:28px 28px;-webkit-mask-image:radial-gradient(ellipse 70% 50% at 50% 0%,black 20%,transparent 100%);mask-image:radial-gradient(ellipse 70% 50% at 50% 0%,black 20%,transparent 100%);opacity:.6}.theme-toggle{position:fixed;top:20px;right:24px;z-index:100;display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:var(--radius);border:1px solid var(--border-card);background:var(--bg-card);color:var(--text-muted);cursor:pointer;transition:color var(--transition),border-color var(--transition);padding:0}.theme-toggle:hover{color:var(--accent);border-color:var(--accent)}.page{position:relative;min-height:100vh}.container{position:relative;z-index:1;max-width:var(--max-w);margin:0 auto;padding:0 24px 80px}.divider{height:1px;background:var(--border);margin:52px 0}.fade-section{opacity:0;transform:translateY(14px);transition:opacity .55s ease,transform .55s ease}.fade-section.is-visible{opacity:1;transform:none}.section-title{font-family:var(--font-sans);font-size:1rem;font-weight:600;letter-spacing:0;color:var(--text-bright);margin-bottom:24px;display:flex;align-items:center;gap:14px}.section-title:after{content:"";flex:1;height:1px;background:var(--border)}.hero{padding-top:88px;padding-bottom:8px}.hero-name-block{opacity:0;transform:translateY(12px);transition:opacity .6s ease,transform .6s ease;margin-bottom:36px}.hero-name-block.visible{opacity:1;transform:none}.hero-name{font-family:var(--font-sans);font-size:clamp(1.75rem,5vw,2.5rem);font-weight:700;color:var(--text-bright);letter-spacing:-.02em;line-height:1.15}.hero-tagline{margin-top:8px;font-size:.9rem;color:var(--text-muted)}.hero-body{display:flex;gap:32px;align-items:flex-start;opacity:0;transform:translateY(12px);transition:opacity .6s ease .18s,transform .6s ease .18s}.hero-body.visible{opacity:1;transform:none}.avatar-wrap{position:relative;flex-shrink:0}.avatar{width:108px;height:108px;border-radius:var(--radius);object-fit:cover;border:1px solid var(--border-card);display:block}.avatar-glow{display:none}.bio-text{flex:1}.bio-text p{font-size:.9rem;color:var(--text);margin-bottom:12px;line-height:1.7}.bio-text p:last-of-type{margin-bottom:18px}.bio-text a{color:var(--accent);text-underline-offset:2px;transition:opacity var(--transition)}.bio-text a:hover{opacity:.75}.contact-row{display:flex;gap:14px}.contact-icon{color:var(--text-muted);transition:color var(--transition);display:flex;align-items:center}.contact-icon:hover{color:var(--accent)}.timeline{list-style:none;border-left:1px solid var(--border-card);padding-left:22px;margin-left:2px}.timeline-item{position:relative;display:grid;grid-template-columns:60px 1fr;align-items:baseline;gap:16px;padding:9px 0}.timeline-dot{position:absolute;left:-26px;top:17px;width:5px;height:5px;border-radius:50%;background:var(--accent)}.timeline-date{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted);white-space:nowrap}.timeline-text{font-size:.9rem;color:var(--text)}.inline-link{color:var(--accent);text-underline-offset:2px;transition:opacity var(--transition)}.inline-link:hover{opacity:.75}.projects-grid{display:grid;grid-template-columns:1fr;gap:14px}.project-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius);transition:border-color var(--transition)}.project-card:hover{border-color:#ffffff29}[data-theme=light] .project-card:hover{border-color:#0000002e}.project-card-inner{padding:20px 22px}.project-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:4px}.project-title{font-size:.92rem;font-weight:600;color:var(--text-bright)}.project-links{display:flex;gap:12px;flex-shrink:0;padding-top:2px}.icon-link{color:var(--text-muted);transition:color var(--transition);display:flex;align-items:center}.icon-link:hover{color:var(--accent)}.project-subtitle{font-size:.83rem;color:var(--text-muted);margin-bottom:8px;line-height:1.5}.project-venue{display:inline-block;font-size:.75rem;color:var(--accent);background:var(--accent-dim);border-radius:3px;padding:1px 7px;margin-bottom:10px}.project-desc{font-size:.87rem;color:var(--text);margin-bottom:14px;line-height:1.65}.tech-stack{display:flex;flex-wrap:wrap;gap:5px}.tech-tag{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted);background:#ffffff08;border:1px solid var(--border);border-radius:3px;padding:1px 7px}[data-theme=light] .tech-tag{background:#00000008}.pub-card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--radius);padding:20px 22px;transition:border-color var(--transition)}.pub-card:hover{border-color:#ffffff29}[data-theme=light] .pub-card:hover{border-color:#0000002e}.pub-title{font-size:.9rem;font-weight:600;color:var(--text-bright);margin-bottom:6px;line-height:1.55}.pub-authors{font-size:.83rem;color:var(--text-muted);margin-bottom:6px}.pub-me{color:var(--text);font-style:italic}.pub-venue{font-size:.83rem;color:var(--text-muted);margin-bottom:12px}.pub-venue-tag{font-size:.75rem;color:var(--accent);background:var(--accent-dim);border-radius:3px;padding:1px 7px;margin-right:6px}.pub-links{display:flex;gap:10px}.pub-link{font-family:var(--font-mono);font-size:.75rem;color:var(--accent);border:1px solid var(--accent);border-radius:3px;padding:2px 9px;opacity:.8;transition:opacity var(--transition),background var(--transition)}.pub-link:hover{opacity:1;background:var(--accent-dim)}.footer{margin-top:64px;padding-top:20px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;font-size:.78rem;color:var(--text-muted)}.footer-links{display:flex;gap:14px}.footer-link{color:var(--text-muted);transition:color var(--transition);display:flex;align-items:center}.footer-link:hover{color:var(--accent)}@media (max-width: 600px){.hero{padding-top:60px}.hero-name{font-size:1.65rem}.hero-body{flex-direction:column;gap:20px}.avatar{width:88px;height:88px}.container{padding:0 18px 60px}.timeline-item{grid-template-columns:52px 1fr;gap:10px}.footer{flex-direction:column;align-items:flex-start}}
