@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #ffffff;--bg-alt: #f8f9fb;--text: #111827;--text-muted: #6b7280;--border: #e5e7eb;--accent: #1d4ed8;--tag-bg: #f3f4f6;--max-w: 960px}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);line-height:1.7;font-size:16px;-webkit-font-smoothing:antialiased}.app{min-height:100vh}.container{max-width:var(--max-w);margin:0 auto;padding:0 1.5rem;width:100%}.nav{position:sticky;top:0;background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);z-index:100;padding:.875rem 0}.nav-inner{display:flex;align-items:center;justify-content:space-between}.nav-brand{font-size:.9375rem;font-weight:700;color:var(--text);letter-spacing:-.02em}.nav-links{display:flex;gap:1.75rem}.nav-link{font-size:.875rem;font-weight:500;color:var(--text-muted);text-decoration:none;transition:color .15s}.nav-link:hover{color:var(--text)}.hero{padding:5rem 0 4.5rem}.hero-inner{display:flex;align-items:center;justify-content:space-between;gap:4rem}.hero-text{flex:1;min-width:0}.hero-greeting{font-size:1rem;color:var(--text-muted);font-weight:400;margin-bottom:.5rem}.hero-name{font-size:3rem;font-weight:700;letter-spacing:-.035em;line-height:1.1;color:var(--text);margin-bottom:.75rem}.hero-title{font-size:1.05rem;color:var(--text-muted);font-weight:400;margin-bottom:1.5rem}.hero-bio{font-size:.9625rem;color:var(--text-muted);line-height:1.8;max-width:520px;margin-bottom:1.75rem}.hero-contact{display:flex;flex-wrap:wrap;gap:1.25rem;margin-bottom:1.5rem;font-size:.875rem}.contact-item{color:var(--text-muted);text-decoration:none}.contact-item:hover{color:var(--accent)}.hero-socials{display:flex;flex-wrap:wrap;gap:.625rem}.social-btn{display:inline-block;padding:.4rem .95rem;font-size:.8375rem;font-weight:500;border:1.5px solid var(--accent);border-radius:6px;color:var(--accent);text-decoration:none;transition:border-color .15s,background .15s,color .15s}.social-btn:hover{border-color:var(--text);background:var(--text);color:#fff}.hero-photo-wrap{flex-shrink:0;width:190px;height:260px;overflow:hidden;display:flex;justify-content:center;align-items:flex-start}.hero-photo{width:100%;height:auto;display:block;filter:grayscale(100%);margin-top:-5%;mask-image:linear-gradient(to right,transparent 0%,black 5%,black 95%,transparent 100%),linear-gradient(to bottom,transparent 0%,black 3%,black 97%,transparent 100%);mask-composite:intersect;-webkit-mask-image:linear-gradient(to right,transparent 0%,black 5%,black 95%,transparent 100%),linear-gradient(to bottom,transparent 0%,black 3%,black 97%,transparent 100%);-webkit-mask-composite:source-in}.section{padding:4rem 0;border-top:1px solid var(--border)}.bg-alt{background:var(--bg-alt)}.section-heading{font-size:1.625rem;font-weight:700;letter-spacing:-.025em;color:var(--text);margin-bottom:2.5rem}.skills-groups{display:flex;flex-direction:column;gap:1.75rem}.skill-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:.75rem}.tags{display:flex;flex-wrap:wrap;gap:.5rem}.tag{display:inline-block;padding:.3rem .75rem;background:var(--tag-bg);color:var(--text);border-radius:4px;font-size:.8375rem;font-weight:500}.tag-dark{background:var(--text);color:#fff}.timeline{display:flex;flex-direction:column}.tl-item{display:grid;grid-template-columns:160px 24px 1fr;gap:0 1rem;padding-bottom:2.5rem}.tl-item:last-child{padding-bottom:0}.tl-date{font-size:.8rem;color:var(--text-muted);font-weight:500;text-align:right;padding-top:.25rem;line-height:1.4}.tl-line{display:flex;flex-direction:column;align-items:center;position:relative}.tl-dot{width:9px;height:9px;background:var(--text);border-radius:50%;flex-shrink:0;margin-top:.3rem;z-index:1}.tl-line:after{content:"";position:absolute;top:.85rem;bottom:-2.5rem;width:1px;background:var(--border)}.tl-item:last-child .tl-line:after{display:none}.tl-body{padding-bottom:0}.tl-role{font-size:1rem;font-weight:600;margin-bottom:.2rem;line-height:1.4}.tl-org{font-size:.875rem;color:var(--text-muted);font-weight:500;margin-bottom:.5rem}.tl-desc{font-size:.875rem;color:var(--text-muted);line-height:1.75}.edu-list{display:flex;flex-direction:column;gap:2rem}.edu-item{display:grid;grid-template-columns:130px 1fr;gap:0 2rem;align-items:start}.edu-year{font-size:.8rem;color:var(--text-muted);font-weight:500;padding-top:.25rem}.edu-degree{font-size:1rem;font-weight:600;margin-bottom:.2rem}.edu-school{font-size:.875rem;color:var(--text-muted);font-weight:500;margin-bottom:.3rem}.edu-detail{font-size:.85rem;color:var(--text-muted);line-height:1.65}.pub-list{list-style:none;display:flex;flex-direction:column;gap:1rem;margin-bottom:1.75rem;padding:0}.pub-item{display:flex;gap:1rem;align-items:baseline}.pub-year{flex-shrink:0;font-size:.775rem;font-weight:600;color:var(--text-muted);width:2.75rem}.pub-text{font-size:.9rem;color:var(--text);line-height:1.65}.view-all-link{font-size:.875rem;font-weight:600;color:var(--accent);text-decoration:none}.view-all-link:hover{text-decoration:underline}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem}.project-card{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:1.5rem;display:flex;flex-direction:column;gap:.4rem;transition:box-shadow .2s,transform .2s}.project-card:hover{box-shadow:0 4px 20px #00000012;transform:translateY(-2px)}.project-name{font-size:.9375rem;font-weight:600}.project-desc{font-size:.85rem;color:var(--text-muted);flex:1}.project-link{font-size:.85rem;font-weight:600;color:var(--accent);text-decoration:none;margin-top:.25rem}.project-link:hover{text-decoration:underline}.footer{border-top:1px solid var(--border);padding:2rem 0;text-align:center}.footer p{font-size:.85rem;color:var(--text-muted)}@media(max-width:700px){.hero{padding:3rem 0}.hero-inner{flex-direction:column-reverse;gap:2rem;text-align:center}.hero-name{font-size:2.25rem}.hero-bio{max-width:100%}.hero-contact,.hero-socials{justify-content:center}.hero-photo-wrap{width:125px;height:170px}.hero-photo{width:100%;height:auto}.tl-item{grid-template-columns:1fr;padding-left:1.25rem;border-left:2px solid var(--border);gap:.2rem}.tl-date{text-align:left;order:-1}.tl-line{display:none}.tl-item:last-child{border-left-color:var(--border)}.edu-item{grid-template-columns:1fr;gap:.25rem}.nav-links{gap:1rem}.nav-link{font-size:.8rem}.section-heading{font-size:1.375rem}}
