@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500&family=DM+Serif+Display&display=swap";@import"https://use.typekit.net/beo4wgf.css";:root{--color-bg: #f0f0ee;--color-card: #ffffff;--color-text: #1a1a1a;--color-text-muted: #888;--color-border: #ddd;--color-accent-publications: #ce5834;--font-body: "DM Sans", sans-serif;--font-title: "articulat-cf", sans-serif;--radius-card: 20px;--tab-height: 10px;--tab-width: 90px;--nav-top-offset: 5px;--common-padding: 3em 4em}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--color-bg);color:var(--color-text);font-family:var(--font-body);font-weight:300;min-height:100vh;display:flex;align-items:flex-start;justify-content:center;padding:40px 24px 80px;line-height:1.5}.bg-frame{background:var(--color-card);border-radius:var(--radius-card);width:100%;max-width:960px;min-height:560px;position:relative;box-shadow:0 4px 40px #0003;overflow:hidden;display:flex;flex-direction:column}.site-header{display:flex;align-items:flex-start;gap:50px;padding:var(--common-padding)}.site-name{font-family:var(--font-title);font-weight:300;font-style:normal;font-size:clamp(2rem,4vw,2.6rem);line-height:1;white-space:nowrap;flex-shrink:0}.tab-nav{display:flex;gap:30px 10px;padding-top:var(--nav-top-offset);flex-wrap:wrap;margin-left:auto}.tab-btn{min-width:min-content;display:flex;flex-direction:column;align-items:flex-start;gap:5px;background:none;border:none;cursor:pointer;padding:0;font-family:var(--font-body);text-decoration:none;text-align:justify}.tab-bar{display:block;width:100%;min-width:var(--tab-width);height:var(--tab-height);transition:transform .15s ease,opacity .15s ease;transform-origin:top center;border-radius:5%}.tab-btn:hover .tab-bar{transform:scaleY(1.5)}.tab-btn.active .tab-bar{transform:scaleY(5)}.tab-label{font-size:.78rem;font-weight:500;line-height:1.2;letter-spacing:.01em;max-width:calc(var(--tab-width) - 2*5px);color:var(--color-text);z-index:1;transform-origin:top center;transition:transform .15s ease,opacity .15s ease}.tab-btn .tab-bar{background:var(--tab-color)}.tab-btn.active .tab-label{transform:translate(5px);font-weight:700}.tab-content{flex:1;padding:var(--common-padding)}.tab-panel{display:none;animation:fadeIn .2s ease}.tab-panel.active{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.tab-panel h2{font-family:var(--font-body);font-size:1.5rem;font-weight:100;margin-bottom:16px}.tab-panel p{font-size:.95rem;color:#444;max-width:600px}.about-layout{display:flex;align-items:flex-start;flex-direction:row;gap:40px}.about-photo{width:180px;height:180px;object-fit:cover;border-radius:100%;flex-shrink:0;box-shadow:0 4px 40px #0003}.pub-list{display:flex;flex-direction:column;gap:30px;line-height:1.3}.pub-title{font-weight:500;font-size:.95rem;margin-bottom:4px}.pub-venue{font-style:italic}.pub-summary{font-size:.88rem;color:#555;line-height:1.6}.pub-link{display:inline-block;margin-top:6px;font-size:.8rem;font-weight:500;color:var(--color-accent-publications);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .15s}.pub-link:hover{border-color:var(--color-accent-publications)}.pub-meta{display:flex;flex-direction:column;gap:2px;margin-bottom:4px;font-size:.85rem}ol.pub-list{list-style:none;counter-reset:pub-counter}ol.pub-list .pub-item{counter-increment:pub-counter;position:relative;padding-left:36px}ol.pub-list .pub-item:before{content:"[" counter(pub-counter) "]";position:absolute;left:0;top:0;font-weight:500;font-size:.95rem}.pub-abstract{margin-top:8px;overflow:hidden}.pub-abstract summary{font-size:.8rem;font-weight:500;color:var(--color-accent-publications);cursor:pointer;user-select:none;list-style:none;display:flex;align-items:center;gap:6px}.pub-abstract summary:before{content:"▶";font-size:.6rem;transition:transform .2s ease;display:inline-block}.pub-abstract[open] summary:before{transform:rotate(90deg)}.pub-abstract p{margin-top:8px;font-size:.85rem;color:#555;border-left:2px solid var(--color-border);padding-left:12px}.project-grid{list-style:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:24px}.project-card{display:flex;flex-direction:column;border-radius:10px;overflow:hidden;border:1px solid var(--color-border);transition:transform .2s ease,box-shadow .2s ease}.project-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #00000014}.project-thumb{width:100%;aspect-ratio:16 / 9;object-fit:cover}.project-info{padding:14px 16px;display:flex;flex-direction:column;gap:4px}.project-title{font-weight:500;font-size:.95rem}.project-year{font-size:.8rem;color:var(--color-text-muted)}.project-tags{list-style:none;display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.project-tags li{font-size:.72rem;font-weight:500;padding:2px 8px;border-radius:99px;background:var(--color-bg);color:var(--color-text-muted)}.project-description{font-size:.85rem;color:#555;line-height:1.6;margin-top:4px}.site-footer{border-top:3.5px solid var(--color-border);border-image:linear-gradient(to right,#000,#fff) 1;padding:18px 48px;display:flex;align-items:center;margin-top:auto;flex-wrap:wrap;gap:12px}.social-links{display:flex;gap:18px}.social-links a{color:var(--color-text);opacity:.65;transition:opacity .15s;display:flex;align-items:center}.social-links a:hover{opacity:1}.footer-legal{font-size:.75rem;color:var(--color-text-muted);text-align:right;margin-left:auto;min-width:max-content}.footer-legal a{color:inherit;text-decoration:none}.footer-legal a:hover{text-decoration:underline}.legal-content{padding:40px 48px;max-width:680px;display:flex;flex-direction:column;gap:16px}.legal-content h1{font-family:var(--font-display);font-size:1.8rem;font-weight:400}.legal-content h2{font-size:1rem;font-weight:500;margin-top:8px}.legal-content h3{font-size:.95rem;font-weight:500}@media(max-width:640px){body{padding:16px 12px 60px}.site-header{flex-direction:column;gap:20px;padding:24px 24px 0}.tab-content{padding:24px 24px 40px}.site-footer{padding:16px 24px;gap:12px}.tab-bar{width:72px}.about-layout{flex-direction:column-reverse;align-items:center;gap:20px}}
