:root{color-scheme:light}body{margin:0;min-height:100vh}*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #2563eb;--primary-dark: #1e40af;--primary-light: #3b82f6;--dark: #1f2937;--text: #374151;--light-gray: #6b7280;--bg: #ffffff;--bg-subtle: #f9fafb;--border: #e5e7eb;--success: #10b981;--warning: #f59e0b}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif;font-size:15px;line-height:1.6;color:var(--text);background:var(--bg)}.portfolio{min-height:100vh;opacity:0;animation:pageLoad .6s ease-out forwards}.portfolio.loaded{opacity:1}@keyframes pageLoad{0%{opacity:0}to{opacity:1}}.nav{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);padding:.5rem;position:sticky;top:0;z-index:100;box-shadow:0 1px 3px #0000000d}.nav-container{max-width:1000px;margin:0 auto;padding:.95rem 1rem;display:flex;justify-content:space-between;align-items:center}.logo{height:32px;width:auto;display:block;transition:transform .2s ease}.logo:hover{transform:scale(1.05)}.nav-links{display:flex;gap:1.5rem;align-items:center}.nav-links a{text-decoration:none;color:var(--text);font-size:.9rem;font-weight:500;transition:color .2s,transform .2s;display:flex;align-items:center;gap:.35rem}.nav-links a:hover{color:var(--primary);transform:translateY(-1px)}.hero{padding:2.5rem 0 1.5rem;background:linear-gradient(to bottom,var(--bg) 0%,var(--bg-subtle) 100%)}.hero-container{max-width:1000px;margin:0 auto;padding:0 1.2rem}.hero-header{display:flex;gap:2rem;align-items:flex-start;margin-bottom:1.25rem}.hero-photo img{width:140px;height:auto;border-radius:8px;object-fit:cover;border:1px solid var(--border);transition:transform .3s ease,box-shadow .3s ease}.hero-photo img:hover{transform:scale(1.03);box-shadow:0 8px 16px #0000001a}.hero-info{flex:1}.hero-title{font-size:1.75rem;font-weight:700;margin-bottom:.25rem;color:var(--dark);background:linear-gradient(135deg,var(--dark) 0%,var(--primary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:1rem;color:var(--light-gray);margin-bottom:.75rem}.hero-affiliation{font-size:.9rem;color:var(--text);margin-bottom:.5rem}.hero-links{display:flex;gap:1rem;flex-wrap:wrap}.hero-link{color:var(--primary);text-decoration:none;font-size:.9rem;font-weight:500;transition:color .2s,transform .2s;display:flex;align-items:center;gap:.35rem}.hero-link:hover{color:var(--primary-dark)}.lab-link{color:var(--primary);font-weight:500;text-decoration:none;transition:color .2s;position:relative}.lab-link:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--primary);transition:width .3s ease}.lab-link:hover:after{width:100%}.hero-bio{font-size:.95rem;line-height:1.7;color:var(--text);max-width:1000px}.hero-bio p{margin-bottom:.75rem}.currently-exploring{font-size:.9rem;color:var(--text);padding:1rem;background:linear-gradient(135deg,#2563eb0a,#2563eb05);border-radius:6px;border-left:3px solid var(--primary);margin-top:1rem}.currently-exploring strong{color:var(--primary)}.container{max-width:1000px;margin:0 auto;padding:2.25rem 1.2rem}.section-title{font-size:1.5rem;font-weight:700;margin-bottom:1.5rem;color:var(--dark);display:flex;align-items:center;gap:.5rem}.news{background:var(--bg);border-top:1px solid var(--border)}.news-scroll{padding-right:.5rem}.news-toggle{display:block;margin:.75rem auto 0;background:none;border:none;color:var(--light-gray);font-size:.8rem;font-weight:500;cursor:pointer;padding:.4rem .8rem;border-radius:4px;transition:color .2s,background .2s;font-family:inherit}.news-toggle:hover{color:var(--primary);background:var(--bg-subtle)}.news-year-group{margin-bottom:1rem}.news-year-label{font-size:.8rem;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem;padding-bottom:.3rem;border-bottom:1px solid var(--border)}.news-item{display:flex;gap:.75rem;padding:.45rem 0;align-items:baseline;line-height:1.5}.news-date{font-size:.75rem;font-weight:700;color:var(--light-gray);background:var(--bg-subtle);padding:.15rem .45rem;border-radius:3px;min-width:36px;text-align:center;flex-shrink:0;font-family:SF Mono,Fira Code,Courier New,monospace}.news-emoji{font-size:.9rem;flex-shrink:0}.news-text{font-size:.9rem;color:var(--text)}.news-link{color:var(--primary);text-decoration:none;font-weight:500;transition:color .2s}.news-link:hover{color:var(--primary-dark);text-decoration:underline}.research{background:var(--bg);border-top:1px solid var(--border)}.highlighted-paper{position:relative;background:linear-gradient(to right,#2563eb05 20%,#2563eb03);padding-left:1rem;margin-left:-1rem}.paper-links{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem;align-items:center}.paper-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:4px;font-size:.8rem;font-weight:500;text-decoration:none;transition:all .2s ease;border:1px solid}.arxiv-badge{background:linear-gradient(135deg,#b31b1b,#d32f2f);color:#fff;border-color:#b31b1b;font-weight:600;box-shadow:0 1px 3px #b31b1b33}.arxiv-badge:hover{background:linear-gradient(135deg,#c62828,#e53935);box-shadow:0 2px 4px #b31b1b4d;transform:translateY(-1px)}.badge-id{font-family:Courier New,monospace;font-size:.75rem;opacity:.95}.code-badge{background:#24292e;color:#fff;border-color:#24292e}.code-badge:hover{background:#3d444d;border-color:#3d444d;transform:translateY(-1px)}.poster-badge{background:var(--bg-subtle);color:var(--text);border-color:var(--border)}.poster-badge:hover{background:var(--border);border-color:var(--light-gray);transform:translateY(-1px)}.webpage-badge{background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;border-color:#2563eb;font-weight:600;box-shadow:0 1px 3px #2563eb33}.webpage-badge:hover{background:linear-gradient(135deg,#1d4ed8,#2563eb);box-shadow:0 2px 4px #2563eb4d;transform:translateY(-1px)}.read-more-badge{background:var(--bg-subtle);color:var(--primary);border-color:var(--primary);cursor:pointer;font-family:inherit}.read-more-badge:hover{background:var(--primary);color:#fff;transform:translateY(-1px)}.cite-badge{background:var(--bg-subtle);color:var(--text);border-color:var(--border);cursor:pointer;font-family:inherit}.cite-badge:hover{background:var(--border);border-color:var(--light-gray);transform:translateY(-1px)}.paper-link-badge{background:var(--bg-subtle);color:var(--text);border-color:var(--border)}.paper-link-badge:hover{background:var(--border);border-color:var(--light-gray);transform:translateY(-1px)}.project-images{margin:1.25rem 0;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.project-image-container{width:100%;border-radius:6px;overflow:hidden;border:1px solid var(--border);background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center}.project-image-container img{width:100%;height:auto;display:block}.image-caption{font-size:.85rem;color:var(--light-gray);text-align:center;padding:.5rem;background:var(--bg);font-style:italic}.research-list{display:flex;flex-direction:column;gap:1.5rem}.research-item{display:flex;gap:1.25rem;opacity:1;transition:opacity .3s ease}.research-year{font-size:.85rem;color:var(--light-gray);font-weight:600;min-width:60px;padding-top:.25rem}.research-content{flex:1}.research-header{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.4rem}.research-title-link{text-decoration:none;flex:1;transition:opacity .2s ease}.research-title-link:hover{opacity:.7}.research-title{font-size:1rem;font-weight:600;color:var(--dark);line-height:1.4}.research-expanded{margin-top:1.5rem;padding:1.5rem;background:var(--bg-subtle);border-radius:6px;animation:expandFade .3s ease}@keyframes expandFade{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.expanded-section{margin-bottom:1.25rem}.expanded-section:last-child{margin-bottom:0}.expanded-section h4{font-size:.9rem;font-weight:600;color:var(--dark);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.expanded-section p{font-size:.95rem;color:var(--text);line-height:1.7}.expanded-image-placeholder{background:var(--bg);border:2px dashed var(--border);border-radius:6px;padding:2rem;text-align:center;margin:1rem 0;color:var(--light-gray);font-size:.85rem}.demo-note{font-size:.85rem;color:var(--light-gray);font-style:italic;padding:.75rem;background:var(--bg);border-radius:4px;margin-top:1rem}.status-badge{font-size:.75rem;padding:.25rem .6rem;border-radius:4px;font-weight:600;white-space:nowrap;flex-shrink:0}.status-badge.published,.status-badge.presented,.status-badge.accepted{background:#d1fae5;color:#065f46}.status-badge.pending-submission{background:#e0e7ff;color:#3730a3}.status-badge.in-progress{background:#dbeafe;color:#1e40af}.status-badge.under-review{background:#fef3c7;color:#92400e}.status-badge.pre-print{background:#dbeafe;color:#1e40af}.research-authors{font-size:.9rem;color:var(--text);margin-bottom:.35rem}.research-authors .me{font-weight:600;color:var(--primary)}.research-venue{font-size:.85rem;color:var(--light-gray);font-style:italic;margin-bottom:.5rem}.research-description{font-size:.9rem;color:var(--text);line-height:1.6;margin-bottom:.5rem}.experience{background:var(--bg-subtle);border-top:1px solid var(--border)}.experience-list{display:flex;flex-direction:column;gap:1.5rem}.experience-item{display:flex;gap:1.25rem;padding:.5rem 0}.experience-date{font-size:.85rem;color:var(--light-gray);font-weight:600;min-width:100px;padding-top:.25rem}.experience-content{flex:1}.experience-title{font-size:1rem;font-weight:600;color:var(--dark);margin-bottom:.25rem;display:flex;align-items:center;gap:.5rem}.experience-icon{font-size:1.2rem}.experience-org{font-size:.9rem;color:var(--text);margin-bottom:.5rem}.experience-description{font-size:.9rem;color:var(--text);line-height:1.6;margin-bottom:.5rem}.projects{background:var(--bg-subtle);border-top:1px solid var(--border)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.25rem}.project-card-link{text-decoration:none;cursor:pointer}.project-card{padding:1.25rem 0;border-bottom:1px solid var(--border);transition:transform .2s ease;height:100%;display:flex;flex-direction:column}.project-card-link:hover .project-card{transform:translate(4px)}.project-title{font-size:1rem;font-weight:600;color:var(--dark);margin-bottom:.5rem}.project-description{font-size:.9rem;color:var(--text);line-height:1.6;margin-bottom:.75rem}.project-tech{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.75rem}.tech-tag{font-size:.75rem;color:var(--light-gray);padding:.2rem .5rem;border-radius:4px;transition:color .2s ease}.tech-tag:hover{color:var(--primary)}.project-link{font-size:.85rem;color:var(--primary);text-decoration:none;font-weight:500;display:inline-flex;align-items:center;gap:.3rem;transition:all .2s;margin-top:auto}.project-card-link:hover .project-link{color:var(--primary-dark)}.misc{background:var(--bg);border-top:1px solid var(--border)}.misc-content{max-width:640px}.misc-content p{font-size:.93rem;color:var(--text);line-height:1.7;margin-bottom:.75rem}.misc-content em{font-style:italic}.contact{background:var(--bg);padding:3rem 0;text-align:center}.contact-description{font-size:.95rem;color:var(--text);margin-bottom:1.5rem}.contact-links{display:flex;gap:2rem;justify-content:center;flex-wrap:wrap}.contact-link{color:var(--primary);text-decoration:none;font-size:.95rem;font-weight:500;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;border-radius:8px;border:1px solid transparent}.contact-link:hover{color:var(--primary-dark);background:var(--bg-subtle);transform:translateY(-2px)}.footer{background:transparent;border-top:1px solid var(--border);text-align:center;padding:2rem 1.5rem}.footer p{font-size:.85rem;color:var(--light-gray)}@media (max-width: 768px){body{font-size:14px}.container{padding:1.75rem 1.25rem}.hero{padding:2rem 0 1.25rem}.hero-container{padding:0 1.25rem}.hero-header{flex-direction:column;align-items:center;text-align:center;margin-bottom:1rem}.hero-info{display:flex;flex-direction:column;align-items:center}.hero-title{font-size:1.4rem}.hero-subtitle{font-size:.85rem}.hero-affiliation{font-size:.8rem}.hero-links{justify-content:center;gap:.65rem}.hero-link{font-size:.8rem}.hero-bio{font-size:.85rem}.hero-bio p{margin-bottom:.6rem}.currently-exploring{font-size:.8rem;padding:.75rem;margin-top:.75rem}.hero-photo img{width:110px}.section-title{font-size:1.25rem;margin-bottom:1.25rem}.news-item{flex-direction:column;gap:.25rem;padding:.5rem 0}.news-date{font-size:.75rem}.news-text{font-size:.83rem}.news-scroll{padding-right:0}.news-item{flex-wrap:wrap;gap:.35rem;padding:.4rem 0}.news-date{font-size:.65rem;min-width:32px;padding:.1rem .35rem}.news-emoji{font-size:.8rem}.news-text{font-size:.8rem;flex-basis:100%;padding-left:0}.news-year-label,.news-toggle{font-size:.75rem}.research-item,.experience-item{flex-direction:column;gap:.5rem;padding:.75rem 0}.research-year,.experience-date{min-width:auto;font-size:.75rem}.research-title{font-size:.9rem}.research-authors,.research-venue,.research-description{font-size:.8rem}.research-header{flex-direction:column;align-items:flex-start;gap:.5rem}.status-badge{font-size:.7rem;padding:.2rem .5rem}.research-expanded{padding:1.25rem}.expanded-section{margin-bottom:1rem}.expanded-section h4,.expanded-section p{font-size:.8rem}.paper-links{gap:.4rem}.paper-badge{font-size:.75rem;padding:3px 8px}.experience-title{font-size:.9rem}.experience-org,.experience-description{font-size:.8rem}.projects-grid{grid-template-columns:1fr;gap:0}.project-title{font-size:.9rem}.project-description{font-size:.8rem}.misc-content p{font-size:.83rem}.contact-description{font-size:.85rem}.contact-links{gap:1rem}.contact-link{font-size:.8rem;padding:.75rem}.nav-container{flex-direction:column;gap:.65rem;padding:.75rem 1rem}.nav-links{gap:.75rem;flex-wrap:wrap;justify-content:center}.nav-links a{font-size:.8rem}.footer{padding:1.5rem 1.25rem}.footer p{font-size:.75rem}.image-caption{font-size:.75rem;padding:.4rem}}@media (max-width: 480px){body{font-size:13px}.section-title{font-size:1.15rem}.hero-title{font-size:1.25rem}.hero-subtitle{font-size:.8rem}.hero-affiliation{font-size:.75rem}.hero-bio{font-size:.8rem}.currently-exploring{font-size:.75rem}.research-title{font-size:.85rem}.container{padding:1.5rem 1rem}.nav-links a{font-size:.75rem}.hero-links{gap:.5rem}.hero-link{font-size:.75rem}}
