@import url('https://fonts.googleapis.com/css2?family=Newsreader:ital,opsz,wght@0,6..72,400;0,6..72,500;0,6..72,600;1,6..72,400&family=Public+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap');

:root {
  --navy-900: #13294a;
  --navy-800: #1c2433;
  --charcoal-700: #4d4444;
  --slate-600: #7c8393;
  --slate-500: #94949c;
  --periwinkle-400: #a3a4b3;
  --slate-300: #b9b9c1;
  --tan-600: #936443;
  --tan-hover: #7f5539;
  --maroon-800: #4c2c24;
  --beige-100: #e3d2c5;
  --off-white-50: #f6f5f3;
  --white: #ffffff;

  --surface-page: var(--off-white-50);
  --surface-card: var(--white);
  --surface-sunken: var(--beige-100);
  --text-primary: var(--navy-900);
  --text-secondary: var(--charcoal-700);
  --text-muted: var(--slate-500);
  --text-on-inverse: var(--off-white-50);
  --text-on-inverse-muted: var(--periwinkle-400);
  --border-default: var(--slate-300);
  --accent-primary: var(--tan-600);
  --accent-secondary: var(--slate-600);

  --font-serif: 'Newsreader', 'Iowan Old Style', Georgia, serif;
  --font-sans: 'Public Sans', -apple-system, 'Helvetica Neue', Arial, sans-serif;
  --font-mono: 'IBM Plex Mono', ui-monospace, Menlo, monospace;

  --space-1: 4px; --space-2: 8px; --space-3: 12px; --space-4: 16px; --space-5: 24px;
  --space-6: 32px; --space-7: 48px; --space-8: 64px; --space-9: 96px;
  --radius-sm: 6px; --radius-md: 10px; --radius-lg: 16px; --radius-xl: 24px; --radius-pill: 999px;
  --max-width: 1120px;
  --shadow-sm: 0 2px 8px rgba(19,41,74,0.08);
  --shadow-lg: 0 16px 48px rgba(19,41,74,0.14);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--surface-page);
  font-family: var(--font-sans);
  color: var(--text-primary);
}
img { max-width: 100%; display: block; }
a { color: inherit; }
.container { max-width: var(--max-width); margin: 0 auto; padding: 0 var(--space-5); }
.eyebrow {
  text-transform: uppercase; letter-spacing: 0.14em; font-size: 12px; font-weight: 700;
  color: var(--accent-secondary); margin-bottom: var(--space-3);
}
.section-title {
  font-family: var(--font-serif); font-size: 36px; margin: 0 0 var(--space-6); color: var(--text-primary);
}
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 12px 24px; border-radius: var(--radius-md); font-weight: 600; font-size: 16px;
  text-decoration: none; border: 1px solid transparent; cursor: pointer;
}
.btn-primary { background: var(--navy-900); color: var(--text-on-inverse); }
.btn-secondary { background: transparent; color: var(--navy-900); border-color: var(--border-default); }
.btn-inverse { background: var(--accent-primary); color: var(--navy-900); }

/* NAV */
.nav {
  position: sticky; top: 0; z-index: 50; background: rgba(246,245,243,0.92);
  border-bottom: 1px solid var(--border-default);
}
.nav-inner {
  max-width: var(--max-width); margin: 0 auto; padding: var(--space-4) var(--space-5);
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-5); flex-wrap: wrap;
}
.nav-logo { display: flex; align-items: center; gap: var(--space-3); }
.nav-logo span { font-family: var(--font-serif); font-size: 22px; font-weight: 600; }
.nav-logo img { width: 28px; height: 28px; }
.nav-links { display: flex; align-items: center; gap: var(--space-6); list-style: none; margin: 0; padding: 0; flex-wrap: wrap; }
.nav-links a { text-decoration: none; color: var(--text-secondary); font-weight: 600; font-size: 14px; }
.nav-cta { color: var(--text-on-inverse) !important; background: var(--navy-900); padding: 8px 16px; border-radius: var(--radius-md); }

