@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap";:root{--font-sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SFMono-Regular", Menlo, Consolas, monospace;--bg: #f8fafc;--surface: #ffffff;--surface-2: #f1f5f9;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-secondary: #475569;--text-muted: #64748b;--accent: #2563eb;--accent-hover: #1d4ed8;--accent-soft: #eff6ff;--on-accent: #ffffff;--radius: 14px;--radius-sm: 8px;--maxw: 1180px;--sidebar-w: 264px;--topbar-h: 60px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .04), 0 1px 3px rgba(15, 23, 42, .06);--shadow-md: 0 6px 16px rgba(15, 23, 42, .08), 0 2px 6px rgba(15, 23, 42, .05);font-family:var(--font-sans);line-height:1.6;color:var(--text);font-synthesis:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-height:100vh;background:var(--bg);color:var(--text);font-family:var(--font-sans)}h1,h2,h3,h4{margin:0;color:var(--text);line-height:1.2;letter-spacing:-.02em;font-weight:700}p{margin:0}a{color:var(--accent);text-decoration:none;transition:color .15s ease}a:hover{color:var(--accent-hover)}img{max-width:100%;display:block}button{font-family:inherit}::selection{background:var(--accent);color:var(--on-accent)}a:focus-visible,button:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-w);height:100vh;z-index:999;background:var(--surface);border-right:1px solid var(--border);box-sizing:border-box;padding:2rem 1.4rem;display:flex;flex-direction:column;overflow-y:auto}.sidebar-profile{text-align:center;margin-bottom:2rem}.profile-image{width:96px;height:96px;border-radius:50%;object-fit:cover;margin:0 auto;background:var(--surface-2);border:1px solid var(--border);padding:6px}.profile-name{margin-top:.9rem;font-size:1.05rem;font-weight:700;color:var(--text);letter-spacing:-.01em}.profile-description{margin-top:.25rem;font-size:.82rem;line-height:1.45;color:var(--text-secondary)}.sidebar-nav{margin-top:.5rem}.sidebar-nav ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.25rem}.nav-link{display:flex;align-items:center;gap:.7rem;padding:.6rem .75rem;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.92rem;font-weight:500;transition:background-color .15s ease,color .15s ease}.nav-link:hover{background:var(--surface-2);color:var(--text)}.nav-link.active{background:var(--accent-soft);color:var(--accent);font-weight:600}.nav-icon{font-size:1.05rem;flex-shrink:0}.sidebar-bottom{display:flex;justify-content:center;align-items:center;gap:1.4rem;margin-top:auto;padding-top:1.5rem;border-top:1px solid var(--border)}.sidebar-bottom a{font-size:1.25rem;color:var(--text-muted);transition:color .15s ease,transform .15s ease}.sidebar-bottom a:hover{color:var(--accent);transform:translateY(-2px)}.topbar,.sidebar-backdrop{display:none}@media (max-width: 860px){.topbar{position:fixed;top:0;left:0;right:0;height:var(--topbar-h);z-index:1001;display:flex;align-items:center;justify-content:space-between;padding:0 1.1rem;background:#ffffffd9;backdrop-filter:saturate(180%) blur(10px);-webkit-backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--border)}.topbar-brand{font-weight:700;font-size:1.05rem;color:var(--text);letter-spacing:-.01em}.topbar-toggle{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:1.15rem;cursor:pointer}.sidebar{top:var(--topbar-h);height:calc(100vh - var(--topbar-h));transform:translate(-100%);transition:transform .25s ease;box-shadow:var(--shadow-md)}.sidebar.is-open{transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;inset:var(--topbar-h) 0 0 0;z-index:998;background:#0f172a66}}.home-clear{font-weight:600}.articles-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:1.5rem}@media (max-width: 520px){.articles-list{grid-template-columns:1fr}}.article-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.article-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--border-strong)}.article-thumb{position:relative;height:190px;background:var(--surface-2);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:center;padding:.75rem}.article-image{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}.article-year{position:absolute;top:.6rem;left:.6rem;font-family:var(--font-mono);font-size:.7rem;font-weight:500;letter-spacing:.04em;color:var(--text-secondary);background:#ffffffe6;border:1px solid var(--border);border-radius:999px;padding:.15rem .55rem}.article-body{display:flex;flex-direction:column;flex:1;padding:1.25rem 1.25rem 1.1rem}.article-title{font-size:1.02rem;font-weight:700;line-height:1.32;color:var(--text);letter-spacing:-.01em}.article-authors{margin-top:.5rem;font-size:.78rem;line-height:1.45;color:var(--text-muted)}.article-summary{margin-top:.7rem;font-size:.86rem;line-height:1.55;color:var(--text-secondary);display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.article-categories{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.9rem}.category-pill-home{font-family:var(--font-mono);font-size:.68rem;color:var(--text-secondary);background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:.22rem .6rem;transition:background-color .15s ease,color .15s ease,border-color .15s ease}.category-pill-home:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.read-more-button{align-self:flex-start;margin-top:auto;padding-top:1rem;font-size:.85rem;font-weight:600;color:var(--accent)}.article-card:hover .read-more-button{color:var(--accent-hover)}.categories-list{display:flex;flex-wrap:wrap;gap:.75rem}.category-pill{display:inline-flex;align-items:center;gap:.6rem;background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:.55rem .7rem .55rem 1.05rem;color:var(--text);font-size:1rem;font-weight:500;transition:border-color .15s ease,background-color .15s ease,color .15s ease,transform .15s ease}.category-pill:hover{border-color:var(--accent);background:var(--accent-soft);color:var(--accent);transform:translateY(-2px)}.category-name{letter-spacing:-.01em}.category-count{font-family:var(--font-mono);font-size:.78rem;font-weight:500;color:var(--text-secondary);background:var(--surface-2);border-radius:999px;min-width:1.6rem;height:1.6rem;display:inline-flex;align-items:center;justify-content:center;padding:0 .45rem}.category-pill:hover .category-count{background:var(--surface);color:var(--accent)}.timeline{list-style:none;margin:0;padding:0;border-left:2px solid var(--border);margin-left:.5rem}.timeline-item{position:relative;display:grid;grid-template-columns:120px 1fr;align-items:start;gap:1.25rem;padding:0 0 1.75rem 1.75rem}.timeline-item:last-child{padding-bottom:0}.timeline-marker{position:absolute;left:-7px;top:.55rem;width:12px;height:12px;border-radius:50%;background:var(--surface);border:2px solid var(--accent)}.timeline-date{font-family:var(--font-mono);font-size:.78rem;color:var(--text-muted);padding-top:.45rem;white-space:nowrap}.timeline-article{text-align:left;font-family:inherit;font-size:.95rem;font-weight:500;line-height:1.45;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.65rem .9rem;cursor:pointer;transition:border-color .15s ease,background-color .15s ease,color .15s ease,transform .15s ease}.timeline-article:hover{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-hover);transform:translate(2px)}@media (max-width: 600px){.timeline-item{grid-template-columns:1fr;gap:.4rem}.timeline-date{padding-top:0}}.about{max-width:820px}.about-content{display:flex;align-items:flex-start;gap:2.25rem}.about-image{width:150px;height:150px;object-fit:cover;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);flex-shrink:0}.about-text{flex:1;color:var(--text-secondary);font-family:var(--font-sans)}.about-text p{line-height:1.7;margin-bottom:1.2rem;font-size:.98rem}.about-text strong{color:var(--text)}.about-text a{font-weight:600;border-bottom:1px solid transparent;transition:border-color .15s ease}.about-text a:hover{border-bottom-color:var(--accent)}.circle-list{list-style:none;padding:0;margin:1.5rem 0;counter-reset:circle-count}.circle-list li{counter-increment:circle-count;position:relative;margin-bottom:1.25rem;padding-left:3.25rem;line-height:1.65;font-size:.96rem}.circle-list li:before{content:counter(circle-count);position:absolute;left:0;top:.1rem;width:2.1rem;height:2.1rem;background:var(--accent);color:var(--on-accent);border-radius:50%;text-align:center;line-height:2.1rem;font-weight:700;font-size:.95rem}.contact-prompt{margin-top:2rem;font-size:1.05rem;color:var(--text)}.about-icons{margin-top:1.5rem;display:flex;gap:1.1rem}.contact-icon{width:26px;height:26px;color:var(--text-muted);transition:color .2s ease,transform .2s ease}.contact-icon:hover{color:var(--accent);transform:translateY(-2px)}@media (max-width: 860px){.about-content{flex-direction:column;align-items:center;text-align:center}.about-image{width:120px;height:120px}.circle-list li{text-align:left}.about-icons{justify-content:center}}.funded-container{max-width:820px}.projects-grid{display:grid;grid-template-columns:1fr;gap:1.25rem}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.6rem 1.75rem;transition:box-shadow .18s ease,border-color .18s ease}.project-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong)}.project-card h2{margin:0 0 .85rem;font-size:1.2rem;font-weight:700;letter-spacing:-.01em;color:var(--text)}.project-funder{display:flex;align-items:center;gap:.6rem;margin:0 0 1.1rem;font-size:.9rem;color:var(--text-secondary)}.funder-label{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);background:var(--accent-soft);border-radius:999px;padding:.2rem .55rem}.project-summary{margin:0 0 .9rem;font-size:.94rem;line-height:1.65;color:var(--text-secondary);text-align:left}.project-summary:last-child{margin-bottom:0}.App{min-height:100vh}.main-content{margin-left:var(--sidebar-w);min-height:100vh}@media (max-width: 860px){.main-content{margin-left:0;padding-top:var(--topbar-h)}}.page{max-width:var(--maxw);margin:0 auto;padding:3rem 2.5rem 4rem}.page-header{margin-bottom:2.5rem}.page-kicker{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:.6rem}.page-title{font-size:clamp(1.7rem,1.2rem + 1.8vw,2.5rem);font-weight:800;letter-spacing:-.03em}.page-sub{margin-top:.6rem;color:var(--text-secondary);font-size:.95rem}@media (max-width: 860px){.page{padding:2rem 1.25rem 3rem}}
