:root{--color-page: #050507;--color-shell: #0B0B10;--color-card: #111118;--color-card-hover: #16161E;--color-input: #0D0D13;--color-fg: #F2F3F5;--color-fg-muted: #A1A5B0;--color-fg-subtle: #6B6F7D;--color-fg-faint: #3F4250;--color-accent: #6896FF;--color-accent-hover: #7FA8FF;--color-accent-dim: rgba(104, 150, 255, .1);--color-accent-glow: rgba(104, 150, 255, .25);--color-border: rgba(255, 255, 255, .06);--color-border-hover: rgba(255, 255, 255, .12);--color-ring: rgba(104, 150, 255, .35);--shell-gap: 14px;--shell-pad: 14px;--header-h: 68px;--sidebar-w: 280px;--footer-h: 52px;--radius-shell: 16px;--radius-card: 14px;--radius-sm: 10px;--font-display: "Syne", "Times New Roman", serif;--font-body: "Outfit", system-ui, -apple-system, sans-serif;--ease: cubic-bezier(.16, 1, .3, 1);--ease-smooth: cubic-bezier(.23, 1, .32, 1)}[data-theme=light]{--color-page: #D8DEE8;--color-shell: #F4F6FA;--color-card: #FFFFFF;--color-card-hover: #F8FAFD;--color-input: #FFFFFF;--color-fg: #0A0C14;--color-fg-muted: #3E4557;--color-fg-subtle: #5A6274;--color-fg-faint: #B8BFCF;--color-accent: #2E5CE6;--color-accent-hover: #1E4BD6;--color-accent-dim: rgba(46, 92, 230, .08);--color-accent-glow: rgba(46, 92, 230, .22);--color-border: rgba(10, 12, 20, .08);--color-border-hover: rgba(10, 12, 20, .16);--color-ring: rgba(46, 92, 230, .35)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background:var(--color-page);color:var(--color-fg);overflow:hidden;height:100vh;cursor:none;transition:background-color .4s var(--ease)}a{color:inherit;text-decoration:none;cursor:none}button{font-family:inherit;cursor:none;border:none;background:none;color:inherit;font-size:inherit}img{max-width:100%;display:block}::selection{background:var(--color-accent);color:#fff}:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px}@media(max-width:900px){body{cursor:auto;overflow:auto}a,button{cursor:auto}}.cursor-glow{position:fixed;pointer-events:none;z-index:9999;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,var(--color-accent-glow) 0%,transparent 70%);transform:translate(-50%,-50%);mix-blend-mode:screen;opacity:.7}.cursor-dot{position:fixed;pointer-events:none;z-index:10000;width:8px;height:8px;border-radius:50%;background:var(--color-accent);transform:translate(-50%,-50%);transition:width .2s var(--ease-smooth),height .2s var(--ease-smooth),background-color .2s}.cursor-dot.is-hovering{width:40px;height:40px;background:var(--color-accent-dim);border:1.5px solid var(--color-accent)}@media(max-width:900px){.cursor-glow,.cursor-dot{display:none!important}}.grain-overlay{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:9998;opacity:.025;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px}[data-theme=light] .grain-overlay{opacity:.04}.shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--header-h) 1fr var(--footer-h);grid-template-areas:"header header" "sidebar main" "footer footer";gap:var(--shell-gap);padding:var(--shell-pad);height:100vh;width:100vw}@media(max-width:900px){.shell{display:block;height:auto;min-height:100vh;padding:10px}}.panel{background:var(--color-shell);border:1px solid var(--color-border);border-radius:var(--radius-shell);transition:background-color .4s var(--ease),border-color .4s}.header{grid-area:header;display:flex;align-items:center;justify-content:space-between;padding:0 24px;gap:16px}.header-logo{font-family:var(--font-display);font-size:20px;font-weight:800;letter-spacing:-.03em;color:var(--color-fg);flex-shrink:0}.header-logo .accent{color:var(--color-accent)}.header-nav{display:flex;align-items:center;gap:4px;flex:1;justify-content:flex-end}.nav-btn{padding:8px 16px;font-size:13px;font-weight:500;color:var(--color-fg-muted);border-radius:var(--radius-sm);transition:all .3s var(--ease-smooth);letter-spacing:-.01em;position:relative;white-space:nowrap}.nav-btn:hover,.nav-btn.is-active{color:var(--color-fg);background:var(--color-accent-dim)}.nav-btn.is-active:after{content:"";position:absolute;bottom:2px;left:50%;transform:translate(-50%);width:16px;height:2px;background:var(--color-accent);border-radius:1px}.theme-btn{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--color-fg-muted);border:1px solid var(--color-border);transition:all .3s var(--ease-smooth);margin-left:8px;flex-shrink:0}.theme-btn:hover{color:var(--color-accent);border-color:var(--color-accent);background:var(--color-accent-dim)}.mobile-toggle{display:none;width:40px;height:40px;align-items:center;justify-content:center;color:var(--color-fg);border-radius:var(--radius-sm)}@media(max-width:900px){.header{padding:0 16px}.header-nav{display:none}.mobile-toggle{display:flex}}.mobile-menu{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:var(--color-page);flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:20px}.mobile-menu.is-open{display:flex}.mobile-menu .nav-btn{font-size:18px;padding:14px 28px}.mobile-menu .mobile-close{position:absolute;top:20px;right:20px;color:var(--color-fg);width:44px;height:44px;display:flex;align-items:center;justify-content:center}.sidebar{grid-area:sidebar;display:flex;flex-direction:column;align-items:center;padding:36px 20px 24px;overflow-y:auto}.sidebar::-webkit-scrollbar{width:0}@media(max-width:900px){.sidebar{flex-direction:row;flex-wrap:wrap;justify-content:center;padding:20px 16px;gap:14px;margin:10px 0}}.profile-photo{position:relative;width:150px;height:150px;margin-bottom:22px;flex-shrink:0}@media(max-width:900px){.profile-photo{width:96px;height:96px;margin-bottom:0}}.profile-photo-ring{position:absolute;top:-6px;right:-6px;bottom:-6px;left:-6px;border-radius:50%;border:2px solid transparent;border-top-color:var(--color-accent);border-right-color:var(--color-accent);animation:ring-spin 8s linear infinite}.profile-photo-ring-2{position:absolute;top:-12px;right:-12px;bottom:-12px;left:-12px;border-radius:50%;border:1px solid transparent;border-bottom-color:var(--color-ring);border-left-color:var(--color-ring);animation:ring-spin 14s linear infinite reverse}@keyframes ring-spin{to{transform:rotate(360deg)}}.profile-photo-inner{width:100%;height:100%;border-radius:50%;overflow:hidden;background:var(--color-card);border:3px solid var(--color-border-hover);position:relative}.profile-photo-inner img{width:100%;height:100%;object-fit:cover}.profile-photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0a0f1c,#131c33,#1d2847);position:relative;overflow:hidden}[data-theme=light] .profile-photo-placeholder{background:linear-gradient(135deg,#d0d8e8,#b8c4da,#9fafca)}.profile-photo-placeholder:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 40% 30%,var(--color-accent-glow),transparent 60%)}.profile-photo-initials{font-family:var(--font-display);font-size:48px;font-weight:800;color:#ffffff26;position:relative;z-index:1;letter-spacing:-.04em}[data-theme=light] .profile-photo-initials{color:#0a0c1440}@media(max-width:900px){.profile-photo-initials{font-size:30px}}.profile-name{font-family:var(--font-display);font-size:19px;font-weight:700;letter-spacing:-.02em;text-align:center;margin-bottom:2px;color:var(--color-fg)}.profile-role{font-size:12px;color:var(--color-accent);font-weight:500;text-align:center;margin-bottom:22px;letter-spacing:-.01em}@media(max-width:900px){.profile-name{font-size:17px}.profile-role{margin-bottom:0}}.social-row{display:flex;gap:8px;margin-bottom:28px;flex-wrap:wrap;justify-content:center}.social-btn{width:38px;height:38px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--color-fg-muted);border:1px solid var(--color-border);transition:all .35s var(--ease-smooth)}.social-btn:hover{color:var(--color-accent);border-color:var(--color-accent);background:var(--color-accent-dim);transform:translateY(-2px);box-shadow:0 6px 16px var(--color-accent-glow)}@media(max-width:900px){.social-row{margin-bottom:0}}.sidebar-quote{margin-top:auto;padding-top:22px;border-top:1px solid var(--color-border);text-align:center;width:100%}.sidebar-quote blockquote{font-family:var(--font-display);font-size:13px;font-weight:500;font-style:italic;color:var(--color-fg-muted);line-height:1.6;margin-bottom:6px}.sidebar-quote cite{font-size:11px;color:var(--color-fg-subtle);font-style:normal;font-weight:500}@media(max-width:900px){.sidebar-quote{display:none}}.main{grid-area:main;overflow-y:auto;overflow-x:hidden;scroll-behavior:smooth}.main::-webkit-scrollbar{width:6px}.main::-webkit-scrollbar-track{background:transparent}.main::-webkit-scrollbar-thumb{background:var(--color-fg-faint);border-radius:3px}.main::-webkit-scrollbar-thumb:hover{background:var(--color-fg-subtle)}@media(max-width:900px){.main{overflow-y:visible;height:auto;min-height:60vh;margin-top:10px}}.section{padding:48px 40px 64px;border-bottom:1px solid var(--color-border);position:relative}.section:last-child{border-bottom:none;padding-bottom:48px}@media(max-width:768px){.section{padding:36px 20px 48px}}.section-label{font-family:var(--font-display);font-size:11px;font-weight:700;color:var(--color-accent);letter-spacing:.1em;text-transform:uppercase;display:flex;align-items:center;gap:12px;margin-bottom:16px}.section-label:before{content:"";width:28px;height:1.5px;background:var(--color-accent)}.section-heading{font-family:var(--font-display);font-size:clamp(28px,3.5vw,42px);font-weight:800;letter-spacing:-.03em;line-height:1.1;margin-bottom:10px;color:var(--color-fg)}.section-heading .ghost{-webkit-text-stroke:1.5px var(--color-fg);color:transparent}.section-subtitle{font-size:15px;color:var(--color-fg-muted);font-weight:400;line-height:1.7;max-width:560px;margin-bottom:36px}.reveal{opacity:0;transform:translateY(36px);transition:opacity .8s var(--ease),transform .8s var(--ease)}.reveal.is-visible{opacity:1;transform:translateY(0)}.reveal-d1{transition-delay:.06s}.reveal-d2{transition-delay:.12s}.reveal-d3{transition-delay:.18s}.reveal-d4{transition-delay:.24s}.reveal-d5{transition-delay:.3s}.reveal-d6{transition-delay:.36s}.about-bio p{font-size:15px;color:var(--color-fg-muted);line-height:1.75;font-weight:400;margin-bottom:14px}.about-bio p:last-child{margin-bottom:0}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:28px}@media(max-width:640px){.stat-grid{grid-template-columns:1fr 1fr}}.stat-card{padding:18px 14px;border-radius:var(--radius-card);background:var(--color-card);border:1px solid var(--color-border);text-align:center;transition:all .35s var(--ease-smooth)}.stat-card:hover{border-color:var(--color-border-hover);background:var(--color-card-hover);transform:translateY(-2px)}.stat-card-value{font-family:var(--font-display);font-size:26px;font-weight:800;letter-spacing:-.02em;color:var(--color-fg);line-height:1.1}.stat-card-label{font-size:11px;color:var(--color-fg-subtle);margin-top:4px;font-weight:500;letter-spacing:.02em}.skills-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:32px}@media(max-width:768px){.skills-grid{grid-template-columns:1fr 1fr}}@media(max-width:480px){.skills-grid{grid-template-columns:1fr}}.skill-group{padding:20px;border-radius:var(--radius-card);background:var(--color-card);border:1px solid var(--color-border);transition:all .35s var(--ease-smooth)}.skill-group:hover{border-color:var(--color-border-hover)}.skill-group-title{font-family:var(--font-display);font-size:12px;font-weight:700;color:var(--color-accent);margin-bottom:12px;letter-spacing:.02em;text-transform:uppercase}.skill-item{font-size:13px;color:var(--color-fg-muted);padding:6px 0;border-bottom:1px solid var(--color-border);display:flex;align-items:center;gap:8px;font-weight:400}.skill-item:last-child{border-bottom:none;padding-bottom:0}.skill-dot{width:5px;height:5px;border-radius:50%;background:var(--color-accent);flex-shrink:0}.timeline{margin-top:4px}.timeline-item{display:grid;grid-template-columns:170px 1fr;gap:28px;padding:26px 0;border-bottom:1px solid var(--color-border);transition:padding-left .35s var(--ease-smooth)}.timeline-item:first-child{border-top:1px solid var(--color-border)}.timeline-item:hover{padding-left:8px}@media(max-width:640px){.timeline-item{grid-template-columns:1fr;gap:6px;padding:20px 0}}.timeline-period{font-size:12px;color:var(--color-fg-subtle);font-weight:500;padding-top:4px;letter-spacing:.02em}.timeline-role{font-family:var(--font-display);font-size:18px;font-weight:700;letter-spacing:-.02em;margin-bottom:2px;color:var(--color-fg)}.timeline-company{font-size:14px;color:var(--color-accent);font-weight:500;margin-bottom:10px}.timeline-desc{font-size:13px;color:var(--color-fg-muted);line-height:1.65;font-weight:400;margin-bottom:12px}.timeline-tags{display:flex;flex-wrap:wrap;gap:6px}.pill{padding:4px 12px;border-radius:100px;font-size:11px;font-weight:500;color:var(--color-fg-muted);background:var(--color-accent-dim);border:1px solid var(--color-border);letter-spacing:.01em}.education-subhead{font-family:var(--font-display);font-size:16px;font-weight:700;margin-top:36px;margin-bottom:8px;color:var(--color-fg);letter-spacing:-.01em}.education-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media(max-width:640px){.education-grid{grid-template-columns:1fr}}.education-card{padding:18px;border-radius:var(--radius-card);background:var(--color-card);border:1px solid var(--color-border);transition:all .3s var(--ease-smooth)}.education-card:hover{border-color:var(--color-border-hover)}.education-degree{font-family:var(--font-display);font-size:14px;font-weight:700;margin-bottom:2px;color:var(--color-fg)}.education-school{font-size:13px;color:var(--color-fg-muted);font-weight:400}.education-year{font-size:11px;color:var(--color-fg-subtle);margin-top:4px;font-weight:500}.card-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}@media(max-width:900px){.card-grid{grid-template-columns:1fr}}@media(min-width:1400px){.card-grid{grid-template-columns:repeat(3,1fr)}}.project-card,.research-card{border-radius:var(--radius-card);background:var(--color-card);border:1px solid var(--color-border);overflow:hidden;transition:border-color .4s var(--ease-smooth),transform .4s var(--ease-smooth),box-shadow .4s var(--ease-smooth);display:flex;flex-direction:column}.project-card:hover,.research-card:hover{border-color:var(--color-border-hover);transform:translateY(-4px);box-shadow:0 16px 40px #00000040}[data-theme=light] .project-card:hover,[data-theme=light] .research-card:hover{box-shadow:0 16px 40px #0a0c141a}.card-visual{height:140px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.card-visual-bg{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.08;transition:opacity .5s}.project-card:hover .card-visual-bg,.research-card:hover .card-visual-bg{opacity:.2}.card-visual-icon{width:52px;height:52px;border-radius:14px;border:2px solid;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:22px;font-weight:800;position:relative;z-index:1;transition:transform .5s var(--ease-smooth),border-radius .5s var(--ease-smooth);background:var(--color-card)}.project-card:hover .card-visual-icon,.research-card:hover .card-visual-icon{transform:rotate(90deg) scale(1.08);border-radius:50%}.card-body{padding:22px;flex:1;display:flex;flex-direction:column}.card-meta{font-size:10px;font-weight:600;letter-spacing:.08em;color:var(--color-fg-subtle);margin-bottom:8px;text-transform:uppercase;display:flex;gap:10px;flex-wrap:wrap}.card-title{font-family:var(--font-display);font-size:20px;font-weight:700;letter-spacing:-.02em;margin-bottom:2px;color:var(--color-fg)}.card-subtitle{font-size:13px;color:var(--color-fg-subtle);margin-bottom:12px;font-weight:400}.card-description{font-size:13px;color:var(--color-fg-muted);line-height:1.65;font-weight:400;margin-bottom:16px;flex:1}.card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}.card-links{display:flex;gap:16px;flex-wrap:wrap;align-items:center}.card-link{font-size:12px;font-weight:500;color:var(--color-fg-muted);display:flex;align-items:center;gap:5px;transition:color .3s}.card-link:hover{color:var(--color-accent)}.card-visual--has-thumb{height:200px;padding:0;background:#0a0d14;cursor:pointer}[data-theme=light] .card-visual--has-thumb{background:#e4e8f0}.card-visual-thumb{width:100%;height:100%;object-fit:cover;object-position:top center;opacity:.9;transition:opacity .4s var(--ease-smooth)}.research-card:hover .card-visual-thumb{opacity:.3}.card-visual--has-thumb:after{content:"Click to view";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.9);font-family:var(--font-display);font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--color-fg);background:#00000080;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);padding:10px 22px;border-radius:100px;border:1px solid rgba(255,255,255,.12);opacity:0;transition:opacity .35s var(--ease-smooth),transform .35s var(--ease-smooth);pointer-events:none;z-index:2}[data-theme=light] .card-visual--has-thumb:after{background:#ffffffb3;color:var(--color-fg);border-color:#00000014}.research-card:hover .card-visual--has-thumb:after{opacity:1;transform:translate(-50%,-50%) scale(1)}.thumb-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99999;display:flex;align-items:center;justify-content:center;background:#000000e0;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);cursor:zoom-out;padding:40px;animation:lb-fade-in .3s var(--ease-smooth) forwards}@keyframes lb-fade-in{0%{opacity:0}to{opacity:1}}[data-theme=light] .thumb-lightbox{background:#dce1ebeb}.thumb-lightbox-img{max-width:min(92vw,650px);max-height:88vh;object-fit:contain;border-radius:8px;box-shadow:0 24px 80px #0009;animation:lb-scale-in .4s var(--ease-smooth) forwards;cursor:default}@keyframes lb-scale-in{0%{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}[data-theme=light] .thumb-lightbox-img{box-shadow:0 24px 80px #00000026}.thumb-lightbox-close{position:absolute;top:20px;right:24px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#ffffff1a;border:1px solid rgba(255,255,255,.12);color:#fff;cursor:pointer;transition:background .3s,transform .3s}.thumb-lightbox-close:hover{background:#fff3;transform:scale(1.05)}[data-theme=light] .thumb-lightbox-close{background:#0000000f;border-color:#0000001a;color:var(--color-fg)}.card-link--download{color:var(--color-accent)!important;font-weight:600!important;transition:color .3s,transform .3s}.card-link--download:hover{transform:translateY(-1px)}.card-link--venue{color:var(--color-fg-subtle)!important;margin-left:auto}.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:36px}@media(max-width:900px){.contact-grid{grid-template-columns:1fr;gap:28px}}.contact-info h3{font-family:var(--font-display);font-size:20px;font-weight:700;margin-bottom:10px;color:var(--color-fg);letter-spacing:-.02em}.contact-info p{font-size:14px;color:var(--color-fg-muted);line-height:1.7;font-weight:400;margin-bottom:24px}.contact-detail{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--color-fg-muted);margin-bottom:10px}.contact-detail svg{color:var(--color-accent);flex-shrink:0}.form-group{margin-bottom:16px}.form-label{display:block;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-fg-subtle);margin-bottom:6px}.form-input,.form-textarea{width:100%;padding:11px 14px;background:var(--color-input);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:14px;color:var(--color-fg);font-family:var(--font-body);font-weight:400;outline:none;transition:border-color .3s,box-shadow .3s}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-fg-subtle)}.form-input:focus,.form-textarea:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-dim)}.form-input.has-error,.form-textarea.has-error{border-color:#ef4444}.form-textarea{resize:vertical;min-height:90px}.form-error{font-size:12px;color:#ef4444;margin-top:4px}.submit-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;background:var(--color-accent);color:#fff;font-size:13px;font-weight:600;border-radius:var(--radius-sm);transition:all .35s var(--ease-smooth);margin-top:6px;letter-spacing:.02em}.submit-btn:hover:not(:disabled){background:var(--color-accent-hover);box-shadow:0 6px 20px var(--color-accent-glow);transform:translateY(-1px)}.submit-btn:disabled{opacity:.6}.submit-btn.is-sent{background:#22c55e}.footer{grid-area:footer;display:flex;align-items:center;justify-content:center;gap:10px;font-size:12px;color:var(--color-fg-subtle);padding:0 20px}.footer a{color:var(--color-fg-muted);transition:color .3s}.footer a:hover{color:var(--color-accent)}.footer-sep{opacity:.4}@media(max-width:900px){.footer{flex-wrap:wrap;padding:16px;text-align:center;height:auto;margin-top:10px}.footer-sep{display:none}}
