*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-text: #1a1a1a;--color-text-secondary: #555;--color-text-muted: #888;--color-border: #e5e5e5;--color-bg: #ffffff;--color-chip-bg: #f5f5f5;--color-chip-text: #333;--color-link: #1a1a1a;--color-link-hover: #000;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--max-width: 680px}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);color:var(--color-text);background:var(--color-bg);line-height:1.7}a{color:var(--color-link);text-decoration:none;transition:color .15s ease}a:hover{color:var(--color-link-hover)}.page{min-height:100vh;display:flex;justify-content:center;padding:0 24px}.container{width:100%;max-width:var(--max-width);padding:80px 0 60px}.hero{margin-bottom:64px}.hero-name{font-size:2rem;font-weight:700;letter-spacing:-.03em;line-height:1.2;margin-bottom:4px}.hero-title{font-size:1rem;font-weight:400;color:var(--color-text-secondary);margin-bottom:12px}.hero-tagline{font-size:.95rem;color:var(--color-text-muted);margin-bottom:20px;max-width:520px}.hero-links{display:flex;flex-wrap:wrap;gap:16px}.hero-links a{display:inline-flex;align-items:center;gap:6px;font-size:.875rem;font-weight:500;color:var(--color-text-secondary);transition:color .15s ease}.hero-links a:hover{color:var(--color-text)}.section{margin-bottom:56px}.section-title{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);margin-bottom:20px;padding-bottom:8px;border-bottom:1px solid var(--color-border)}.about-text{font-size:.95rem;color:var(--color-text-secondary);line-height:1.8}.chips{display:flex;flex-wrap:wrap;gap:8px}.chip{display:inline-block;font-size:.8rem;font-weight:500;padding:4px 14px;border-radius:100px;background:var(--color-chip-bg);color:var(--color-chip-text);transition:background .15s ease}.chip:hover{background:#eaeaea}.projects{display:flex;flex-direction:column;gap:32px}.project-card{padding:24px 0;border-bottom:1px solid var(--color-border)}.project-card:last-child{border-bottom:none}.project-header{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:8px}.project-title{font-size:1.05rem;font-weight:600;letter-spacing:-.01em}.project-year{font-size:.8rem;color:var(--color-text-muted);white-space:nowrap}.project-description{font-size:.9rem;color:var(--color-text-secondary);line-height:1.7;margin-bottom:12px}.project-images{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.project-image{width:100%;max-height:420px;object-fit:contain;border-radius:8px;border:1px solid var(--color-border);background:var(--color-chip-bg)}.project-tech{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.tech-tag{font-size:.7rem;font-weight:500;padding:2px 10px;border-radius:4px;background:var(--color-chip-bg);color:var(--color-text-muted);letter-spacing:.02em}.project-links{display:flex;gap:16px}.project-link{display:inline-flex;align-items:center;gap:5px;font-size:.8rem;font-weight:500;color:var(--color-text-muted);transition:color .15s ease}.project-link:hover{color:var(--color-text)}.project-video{position:relative;width:100%;padding-bottom:56.25%;margin-bottom:12px;border-radius:8px;overflow:hidden;background:#f5f5f5}.project-video iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.publications{list-style:none}.publication{padding:16px 0;border-bottom:1px solid var(--color-border);display:flex;flex-direction:column;gap:2px}.publication:last-child{border-bottom:none}.pub-title{font-size:.95rem;font-weight:600}.pub-title a{text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}.pub-authors{font-size:.85rem;color:var(--color-text-secondary)}.pub-venue{font-size:.8rem;color:var(--color-text-muted);font-style:italic}.placeholder-text{font-size:.9rem;color:var(--color-text-muted);font-style:italic}.footer{margin-top:40px;padding-top:20px;border-top:1px solid var(--color-border)}.footer p{font-size:.75rem;color:var(--color-text-muted)}@media(max-width:640px){.container{padding:48px 0 40px}.hero-name{font-size:1.6rem}.project-header{flex-direction:column;gap:2px}}