/* HERO */
.hero { position: relative; overflow: hidden; }
.hero-bg {
  position: absolute; inset: 0; background-image: url('assets/backgrounds/gradient-dune-sky.png');
  background-size: cover; background-position: center; opacity: 0.22;
}
.hero-inner {
  position: relative; padding: var(--space-9) 0 var(--space-8); display: grid;
  grid-template-columns: 1.3fr 0.7fr; gap: var(--space-8); align-items: center;
}
.hero h1 { font-family: var(--font-serif); font-size: 64px; line-height: 1.1; margin: 0 0 var(--space-4); }
.hero h1 span { color: var(--accent-primary); }
.hero-role { font-size: 18px; color: var(--text-secondary); margin-bottom: var(--space-2); }
.hero-org { font-size: 16px; color: var(--text-muted); margin-bottom: var(--space-5); }
.hero-desc { font-size: 16px; line-height: 1.7; color: var(--text-secondary); max-width: 60ch; margin: 0 0 var(--space-5); }
.hero-honors { font-size: 14px; color: var(--text-muted); margin-bottom: var(--space-6); }
.hero-ctas { display: flex; gap: var(--space-4); flex-wrap: wrap; }
.hero-photo { display: flex; justify-content: center; }
.hero-photo img {
  width: 100%; max-width: 320px; aspect-ratio: 1/1; object-fit: cover; border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg); border: 1px solid var(--border-default);
}

/* ABOUT */
.section-about {
  background: var(--surface-card); border-top: 1px solid var(--border-default);
  border-bottom: 1px solid var(--border-default); padding: var(--space-9) 0;
}
.about-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: var(--space-8); }
.about-text p { font-size: 18px; line-height: 1.7; color: var(--text-secondary); margin: 0 0 var(--space-5); }
.about-links { display: flex; gap: var(--space-4); flex-wrap: wrap; margin-top: var(--space-6); }
.stats-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); margin-bottom: var(--space-6); }
.stat-card { background: var(--surface-sunken); border: 1px solid var(--border-default); border-radius: var(--radius-lg); padding: var(--space-5); }
.stat-value { font-family: var(--font-serif); font-size: 36px; line-height: 1; }
.stat-label { font-size: 14px; color: var(--text-secondary); margin-top: var(--space-2); }
.honors-label { font-size: 12px; text-transform: uppercase; letter-spacing: 0.14em; font-weight: 700; color: var(--text-muted); margin-bottom: var(--space-3); }
.honors-list { border-top: 1px solid var(--border-default); padding-top: var(--space-5); }
.honors-list div { font-size: 14px; color: var(--text-secondary); padding: 6px 0; border-bottom: 1px solid var(--border-default); }

/* VIDEO */
.section-video { background: var(--navy-900); padding: var(--space-8) 0; }
.video-grid { display: grid; grid-template-columns: auto 1fr; gap: var(--space-6); align-items: center; }
.video-badge {
  width: 72px; height: 72px; border-radius: var(--radius-lg); background: var(--accent-primary);
  display: flex; align-items: center; justify-content: center; font-family: var(--font-serif);
  font-size: 32px; font-weight: 600; color: var(--navy-900);
}
.video-title { font-family: var(--font-serif); font-size: 28px; color: var(--text-on-inverse); margin-bottom: var(--space-2); }
.video-handle { font-size: 14px; color: var(--text-on-inverse-muted); margin-bottom: var(--space-4); }
.video-desc { font-size: 16px; line-height: 1.7; color: var(--text-on-inverse); opacity: 0.9; margin: 0 0 var(--space-4); max-width: 60ch; }
.video-sub { font-size: 14px; color: var(--text-on-inverse-muted); margin: 0 0 var(--space-5); }

