/* ============================================================
   Inner page shared components (Research / Publications /
   Community / CV)
   ============================================================ */

/* ---------- Page header ---------- */
.page-head{ padding-top:clamp(56px,9vw,120px); padding-bottom:clamp(40px,6vw,72px); }
.page-head .eyebrow{ margin-bottom:1.6rem; }
.page-head h1{
  font-size:clamp(2.6rem,6.5vw,5rem); font-weight:300; line-height:1; letter-spacing:-.025em;
}
.page-head .lead{ margin-top:1.8rem; max-width:60ch; }
.page-head-grid{ display:grid; grid-template-columns:1fr; gap:2rem; }

/* breadcrumb-ish index */
.page-index{ font-family:var(--mono); font-size:11.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); }

/* ---------- Prose ---------- */
.prose{ max-width:64ch; }
.prose p{ margin-bottom:1.3em; color:var(--ink-soft); font-size:1.12rem; line-height:1.65; }
.prose p:last-child{ margin-bottom:0; }
.prose strong{ font-weight:500; color:var(--ink); }
.prose em{ font-style:italic; }

/* ---------- Definition / fact grid ---------- */
.deflist{ display:grid; gap:0; border-top:1px solid var(--line); }
.deflist .row{
  display:grid; grid-template-columns:200px 1fr; gap:clamp(12px,3vw,40px);
  padding:1.3rem 0; border-bottom:1px solid var(--line); align-items:baseline;
}
@media (max-width:620px){ .deflist .row{ grid-template-columns:1fr; gap:.4rem; } }
.deflist dt{ font-family:var(--mono); font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }
.deflist dd{ font-size:1.08rem; color:var(--ink); line-height:1.5; }
.deflist dd .sub{ color:var(--muted); font-size:.95rem; display:block; margin-top:.3rem; }

/* ---------- Research streams ---------- */
.stream{
  display:grid; grid-template-columns:90px 1fr; gap:clamp(20px,4vw,56px);
  padding:clamp(36px,5vw,64px) 0; border-top:1px solid var(--line);
  align-items:start;
}
@media (max-width:720px){ .stream{ grid-template-columns:1fr; gap:14px; } }
.stream-no{ font-family:var(--mono); font-size:13px; letter-spacing:.1em; color:var(--accent); padding-top:.5rem; }
.stream h3{ font-size:clamp(1.6rem,3vw,2.3rem); font-weight:400; letter-spacing:-.015em; line-height:1.1; }
.stream .stream-body p{ color:var(--ink-soft); font-size:1.1rem; line-height:1.6; margin-top:1rem; max-width:60ch; }
.stream .stream-rep{ margin-top:1.6rem; display:grid; gap:.7rem; }
.stream .rep{
  font-family:var(--mono); font-size:12px; letter-spacing:.02em; color:var(--ink-soft);
  display:flex; gap:.8rem; align-items:baseline; line-height:1.45;
}
.stream .rep::before{ content:"▸"; color:var(--accent); font-size:.8em; }
.stream .rep .v{ color:var(--muted); }

/* ---------- Entry / timeline lists (talks, experience, teaching) ---------- */
.entries{ list-style:none; display:grid; border-top:1px solid var(--line); }
.entry{
  display:grid; grid-template-columns:130px 1fr auto; gap:clamp(12px,3vw,36px);
  padding:1.5rem 0; border-bottom:1px solid var(--line); align-items:baseline;
}
@media (max-width:680px){ .entry{ grid-template-columns:1fr; gap:.35rem; } .entry .entry-tag{ justify-self:start; } }
.entry .entry-when{ font-family:var(--mono); font-size:12px; letter-spacing:.08em; color:var(--muted); }
.entry .entry-title{ font-size:1.12rem; color:var(--ink); line-height:1.4; }
.entry .entry-title > a.entry-link{ color:inherit; text-decoration:none; border-bottom:1px solid var(--line-strong); transition:color .2s var(--ease), border-color .2s var(--ease); }
.entry .entry-title > a.entry-link:hover{ color:var(--accent); border-color:var(--accent); }
.pt-title a.entry-link{ color:inherit; text-decoration:none; border-bottom:1px solid var(--line-strong); transition:color .2s var(--ease), border-color .2s var(--ease); }
.pt-title a.entry-link:hover{ color:var(--accent); border-color:var(--accent); }
.entry .entry-title .where{ display:block; color:var(--muted); font-size:.95rem; margin-top:.25rem; }
.entry .entry-tag{ font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); white-space:nowrap; }

