
:root{
  --ink:#101828; --muted:#475569; --line:#e5e7eb; --bg:#fafcff; --card:#ffffff;
  --nav1:#1f4582; --nav2:#2853a0; --journal:#c1121f;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial;color:var(--ink);background:linear-gradient(180deg,#fff, var(--bg)) fixed}
.container{max-width:1080px;margin:0 auto;padding:0 18px}
section{padding:36px 0}
h1{font-family:Merriweather,serif;font-weight:800;color:#0f2a56;font-size:30px;line-height:1.2;margin:6px 0}
h2{font-size:22px;color:#0f2a56;margin:0 0 6px}
.lead{color:var(--muted);font-size:16px;max-width:68ch}
.small{font-size:13px;color:var(--muted)}
a{color:#2853a0;text-decoration:none} a:hover{text-decoration:underline}

/* Header */
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.9);backdrop-filter:saturate(160%) blur(8px);border-bottom:1px solid var(--line)}
.header-rail{height:3px;background:linear-gradient(90deg,var(--nav1),var(--nav2))}
.nav{display:flex;align-items:center;justify-content:space-between;height:62px}
.brand{font-weight:900;letter-spacing:.2px;color:#0f2a56}
.menu{display:flex;gap:8px;flex-wrap:wrap}
.menu a{padding:8px 12px;border:1px solid transparent;border-radius:10px;color:#0f172a;font-size:14px}
.menu a.active,.menu a:hover{border-color:var(--line);background:#f6f8fc}
@media (max-width:820px){.menu{display:none}}

/* Hero (index only) */
.hero{background:linear-gradient(135deg,#f4f7fc,#ffffff);border-bottom:1px solid var(--line)}
.hero .wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:22px;padding:28px 0}
.kicker{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border:1px solid var(--line);border-radius:999px;background:#fff;color:#687388;font-size:11px}
.k-dot{width:6px;height:6px;border-radius:999px;background:#1f4582}
.cta-row{display:flex;gap:10px;margin-top:14px}
.btn{display:inline-flex;align-items:center;gap:6px;border:1px solid #1f4582;background:#1f4582;color:#fff;padding:8px 12px;border-radius:10px;font-weight:700;font-size:14px}
.btn.alt{background:#fff;border-color:var(--line);color:#0f172a}
.hero-art{border-radius:12px;border:1px solid var(--line);background:radial-gradient(60% 60% at 60% 60%, #e8f0ff, #ffffff 70%);box-shadow:0 6px 16px rgba(15,23,42,.06);min-height:220px;position:relative;overflow:hidden}
.ring{position:absolute;border-radius:999px;border:2px solid rgba(31,69,130,.18)}
.r1{width:240px;height:240px;left:14%;top:10%}
.r2{width:170px;height:170px;right:14%;top:16%}
.r3{width:300px;height:300px;left:58%;bottom:-120px}

/* Page */
.page{padding-top:24px}
.grid{display:grid;gap:12px} .g-3{grid-template-columns:repeat(3,1fr)} .g-2{grid-template-columns:repeat(2,1fr)}
@media (max-width:960px){.hero .wrap{grid-template-columns:1fr}.g-3{grid-template-columns:1fr 1fr}}
@media (max-width:620px){.g-3,.g-2{grid-template-columns:1fr}}
.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px;box-shadow:0 6px 14px rgba(15,23,42,.05)}

/* Publications */
.pub-wrap{ max-width: 980px; margin: 0 auto; }
.pub-list{margin:12px 0 0 0;padding:0 0 0 24px}
.pub-list li{margin:8px 0;line-height:1.5}
.pub-title{font-weight:600}
.pub-journal{color:var(--journal); font-weight:800}
.pub-section{ margin-top:22px; }
.pub-tag{ display:inline-block; padding:3px 8px; font-size:11px; border-radius:999px; font-weight:700; border:1px solid var(--line); background:#fff; margin-left:8px; }
.hr-dots{ border:0; height:1px; background:linear-gradient(90deg,transparent,#e5e7eb,transparent); margin:14px 0 }
.pub-lead{ color:var(--muted); font-size:15px; }

/* Contact */
.contact-wrap{ display:grid; grid-template-columns:360px 1fr; gap:16px }
@media (max-width:720px){ .contact-wrap{ grid-template-columns:1fr } }
.contact-rail{ min-height:280px; border-right:1px solid var(--line); border:1px solid var(--line); border-left-width:1px; border-top-left-radius:12px; border-bottom-left-radius:12px; overflow:hidden; background:#fff; box-shadow:0 6px 14px rgba(15,23,42,.05)}
.contact-rail .rail-head{background:linear-gradient(90deg,var(--nav1),var(--nav2));color:#fff;padding:14px 16px;font-weight:800}
.contact-rail .rail-body{padding:14px 16px}
.map-card{border:1px solid var(--line);border-radius:12px;height:260px;background:#eef2f9;box-shadow:0 6px 14px rgba(15,23,42,.05)}

/* Photo cards */
.photo-card{ position:relative; overflow:hidden; border-radius:12px; }
.photo-img{ width:100%; height:220px; background:linear-gradient(120deg,#e6e8ff,#ffffff); border-radius:12px; }
.photo-img.small{ height:160px; }
.photo-overlay{ position:absolute; inset:0; display:flex; align-items:end; justify-content:stretch;
  background:linear-gradient(180deg, rgba(16,24,40,0) 35%, rgba(16,24,40,.55) 100%);
  opacity:0; transition:opacity .25s ease; border-radius:12px; padding:10px 12px; }
.photo-card:hover .photo-overlay{ opacity:1; }
.photo-caption{ color:#fff; font-size:14px; line-height:1.3; }
.photo-caption .name{ font-weight:700 } .photo-caption .role{ opacity:.95; font-size:12px }

/* Table */
table{width:100%;border-collapse:collapse;border:1px solid var(--line);background:#fff;border-radius:12px;overflow:hidden}
th,td{padding:10px 12px;border-bottom:1px solid var(--line);text-align:left;font-size:14px}
thead th{background:#f6f8fc}

/* Footer */
footer{border-top:1px solid var(--line);padding:18px 0;background:#fff}


/* --- One-row covers strip with lightbox --- */
.covers-row{ display:grid; grid-template-columns:repeat(5,1fr); gap:10px; margin-top:12px }
.covers-row img{ width:100%; height:120px; object-fit:cover; border-radius:10px; border:1px solid var(--line); transition:transform .15s ease, box-shadow .15s ease }
.covers-row a:hover img{ transform:translateY(-2px); box-shadow:0 8px 18px rgba(15,23,42,.12) }

.lb-backdrop{ position:fixed; inset:0; background:rgba(15,23,42,.8); display:none; align-items:center; justify-content:center; z-index:90 }
.lb-backdrop.open{ display:flex }
.lb-content{ max-width:90vw; max-height:90vh }
.lb-content img{ max-width:100%; max-height:90vh; border-radius:12px; box-shadow:0 12px 32px rgba(0,0,0,.4) }
.lb-close{ position:fixed; top:16px; right:20px; color:#fff; font-size:24px; cursor:pointer }


.photo-card img{ object-fit:contain; background:#fff; }
.covers-row img{ object-fit:contain; background:#fff; height:140px; }
.lb-caption{ color:#fff; margin-top:8px; text-align:center; font-size:14px }


.pi-grid{ display:grid; grid-template-columns: 380px 1fr; gap:20px; align-items:start }
@media (max-width:900px){ .pi-grid{ grid-template-columns:1fr } }
.photo-frame{ background:#fff; border:1px solid var(--line); border-radius:12px; box-shadow:0 6px 14px rgba(15,23,42,.06); padding:8px; }
.photo-frame img{ width:100%; height:auto; max-height:440px; object-fit:contain; border-radius:8px; display:block; margin:0 auto; }
.member-photo{ background:#fff; border:1px solid var(--line); border-radius:12px; height:190px; display:flex; align-items:center; justify-content:center; overflow:hidden }
.member-photo img{ max-width:100%; max-height:100%; object-fit:contain; border-radius:8px }
.team-bio p{ margin:6px 0 }


.bio-text { color:#475569; font-size:14px; line-height:1.4; margin-top:4px; }


/* Lightbox arrows */
.lb-arrow{ position:fixed; top:50%; transform:translateY(-50%); z-index:95; width:44px; height:44px;
  display:flex; align-items:center; justify-content:center; border-radius:999px; cursor:pointer;
  background:rgba(31,69,130,.85); color:#fff; font-size:22px; user-select:none; }
.lb-arrow:hover{ background:rgba(31,69,130,1) }
.lb-arrow.left{ left:16px } .lb-arrow.right{ right:16px }

/* Member card spacing & bio */
.grid.g-3{ gap:16px }
.bio-text { color:#475569; font-size:14px; line-height:1.45; margin-top:6px }
.member-photo{ background:#fff; border:1px solid var(--line); border-radius:12px; height:190px; display:flex; align-items:center; justify-content:center; overflow:hidden }
.member-photo img{ max-width:100%; max-height:100%; object-fit:contain; border-radius:8px }

/* --- News Timeline: Left-Aligned Compact Layout --- */
.timeline {
  position: relative;
  max-width: 760px;           /* narrower, reads like a column */
  margin: 0;                  /* remove auto-centering */
  padding: 8px 0 24px 24px;   /* add left padding for dots */
  border-left: 2px solid #e5e7eb;  /* vertical line on left */
}

.year {
  margin: 22px 0 8px;
  font-weight: 800;
  color: #0f2a56;
  text-align: left;
  padding-left: 8px;
}

.item {
  position: relative;
  display: flex;
  flex-direction: column;
  margin: 10px 0 20px 0;
  padding-left: 16px;
}

.item::before {
  content: '';
  position: absolute;
  left: -10px;                /* aligns dot with the vertical line */
  top: 6px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--journal);
}

.item .when {
  font-size: 13px;
  color: #475569;
  font-weight: 600;
}

.item .card {
  border: none;
  background: transparent;
  padding: 0;
  box-shadow: none;
  margin-top: 4px;
}

.item .what {
  font-size: 15px;
  line-height: 1.5;
  color: #101828;
}

.learn-more {
  background: radial-gradient(1000px at 30% 0%, rgba(45,108,195,.05), transparent),
              radial-gradient(800px at 110% 10%, rgba(212,160,23,.08), transparent);
  padding: 64px 0;
}
.learn-more .title {
  font-family: 'Merriweather', serif;
  font-weight: 800;
  color: #0f2a56;
  font-size: 28px;
  text-align: center;
  margin-bottom: 40px;
  position: relative;
}
.learn-more .grid-3 {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 24px;
}
.topic {
  position: relative;
  background: #fff;
  border-radius: 20px;
  padding: 28px 24px 36px;
  border: 1px solid rgba(15,42,86,.08);
  box-shadow: 0 8px 30px rgba(15,42,86,.08);
  overflow: hidden;
  transition: all .3s ease;
}
.topic:hover {
  transform: translateY(-6px);
  box-shadow: 0 14px 40px rgba(15,42,86,.12);
}
.topic h3 {
  color: #0f2a56;
  font-size: 20px;
  margin-bottom: 10px;
  font-weight: 700;
}
.topic p {
  color: #475569;
  font-size: 16px;
  line-height: 1.7;
  margin: 0;
}
.glow {
  position: absolute;
  inset: 0;
  border-radius: 20px;
  background: linear-gradient(135deg, rgba(45,108,195,.15), rgba(212,160,23,.15));
  opacity: 0;
  transition: opacity .4s ease;
  z-index: 0;
}
.topic:hover .glow { opacity: 1; }
.topic > * { position: relative; z-index: 1; }
.t1 .glow { background: linear-gradient(135deg, rgba(45,108,195,.18), rgba(127,179,255,.12)); }
.t2 .glow { background: linear-gradient(135deg, rgba(212,160,23,.2), rgba(255,213,107,.1)); }
.t3 .glow { background: linear-gradient(135deg, rgba(25,135,84,.18), rgba(159,232,201,.12)); }