/* FOCUS SECTIONS */
.section-focus { padding: var(--space-9) 0; }
.pillars-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); }
.pillar-card { background: var(--surface-card); border: 1px solid var(--border-default); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); padding: var(--space-6); }
.pillar-card img { width: 32px; height: 32px; margin-bottom: var(--space-4); }
.pillar-num { font-size: 12px; font-weight: 700; color: var(--accent-secondary); text-transform: uppercase; letter-spacing: 0.14em; margin-bottom: var(--space-2); }
.pillar-title { font-family: var(--font-serif); font-size: 22px; margin: 0 0 var(--space-3); }
.pillar-desc { font-size: 14px; line-height: 1.7; color: var(--text-secondary); margin: 0 0 var(--space-4); }
.pillar-work-label { font-size: 12px; text-transform: uppercase; letter-spacing: 0.14em; font-weight: 700; color: var(--text-muted); margin-bottom: var(--space-3); }
.pillar-card .work-item { font-size: 14px; color: var(--text-secondary); padding: var(--space-2) 0; border-top: 1px solid var(--border-default); }

/* PUBLICATIONS LAYOUT */
.pub-layout { display: grid; grid-template-columns: 1fr 280px; gap: var(--space-6); align-items: start; }
@media (max-width: 860px) { .pub-layout { grid-template-columns: 1fr; } }

/* TRIALS */
.trials-list { display: flex; flex-direction: column; gap: var(--space-4); }
.trial-card { background: var(--surface-card); border: 1px solid var(--border-default); border-radius: var(--radius-lg); padding: var(--space-5) var(--space-6); display: flex; flex-direction: column; gap: var(--space-2); }
.trial-role {
  display: inline-flex; align-self: flex-start; align-items: center; height: 22px; padding: 0 10px;
  border-radius: var(--radius-pill); font-size: 12px; font-weight: 600; background: var(--navy-900); color: var(--text-on-inverse);
}
.trial-title { font-family: var(--font-serif); font-size: 18px; }
.trial-sub { font-size: 14px; color: var(--text-secondary); }
.trial-badge { font-family: var(--font-mono); font-size: 12px; color: var(--text-muted); margin-top: var(--space-1); }