/* ---------- Connections ---------- */
.connections{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
@media (max-width:680px){ .connections{ grid-template-columns:1fr; } }
.conn{ background:var(--paper); padding:clamp(24px,3vw,40px); }
.bg-2 .conn{ background:var(--paper-2); }
.conn h4{ font-family:var(--mono); font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); font-weight:500; margin-bottom:1.1rem; }
.conn .tags{ display:flex; flex-wrap:wrap; gap:.55rem; }

/* ---------- Publications ---------- */
.filter-bar{
  display:flex; flex-wrap:wrap; gap:.6rem; align-items:center;
  padding-block:1.4rem; position:sticky; top:72px; z-index:40;
  background:color-mix(in srgb, var(--paper) 92%, transparent);
  backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
@media (max-width:760px){ .filter-bar{ top:62px; } }
.filter-btn{
  font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase;
  padding:.6em 1em; border:1px solid var(--line-strong); background:transparent; color:var(--ink-soft);
  cursor:pointer; border-radius:1px; transition:.25s var(--ease); white-space:nowrap;
}
.filter-btn:hover{ border-color:var(--ink); color:var(--ink); }
.filter-btn[aria-pressed="true"]{ background:var(--ink); border-color:var(--ink); color:var(--paper); }
.filter-count{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; color:var(--muted); margin-left:auto; }
@media (max-width:760px){ .filter-count{ width:100%; margin-left:0; order:-1; } }

.pub-group{ padding-top:clamp(40px,5vw,64px); }
.pub-group-title{
  font-family:var(--mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--accent); margin-bottom:.4rem; display:flex; align-items:center; gap:.8rem;
}
.pub-group-title .gc{ color:var(--muted); }
.pub-group-sub{ color:var(--muted); font-size:1rem; margin-bottom:1.6rem; max-width:60ch; }

.pub-list{ list-style:none; border-top:1px solid var(--line); }
.pub-item{
  display:grid; grid-template-columns:1fr auto; gap:clamp(14px,3vw,40px);
  padding:1.5rem 0; border-bottom:1px solid var(--line); align-items:start;
  transition:background .3s var(--ease);
}
.pub-item:hover{ background:color-mix(in srgb, var(--paper-2) 60%, transparent); }
.pub-main .pub-title{ font-size:1.22rem; line-height:1.32; letter-spacing:-.01em; color:var(--ink); }
.pub-main .pub-authors{ font-family:var(--mono); font-size:12px; color:var(--ink-soft); margin-top:.7rem; letter-spacing:.01em; line-height:1.5; }
.pub-main .pub-authors .author-link{
  color:var(--ink-soft); text-decoration:none;
  border-bottom:1px solid var(--line-strong);
  transition:color .22s var(--ease), border-color .22s var(--ease);
}
.pub-main .pub-authors .author-link:hover{ color:var(--accent); border-color:var(--accent); }
.pub-main .pub-authors .author-link.self{ color:var(--ink); border-bottom-color:var(--line-strong); }
.pub-main .pub-authors .author-link.self:hover{ color:var(--accent); border-color:var(--accent); }
.pub-main .pub-venue{ font-size:1rem; color:var(--accent); margin-top:.5rem; font-style:italic; }
.pub-main .pub-venue a{ color:inherit; text-decoration:none; border-bottom:1px solid color-mix(in srgb, var(--accent) 30%, transparent); transition:border-color .2s var(--ease); }
.pub-main .pub-venue a:hover{ border-bottom-color:var(--accent); }
.pub-main .pub-meta{ font-family:var(--mono); font-size:11px; letter-spacing:.05em; color:var(--muted-2); margin-top:.5rem; }
.pub-main .pub-title a{ color:inherit; text-decoration:none; transition:color .25s var(--ease); }
.pub-main .pub-title a:hover{ color:var(--accent); }
.pub-main .pub-title a::after{
  content:"↗"; font-size:.62em; color:var(--muted-2); margin-left:.45em;
  position:relative; top:-.35em; transition:color .25s var(--ease);
}
.pub-main .pub-title a:hover::after{ color:var(--accent); }
.pub-aside{ display:flex; flex-direction:column; align-items:flex-end; gap:.6rem; text-align:right; }
@media (max-width:680px){
  .pub-item{ grid-template-columns:1fr; }
  .pub-aside{ flex-direction:row; align-items:center; text-align:left; flex-wrap:wrap; }
}

/* status chips */
.status{ font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; padding:.4em .7em; border-radius:1px; white-space:nowrap; border:1px solid; display:inline-flex; align-items:center; gap:.4em; }
.status .dot{ width:5px; height:5px; border-radius:50%; background:currentColor; }
.status.pub{ color:#2f6b46; border-color:#bcd8c6; background:#eef6f0; }
.status.rr{ color:#9a6612; border-color:#e6d4ab; background:#f8f1e0; }
.status.rev{ color:#5a5f7a; border-color:#cfd2e0; background:#eef0f6; }
.status.editor{ color:var(--accent); border-color:#e3c2bd; background:var(--accent-tint); }
.status.conf{ color:#4a463a; border-color:var(--line-strong); background:var(--paper-2); }
.rank{ font-family:var(--mono); font-size:10px; letter-spacing:.08em; color:var(--muted); }

/* ---------- Research section sub-nav ---------- */
.section-nav{ position:sticky; top:72px; z-index:45; background:color-mix(in srgb, var(--paper) 92%, transparent); backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px); border-bottom:1px solid var(--line); }
@media (max-width:760px){ .section-nav{ top:62px; } }
.section-nav .sn-inner{ display:flex; flex-wrap:wrap; gap:.4rem 1.6rem; padding-block:1.1rem; }
.section-nav a{ font-family:var(--mono); font-size:11.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); display:inline-flex; align-items:baseline; gap:.6em; transition:color .22s var(--ease); }
.section-nav a .sn-no{ font-size:9.5px; color:var(--accent); }
.section-nav a:hover{ color:var(--ink); }
.section-nav a.active{ color:var(--ink); }
.section-nav a.active .sn-no{ color:var(--accent); }
/* scroll-progress bar pinned to the nav's bottom edge */
.section-nav .sn-progress{ position:absolute; left:0; right:0; bottom:-1px; height:2px; background:transparent; overflow:hidden; }
.section-nav .sn-progress-fill{ display:block; height:100%; width:0%; background:var(--accent); transform-origin:left; transition:width .12s linear; }
.research-section{ padding-top:clamp(48px,6vw,84px); scroll-margin-top:130px; }
/* any id-anchored main section clears the sticky sub-nav */
main section[id]{ scroll-margin-top:130px; }
.research-section > .rs-head{ margin-bottom:clamp(28px,4vw,48px); }
.research-section .rs-head h2{ font-size:clamp(1.7rem,3.2vw,2.6rem); font-weight:300; letter-spacing:-.02em; margin-top:.8rem; }
.research-section .rs-head .rs-sub{ color:var(--muted); font-size:1.05rem; max-width:62ch; margin-top:.8rem; }

/* ---------- Collaborative institutions ---------- */
.inst-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
@media (max-width:680px){ .inst-grid{ grid-template-columns:1fr; } }
.inst{ background:var(--paper); padding:clamp(24px,3vw,38px); display:grid; gap:1.1rem; align-content:start; }
.bg-2 .inst{ background:var(--paper-2); }
.inst h4{ font-family:var(--mono); font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); font-weight:500; }
.inst .inst-list{ display:flex; flex-direction:column; gap:0; }
.inst .inst-row{ display:flex; justify-content:space-between; align-items:baseline; gap:1rem; padding:.7rem 0; border-bottom:1px solid var(--line); }
.bg-2 .inst .inst-row{ border-bottom-color:var(--line-strong); }
.inst .inst-row:last-child{ border-bottom:0; }
.inst .inst-name{ font-size:1.06rem; color:var(--ink); line-height:1.3; }
.inst .inst-name a{ color:var(--ink); border-bottom:1px solid var(--line-strong); transition:color .2s var(--ease), border-color .2s var(--ease); }
.inst .inst-name a:hover{ color:var(--accent); border-color:var(--accent); }
.inst .inst-role{ font-family:var(--mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--accent); white-space:nowrap; }

/* institution logo grid */
.inst-region{ margin-bottom:clamp(28px,3.5vw,48px); }
.inst-region:last-child{ margin-bottom:0; }
.inst-region-title{ font-family:var(--mono); font-size:11.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-bottom:1.1rem; padding-bottom:.7rem; border-bottom:1px solid var(--line); display:flex; align-items:baseline; gap:.7em; }
.inst-region-title .irt-no{ color:var(--accent); font-size:10px; }
.inst-logos{ display:grid; grid-template-columns:repeat(auto-fill, minmax(168px,1fr)); gap:clamp(12px,1.4vw,18px); }
.ilc{ display:grid; gap:.7rem; }
.ilc-slot{ display:flex; align-items:center; justify-content:center; width:100%; aspect-ratio:5/3; background:#fff; border:1px solid var(--line); padding:clamp(14px,1.6vw,22px); overflow:hidden; transition:border-color .25s var(--ease), box-shadow .25s var(--ease), transform .25s var(--ease); }
.ilc-slot[role="link"]:hover{ border-color:var(--accent); box-shadow:0 6px 22px -14px rgba(0,0,0,.4); transform:translateY(-2px); }
.ilc-slot[role="link"]:focus-visible{ outline:2px solid var(--accent); outline-offset:2px; }
.ilc-slot img{ max-width:100%; max-height:100%; width:auto; height:auto; object-fit:contain; }
.ilc-slot.scale-up img{ transform:scale(1.45); }
.ilc-slot.dark-tile{ background:#26266b; padding:clamp(16px,1.8vw,26px); }
.ilc-empty{ background:var(--paper-2); }
.ilc-empty span{ font-family:var(--mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted-2); }

/* show-more collapser */
.collapsed-hidden{ display:none !important; }
.show-more-btn{
  display:inline-flex; align-items:center; gap:.6em;
  margin-top:clamp(20px,2.5vw,32px);
  font-family:var(--mono); font-size:11.5px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink-soft); background:transparent;
  border:1px solid var(--line-strong); border-radius:1px;
  padding:.85em 1.4em; cursor:pointer;
  transition:color .25s var(--ease), border-color .25s var(--ease), background .25s var(--ease);
}
.show-more-btn:hover{ color:var(--accent); border-color:var(--accent); background:var(--accent-tint); }
.show-more-btn .sm-icon{ color:var(--accent); font-size:1.1em; }
.bg-2 .show-more-btn{ background:var(--paper); }
.bg-2 .ilc-slot{ border-color:var(--line-strong); }
.ilc-cap{ display:grid; gap:.25rem; }
.ilc-name{ font-size:.98rem; color:var(--ink); line-height:1.25; }
.ilc-name a{ color:var(--ink); border-bottom:1px solid var(--line-strong); transition:color .2s var(--ease), border-color .2s var(--ease); }
.ilc-name a:hover{ color:var(--accent); border-color:var(--accent); }
.ilc-role{ font-family:var(--mono); font-size:9.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); }

/* ---------- Patents ---------- */
.patent{ display:grid; grid-template-columns:90px 1fr auto; gap:clamp(18px,3vw,44px); padding:clamp(26px,3vw,38px) 0; border-top:1px solid var(--line); align-items:start; }
.patent:last-child{ border-bottom:1px solid var(--line); }
@media (max-width:680px){ .patent{ grid-template-columns:1fr; gap:12px; } }
.patent .pt-no{ font-family:var(--mono); font-size:12px; letter-spacing:.06em; color:var(--accent); padding-top:.4rem; }
.patent .pt-title{ font-size:clamp(1.25rem,2.2vw,1.65rem); font-weight:400; letter-spacing:-.01em; line-height:1.2; }
.patent .pt-meta{ font-family:var(--mono); font-size:11.5px; letter-spacing:.04em; color:var(--muted); margin-top:.7rem; }
.patent .pt-desc{ color:var(--ink-soft); font-size:1.02rem; line-height:1.55; margin-top:.7rem; max-width:54ch; }

/* ---------- Projects ---------- */
.proj-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.proj-grid.four{ grid-template-columns:repeat(4,1fr); }
@media (max-width:900px){ .proj-grid,.proj-grid.four{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .proj-grid,.proj-grid.four{ grid-template-columns:1fr; } }
.proj{ background:var(--paper); padding:clamp(24px,2.6vw,34px); display:flex; flex-direction:column; gap:1rem; transition:background .35s var(--ease), box-shadow .45s var(--ease); }
.bg-2 .proj{ background:var(--paper-2); }
.proj:hover{ background:var(--paper-2); }
.bg-2 .proj:hover{ background:var(--paper); }
.proj:hover{ box-shadow:0 24px 48px -32px rgba(28,26,23,.3); }
.proj-top{ display:flex; justify-content:space-between; align-items:center; gap:1rem; flex-wrap:wrap; }
.proj-cat{ font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }
.proj-link{ font-size:10.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--accent); text-decoration:none; border-bottom:1px solid transparent; transition:border-color .22s var(--ease); white-space:nowrap; }
.proj-link:hover{ border-color:var(--accent); }
.proj-title{ font-size:1.32rem; font-weight:400; letter-spacing:-.012em; line-height:1.18; }
.proj.compact .proj-title{ font-size:1.16rem; }
.proj-desc{ color:var(--ink-soft); font-size:1rem; line-height:1.55; flex:1; }
.proj.compact .proj-desc{ font-size:.95rem; }
.proj-meta{ font-size:11px; letter-spacing:.05em; color:var(--muted-2); }
.proj-tags{ display:flex; flex-wrap:wrap; gap:.5rem; margin-top:.2rem; }

/* credits block: collaborators / partners / funding */
.proj-credits{ display:grid; gap:.55rem; align-content:end; margin-top:.4rem; padding-top:1.1rem; border-top:1px solid var(--line); min-height:122px; }
.bg-2 .proj-credits{ border-top-color:var(--line-strong); }
.pc-row{ display:grid; grid-template-columns:92px 1fr; gap:.8rem; align-items:baseline; }
.pc-k{ font-family:var(--mono); font-size:9.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); padding-top:.15em; }
.pc-v{ font-size:.9rem; color:var(--ink-soft); line-height:1.5; }
.pc-v.empty{ color:var(--muted-2); font-style:italic; }
.pc-v a{ color:var(--ink-soft); border-bottom:1px solid var(--line-strong); text-decoration:none; transition:color .2s var(--ease), border-color .2s var(--ease); }
.pc-v a:hover{ color:var(--accent); border-color:var(--accent); }

/* ---------- Teaching ---------- */
.philosophy{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
@media (max-width:720px){ .philosophy{ grid-template-columns:1fr; } }
.phil{ background:var(--paper); padding:clamp(28px,3.4vw,44px); display:grid; gap:.9rem; align-content:start; transition:background .35s var(--ease); }
.bg-2 .phil{ background:var(--paper-2); }
.phil:hover{ background:var(--paper-2); }
.bg-2 .phil:hover{ background:var(--paper); }
.phil-no{ font-family:var(--mono); font-size:11px; letter-spacing:.18em; color:var(--accent); }
.phil h3{ font-size:clamp(1.25rem,2.2vw,1.6rem); font-weight:400; letter-spacing:-.01em; line-height:1.16; }
.phil p{ color:var(--ink-soft); font-size:1.02rem; line-height:1.58; }

/* recognition callout */
.recognition{ display:grid; grid-template-columns:1.1fr 1fr; gap:1px; background:var(--line); border:1px solid var(--line); }
@media (max-width:760px){ .recognition{ grid-template-columns:1fr; } }
.rec-card{ background:var(--paper); padding:clamp(26px,3vw,40px); display:grid; gap:.8rem; align-content:start; }
.bg-2 .rec-card{ background:var(--paper-2); }
.rec-card .rec-k{ font-family:var(--mono); font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); }
.rec-card h3{ font-size:1.35rem; font-weight:400; letter-spacing:-.01em; line-height:1.2; }
.rec-card p{ color:var(--ink-soft); font-size:1rem; line-height:1.55; }
.rec-card .rec-meta{ font-family:var(--mono); font-size:11px; letter-spacing:.05em; color:var(--muted); margin-top:.2rem; }

/* teaching activity group label */
.teach-cat{ margin-bottom:clamp(20px,2.5vw,30px); }
.teach-cat .eyebrow{ margin-bottom:.7rem; }
.teach-cat .tc-sub{ color:var(--muted); font-size:1rem; max-width:62ch; }

/* impact pull-quotes */
.impact-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
@media (max-width:760px){ .impact-grid{ grid-template-columns:1fr; } }
.impact{ background:var(--paper); padding:clamp(26px,3vw,40px); display:grid; gap:.7rem; }
.bg-2 .impact{ background:var(--paper-2); }
.impact .imp-v{ font-family:var(--serif); font-size:clamp(2rem,3.4vw,2.8rem); font-weight:300; line-height:1; letter-spacing:-.02em; color:var(--ink); }
.impact .imp-v .unit{ color:var(--accent); }
.impact .imp-l{ color:var(--ink-soft); font-size:1rem; line-height:1.5; }

/* teaching hero figure */
.teach-hero-fig{ margin-top:0; }
.teach-hero-fig figure{ display:grid; gap:1rem; }
.teach-hero-fig .fig-frame{ width:100%; aspect-ratio:16/9; overflow:hidden; border:1px solid var(--line); background:#fff; padding:12px; }
.teach-hero-fig .fig-frame img{ width:100%; height:100%; object-fit:contain; }
.teach-hero-fig figcaption{ font-family:var(--mono); font-size:11.5px; letter-spacing:.06em; color:var(--muted); display:flex; gap:.7em; align-items:baseline; }
.teach-hero-fig figcaption::before{ content:""; width:20px; height:1px; background:var(--accent); flex:none; position:relative; top:.5em; }

/* gallery */
.gallery{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(14px,1.6vw,22px); }
@media (max-width:820px){ .gallery{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .gallery{ grid-template-columns:1fr; } }
.gallery figure{ display:grid; gap:.8rem; }
.gallery .g-frame{ width:100%; aspect-ratio:4/3; overflow:hidden; border:1px solid var(--line); background:#fff; padding:10px; }
.gallery .g-frame img{ width:100%; height:100%; object-fit:contain; }
.gallery figcaption{ font-size:.95rem; line-height:1.45; color:var(--ink-soft); }
.gallery figcaption .g-when{ font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); display:block; margin-bottom:.3rem; }

/* role-definitions legend */
.role-key{ display:grid; grid-template-columns:repeat(2,1fr); gap:.7rem 2rem; margin-top:1.6rem; max-width:760px; }
@media (max-width:680px){ .role-key{ grid-template-columns:1fr; } }
.role-key .rk{ display:flex; gap:.7rem; align-items:baseline; }
.role-key dt{ font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); white-space:nowrap; padding-top:.05em; flex:none; }
.role-key dd{ font-size:.92rem; line-height:1.45; color:var(--ink-soft); }

/* logo wall — partners & funders */
.logo-wall{ display:grid; grid-template-columns:repeat(auto-fill, minmax(160px,1fr)); gap:1px; background:var(--line); border:1px solid var(--line); }
.logo-wall .lw{ background:#fff; aspect-ratio:3/2; display:flex; align-items:center; justify-content:center; padding:20px 26px; transition:background .3s var(--ease); position:relative; cursor:pointer; text-decoration:none; }
.logo-wall .lw img{ max-width:100%; max-height:100%; width:auto; height:auto; object-fit:contain; filter:grayscale(0.18); opacity:.92; transition:filter .35s var(--ease), opacity .35s var(--ease), transform .35s var(--ease); }
.logo-wall .lw:hover{ background:var(--paper); }
.logo-wall .lw:hover img{ filter:grayscale(0); opacity:1; transform:scale(1.04); }

/* feature block */
.proj-feature{ display:grid; grid-template-columns:1.3fr 1fr; gap:clamp(32px,5vw,72px); align-items:center; border:1px solid var(--line); background:var(--paper-2); padding:clamp(32px,4vw,56px); }
@media (max-width:820px){ .proj-feature{ grid-template-columns:1fr; gap:32px; } }
.proj-feature-title{ font-size:clamp(1.5rem,2.6vw,2.1rem); font-weight:400; letter-spacing:-.015em; line-height:1.12; margin-top:1rem; }
.proj-feature-desc{ color:var(--ink-soft); font-size:1.08rem; line-height:1.6; margin:1.2rem 0 1.8rem; max-width:52ch; }
.proj-metrics{ list-style:none; display:grid; gap:1px; background:var(--line); border:1px solid var(--line); }
.proj-metrics li{ background:var(--paper); padding:1.2rem 1.4rem; display:grid; gap:.35rem; }
.pm-v{ font-family:var(--serif); font-size:clamp(1.7rem,3vw,2.4rem); font-weight:300; line-height:1; color:var(--ink); letter-spacing:-.01em; }
.pm-l{ font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); line-height:1.5; }

/* ---------- CV ---------- */
.cv-actions{ display:flex; gap:.8rem; flex-wrap:wrap; margin-top:2rem; }
.cv-section{ padding-block:clamp(36px,5vw,60px); border-top:1px solid var(--line); }
.cv-section:first-of-type{ border-top:0; }
.cv-item.has-logo{ display:grid; grid-template-columns:60px 1fr; gap:24px; align-items:start; }
.cv-logo{ width:60px; height:60px; border:1px solid var(--line); background:#fff; border-radius:8px; flex:none; }
@media (max-width:760px){
  .cv-item.has-logo{ grid-template-columns:46px 1fr; gap:16px; }
  .cv-logo{ width:46px; height:46px; }
}
.ref-link{ color:var(--ink); text-decoration:none; border-bottom:1px solid var(--line-strong); transition:color .22s var(--ease), border-color .22s var(--ease); }
.ref-link:hover{ color:var(--accent); border-color:var(--accent); }
.cv-grid{ display:grid; grid-template-columns:230px 1fr; gap:clamp(20px,4vw,56px); align-items:start; }
@media (max-width:760px){ .cv-grid{ grid-template-columns:1fr; gap:1rem; } }
.cv-h{ font-family:var(--mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--accent); position:sticky; top:96px; }
@media (max-width:760px){ .cv-h{ position:static; } }
.cv-block{ display:grid; gap:1.8rem; }
.cv-item .cv-row1{ display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; align-items:baseline; }
.cv-item .cv-role{ font-size:1.22rem; color:var(--ink); letter-spacing:-.01em; }
.cv-item .cv-when{ font-family:var(--mono); font-size:11.5px; letter-spacing:.08em; color:var(--muted); white-space:nowrap; }
.cv-item .cv-org{ color:var(--accent); font-style:italic; font-size:1.05rem; margin-top:.2rem; }
.cv-item ul{ margin-top:.9rem; padding-left:0; list-style:none; display:grid; gap:.55rem; }
.cv-item ul li{ position:relative; padding-left:1.4rem; color:var(--ink-soft); font-size:1.02rem; line-height:1.55; }
.cv-item ul li::before{ content:"—"; position:absolute; left:0; color:var(--accent); }
.cv-tags{ display:flex; flex-wrap:wrap; gap:.5rem; }

/* simple two-column award/grant list */
.linelist{ list-style:none; display:grid; gap:0; border-top:1px solid var(--line); }
.linelist li{ display:grid; grid-template-columns:88px 1fr; gap:1rem; padding:.95rem 0; border-bottom:1px solid var(--line); align-items:baseline; }
.linelist .yr{ font-family:var(--mono); font-size:12px; color:var(--accent); letter-spacing:.04em; }
.linelist .txt{ color:var(--ink-soft); font-size:1.04rem; line-height:1.45; }
.linelist .txt b{ color:var(--ink); font-weight:500; }

/* print */
@media print{
  .site-header,.site-footer,.filter-bar,.cv-actions,.nav-toggle,.skip,.venues{ display:none !important; }
  body{ background:#fff; color:#000; font-size:11pt; }
  .reveal{ opacity:1 !important; transform:none !important; }
  .cv-h{ position:static; }
  .section,.cv-section,.page-head{ padding-block:14px; }
  a{ color:#000; }
  .pub-item,.cv-section,.stream,.entry{ break-inside:avoid; }
}

/* ============ Motion refinements ============ */
/* slow ken-burns on mounted photos */
.g-frame img, .fig-frame img{ transition:transform 1.3s var(--ease); }
.g-frame:hover img, .fig-frame:hover img{ transform:scale(1.035); }

/* publication rows nudge right on hover */
.pub-item{ transition:background .3s var(--ease), transform .45s var(--ease); }
.pub-item:hover{ transform:translateX(8px); }

/* entry rows: date warms on hover */
.entry{ transition:background .3s var(--ease); }
.entry:hover .entry-when{ color:var(--accent); }
.entry .entry-when{ transition:color .3s var(--ease); }

@media (prefers-reduced-motion: reduce){
  .g-frame img, .fig-frame img, .pub-item{ transition:none; }
  .pub-item:hover{ transform:none; }
}

/* staggered settle for publication rows */
.pub-item.pf{ opacity:0; transform:translateY(12px); transition:opacity .5s var(--ease), transform .5s var(--ease); }
.pub-item.pf.pf-in{ opacity:1; transform:none; }

/* ============ Item hover dynamics ============ */
@media (hover:hover) and (prefers-reduced-motion: no-preference){
  /* claret rule draws along the row's bottom edge */
  .pub-item, .entry, .linelist li, .cv-item, .deflist .row{ position:relative; }
  .pub-item::after, .entry::after, .linelist li::after, .deflist .row::after{
    content:""; position:absolute; left:0; bottom:-1px; height:1px; width:100%;
    background:var(--accent); transform:scaleX(0); transform-origin:left;
    transition:transform .55s var(--ease); pointer-events:none;
  }
  .pub-item:hover::after, .entry:hover::after, .linelist li:hover::after, .deflist .row:hover::after{ transform:scaleX(1); }

  /* titles warm to claret */
  .pub-main .pub-title, .entry .entry-title, .linelist .txt b, .deflist dt{ transition:color .3s var(--ease); }
  .pub-item:hover .pub-title{ color:var(--accent); }
  .entry:hover .entry-title{ color:var(--accent); }
  .linelist li:hover .txt b{ color:var(--accent); }
  .deflist .row:hover dt{ color:var(--accent); }

  /* CV items: claret rail grows in the gutter */
  .cv-item::before{
    content:""; position:absolute; left:-16px; top:4px; bottom:4px; width:2px;
    background:var(--accent); transform:scaleY(0); transform-origin:top;
    transition:transform .5s var(--ease); pointer-events:none;
  }
  .cv-item:hover::before{ transform:scaleY(1); }

  /* logo cards: tile lifts, mark zooms, name warms */
  .ilc-slot{ transition:transform .45s var(--ease), box-shadow .45s var(--ease); }
  .ilc:hover .ilc-slot{ transform:translateY(-4px); box-shadow:0 18px 32px -22px rgba(28,26,23,.4); }
  .ilc-slot img{ transition:transform .45s var(--ease); }
  .ilc:hover .ilc-slot img{ transform:scale(1.06); }
  .ilc-name a{ transition:color .3s var(--ease); }
  .ilc:hover .ilc-name a{ color:var(--accent); }

  /* status chips tick on row hover */
  .pub-aside .status{ transition:transform .35s var(--ease); }
  .pub-item:hover .status{ transform:translateX(-3px); }
}

/* ---------- Page-head contents card ---------- */
.page-head .wrap.has-toc{
  display:grid; grid-template-columns:1.45fr .75fr;
  gap:clamp(36px,6vw,96px); align-items:end;
}
.ph-toc .pt-label{
  font-family:var(--mono); font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--muted); padding-bottom:.9rem; border-bottom:1px solid var(--line-strong);
}
.ph-toc a{
  display:flex; align-items:baseline; gap:1.1rem;
  padding:.8rem 0; border-bottom:1px solid var(--line);
  transition:padding-left .35s var(--ease);
}
.ph-toc .pt-no{ font-family:var(--mono); font-size:11px; color:var(--accent); letter-spacing:.08em; flex:none; }
.ph-toc .pt-t{ font-size:1.05rem; line-height:1.3; color:var(--ink-soft); transition:color .3s var(--ease); }
.ph-toc .pt-c{
  margin-left:auto; flex:none;
  font-family:var(--mono); font-size:11px; color:var(--muted);
  transition:color .3s var(--ease);
}
.ph-toc a:hover .pt-c{ color:var(--accent); }
.ph-toc a:hover{ padding-left:.5rem; }
.ph-toc a:hover .pt-t{ color:var(--accent); }
@media (max-width:860px){
  .page-head .wrap.has-toc{ grid-template-columns:1fr; }
  .ph-toc{ display:none; }
}