/* CONTACT */
.section-contact { background: #fdfaf5; border-top: 1px solid var(--border-default); padding: var(--space-9) 0; }
.contact-lead { font-size: 18px; line-height: 1.7; color: var(--text-secondary); max-width: 65ch; margin: 0 0 var(--space-6); }
.contact-grid { display: flex; flex-wrap: wrap; gap: var(--space-8); }
.contact-label { font-size: 12px; text-transform: uppercase; letter-spacing: 0.14em; font-weight: 700; color: var(--text-muted); margin-bottom: var(--space-2); }
.contact-value { font-size: 16px; color: var(--text-primary); text-decoration: none; font-weight: 600; }
.contact-elsewhere { display: flex; flex-direction: column; gap: var(--space-2); }

/* FOOTER */
.footer { background: var(--navy-900); }
.footer-inner { padding: var(--space-6) 0; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: var(--space-4); }
.footer-brand { display: flex; align-items: center; gap: var(--space-3); }
.footer-brand img { width: 20px; height: 20px; filter: brightness(0) invert(1); }
.footer-brand span { font-family: var(--font-serif); font-size: 16px; color: var(--text-on-inverse); }
.footer-copy { font-size: 14px; color: var(--text-on-inverse-muted); }

@media (max-width: 860px) {
  .hero-inner { grid-template-columns: 1fr; }
  .about-grid { grid-template-columns: 1fr; }
  .pillars-grid { grid-template-columns: 1fr; }
  .video-grid { grid-template-columns: 1fr; text-align: center; }
  .video-badge { margin: 0 auto; }
}

/* PUBLICATIONS WIDGET (populated live from PubMed by publications-widget.js) */
#zb-publications .zbpub-filters { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: var(--space-6); }
#zb-publications .zbpub-chip {
  padding: 8px 16px; border-radius: var(--radius-pill); cursor: pointer; font-size: 14px; font-weight: 600;
  font-family: inherit; background: var(--white); color: var(--charcoal-700); border: 1px solid var(--border-default);
  transition: background 120ms ease, color 120ms ease, border-color 120ms ease;
}
#zb-publications .zbpub-chip:hover { border-color: var(--slate-600); }
#zb-publications .zbpub-chip[aria-pressed="true"] { background: var(--accent-primary); color: var(--off-white-50); border-color: transparent; }
#zb-publications .zbpub-list { display: flex; flex-direction: column; gap: var(--space-4); }
#zb-publications .zbpub-card {
  background: var(--white); border: 1px solid var(--border-default); border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-6); display: flex; flex-direction: column; gap: var(--space-2);
  animation: zbpubFadeIn 260ms cubic-bezier(0.4, 0, 0.2, 1);
}
@keyframes zbpubFadeIn { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: translateY(0); } }
#zb-publications .zbpub-meta { display: flex; align-items: center; gap: var(--space-3); flex-wrap: wrap; font-size: 12px; color: var(--slate-600); }
#zb-publications .zbpub-meta .zbpub-year { font-family: var(--font-mono); }
#zb-publications .zbpub-type {
  display: inline-flex; align-items: center; height: 22px; padding: 0 10px; border-radius: var(--radius-pill);
  font-size: 12px; font-weight: 600; background: var(--beige-100); color: var(--tan-600); border: 1px solid var(--border-default);
}
#zb-publications .zbpub-title { font-family: var(--font-serif); font-size: 18px; line-height: 1.25; color: var(--navy-900); }
#zb-publications .zbpub-authors { font-size: 14px; color: var(--charcoal-700); }
#zb-publications .zbpub-link { font-size: 14px; font-weight: 600; color: var(--slate-600); text-decoration: none; margin-top: var(--space-1); }
#zb-publications .zbpub-link:hover { text-decoration: underline; }
#zb-publications .zbpub-empty { font-size: 14px; color: var(--slate-600); padding: var(--space-6) 0; }
#zb-publications .zbpub-skel { background: var(--off-white-50); border: 1px solid var(--border-default); border-radius: var(--radius-lg); height: 120px; }
#zb-publications .zbpub-footer { margin-top: var(--space-6); display: flex; align-items: center; gap: var(--space-4); flex-wrap: wrap; }
#zb-publications .zbpub-viewall { font-size: 14px; font-weight: 700; color: var(--navy-900); text-decoration: none; }
#zb-publications .zbpub-viewall:hover { text-decoration: underline; }
#zb-publications .zbpub-status { font-size: 12px; color: var(--slate-300); }

/* GOOGLE SCHOLAR WIDGET (populated by scholar-widget.js) */
#zb-scholar .zbs-card { background: var(--white); border: 1px solid var(--border-default); border-radius: var(--radius-lg); padding: var(--space-5); position: sticky; top: 88px; }
#zb-scholar .zbs-header { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.14em; color: var(--slate-600); margin-bottom: var(--space-4); }
#zb-scholar .zbs-primary { text-align: center; padding: var(--space-4) 0 var(--space-5); border-bottom: 1px solid var(--beige-100); margin-bottom: var(--space-4); }
#zb-scholar .zbs-primary-value { font-family: var(--font-serif); font-size: 48px; line-height: 1; color: var(--navy-900); }
#zb-scholar .zbs-primary-label { font-size: 14px; font-weight: 600; color: var(--charcoal-700); margin-top: var(--space-2); }
#zb-scholar .zbs-secondary { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3); margin-bottom: var(--space-4); }
#zb-scholar .zbs-stat { background: var(--off-white-50); border: 1px solid var(--border-default); border-radius: var(--radius-md); padding: var(--space-3); text-align: center; }
#zb-scholar .zbs-stat-value { font-family: var(--font-serif); font-size: 22px; color: var(--navy-900); }
#zb-scholar .zbs-stat-label { font-size: 12px; color: var(--charcoal-700); margin-top: 2px; }
#zb-scholar .zbs-updated { font-size: 12px; color: var(--slate-300); text-align: center; margin-bottom: var(--space-3); }
#zb-scholar .zbs-link { display: block; text-align: center; font-size: 14px; font-weight: 700; color: var(--tan-600); text-decoration: none; }
#zb-scholar .zbs-link:hover { text-decoration: underline; }
