/* ============================================================
   MCM Lab — shared stylesheet
   ============================================================ */

/* ── reset & variables ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --bg:#06080c;
  --surface:#0b0f16;
  --surface-2:#111722;
  --text:#e8e2d8;
  --text-muted:#64605a;
  --text-dim:#96918b;
  --accent:#4e87c8;
  --accent-warm:#c49a50;
  --border:rgba(255,255,255,0.055);
  --border-accent:rgba(78,135,200,0.22);
  --green:#7ec49a;
  --green-border:rgba(126,196,154,0.2);
}
html{scroll-behavior:smooth;font-size:17px;}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;line-height:1.7;}

/* ── navigation ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.25rem 4rem;
  background:rgba(6,8,12,0.88);backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
}
.nav-logo{display:flex;flex-direction:column;gap:2px;text-decoration:none;}
.nav-logo-main{font-family:'Cormorant Garamond',serif;font-size:1.0rem;font-weight:400;color:var(--text);letter-spacing:0.02em;}
.nav-logo-sub{font-family:'IBM Plex Mono',monospace;font-size:0.56rem;color:var(--text-muted);letter-spacing:0.1em;}
.nav-links{display:flex;gap:2.5rem;list-style:none;}
.nav-links a{font-size:0.7rem;font-weight:500;letter-spacing:0.09em;text-transform:uppercase;color:var(--text-muted);text-decoration:none;transition:color 0.2s;}
.nav-links a:hover,.nav-links a.active{color:var(--accent);}

/* ── page wrapper ── */
.page-body{padding-top:72px;padding-bottom:80px;}

/* ── hero (index only) ── */
#hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;}
#fracture-canvas{position:absolute;inset:0;width:100%;height:100%;}
.hero-inner{position:relative;z-index:2;text-align:center;max-width:820px;padding:0 3rem;animation:heroIn 1.3s ease both;}
@keyframes heroIn{from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:translateY(0);}}
.hero-badge{
  display:inline-flex;align-items:center;gap:0.7rem;
  font-family:'IBM Plex Mono',monospace;font-size:0.6rem;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--accent);border:1px solid rgba(78,135,200,0.28);
  padding:0.4rem 1.2rem;border-radius:100px;margin-bottom:2.8rem;
  animation:heroIn 1.3s 0.15s ease both;
}
.hero-title{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(3.2rem,8vw,6.8rem);
  font-weight:300;line-height:1.02;letter-spacing:-0.015em;margin-bottom:1.8rem;
  animation:heroIn 1.3s 0.3s ease both;
}
.hero-title strong{display:block;font-weight:600;}
.hero-title em{font-style:italic;color:var(--accent);}
.hero-divider{
  width:48px;height:1px;background:var(--accent);
  margin:0 auto 2rem;opacity:0.5;
  animation:heroIn 1.3s 0.55s ease both;
}
.hero-tagline{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1rem,2vw,1.28rem);font-weight:300;font-style:italic;
  color:var(--text-dim);line-height:1.75;max-width:640px;margin:0 auto 3rem;
  animation:heroIn 1.3s 0.7s ease both;
}
.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;animation:heroIn 1.3s 0.9s ease both;}
.scroll-cue{position:absolute;bottom:2.8rem;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:0.5rem;}
.scroll-cue span{font-family:'IBM Plex Mono',monospace;font-size:0.56rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--text-muted);opacity:0.4;}
.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--accent),transparent);animation:pulse 2.4s ease-in-out infinite;}
@keyframes pulse{0%,100%{opacity:0.2;}50%{opacity:0.8;}}

/* ── shared section utilities ── */
.sec{padding:8rem 4rem;}
.sec-inner{max-width:1100px;margin:0 auto;}
.kicker{font-family:'IBM Plex Mono',monospace;font-size:0.59rem;color:var(--accent);letter-spacing:0.18em;text-transform:uppercase;margin-bottom:0.9rem;display:flex;align-items:center;gap:0.8rem;}
.kicker::before{content:'';display:block;width:22px;height:1px;background:var(--accent);}
.sec-heading{font-family:'Cormorant Garamond',serif;font-size:clamp(2rem,3.5vw,2.8rem);font-weight:300;line-height:1.14;margin-bottom:1.1rem;}
.sec-sub{font-size:1rem;font-weight:300;color:var(--text-dim);line-height:1.9;max-width:640px;}

/* ── buttons ── */
.btn{font-family:'DM Sans',sans-serif;font-size:0.7rem;font-weight:500;letter-spacing:0.09em;text-transform:uppercase;text-decoration:none;padding:0.82rem 1.9rem;border-radius:2px;transition:all 0.22s;display:inline-block;cursor:pointer;border:none;}
.btn-primary{background:var(--accent);color:#06080c;}
.btn-primary:hover{background:#5d96d9;}
.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border);}
.btn-ghost:hover{border-color:var(--border-accent);color:var(--accent);}

/* ── tags ── */
.tags{display:flex;flex-wrap:wrap;gap:0.4rem;margin-top:1.2rem;}
.tag{font-size:0.57rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;color:var(--text-muted);border:1px solid var(--border);padding:0.27rem 0.62rem;border-radius:1px;}

/* ── fade-up animation ── */
.fade-up{opacity:0;transform:translateY(18px);transition:opacity 0.7s ease,transform 0.7s ease;}
.fade-up.in{opacity:1;transform:translateY(0);}

/* ============================================================
   HOME — mini research pillars
   ============================================================ */
.mini-pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);}
.mini-pillar{background:var(--bg);padding:2.2rem 2rem;transition:background 0.25s;cursor:pointer;text-decoration:none;display:block;}
.mini-pillar:hover{background:var(--surface-2);}
.mp-idx{font-family:'IBM Plex Mono',monospace;font-size:0.55rem;color:var(--text-muted);margin-bottom:1.1rem;opacity:0.5;}
.mp-name{font-family:'Cormorant Garamond',serif;font-size:1.22rem;font-weight:400;color:var(--text);margin-bottom:0.55rem;line-height:1.2;}
.mp-body{font-size:0.9rem;font-weight:300;color:var(--text-dim);line-height:1.82;}
.mp-arrow{font-size:0.68rem;color:var(--accent);margin-top:1.1rem;opacity:0.65;}

/* ── HOME — join teaser ── */
.join-teaser{display:grid;grid-template-columns:1fr 360px;gap:6rem;align-items:center;}
.jt-text h2{font-family:'Cormorant Garamond',serif;font-size:clamp(1.8rem,3vw,2.4rem);font-weight:300;line-height:1.2;margin-bottom:1rem;}
.jt-text p{font-size:1rem;font-weight:300;color:var(--text-dim);line-height:1.9;margin-bottom:1.7rem;}
.jt-card{border:1px solid var(--border);background:var(--surface);padding:2.2rem;}
.jt-card-head{font-family:'Cormorant Garamond',serif;font-size:1.12rem;font-weight:400;color:var(--text);margin-bottom:0.5rem;}
.jt-card-sub{font-size:0.87rem;font-weight:300;color:var(--text-dim);line-height:1.75;margin-bottom:1.6rem;}
.jt-positions{display:flex;flex-direction:column;gap:0.6rem;margin-bottom:1.7rem;}
.jt-pos{display:flex;align-items:center;gap:0.7rem;font-size:0.9rem;font-weight:300;color:var(--text-dim);}
.jt-pos::before{content:'';display:block;width:6px;height:6px;border-radius:50%;background:var(--green);flex-shrink:0;}

/* ============================================================
   RESEARCH — full pillars
   ============================================================ */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--border);}
.pillar{padding:3rem 2.6rem;border-right:1px solid var(--border);position:relative;transition:background 0.3s;}
.pillar:last-child{border-right:none;}
.pillar-bar{position:absolute;top:0;left:0;right:0;height:2px;background:transparent;transition:background 0.35s;}
.pillar:hover{background:var(--surface-2);}
.pillar:hover .pillar-bar{background:var(--accent);}
.pillar-idx{font-family:'IBM Plex Mono',monospace;font-size:0.59rem;color:var(--text-muted);margin-bottom:2.2rem;opacity:0.55;}
.pillar-icon{margin-bottom:1.6rem;}
.pillar-icon img{width:40px;height:40px;display:block;}
.pillar-name{font-family:'Cormorant Garamond',serif;font-size:1.45rem;font-weight:400;color:var(--text);margin-bottom:0.9rem;line-height:1.2;}
.pillar-body{font-size:0.95rem;font-weight:300;color:var(--text-dim);line-height:1.9;margin-bottom:2rem;}
.pillar-foundation{margin-bottom:2rem;}
.pf-label{font-size:0.57rem;font-weight:500;letter-spacing:0.13em;text-transform:uppercase;color:var(--text-muted);margin-bottom:0.7rem;}
.pf-item{font-size:0.8rem;font-weight:300;font-style:italic;color:var(--text-dim);line-height:1.7;padding-left:0.85rem;border-left:1px solid rgba(78,135,200,0.25);margin-bottom:0.45rem;opacity:0.85;}

/* ============================================================
   PUBLICATIONS
   ============================================================ */
.pub-filter{display:flex;gap:0.5rem;margin-bottom:3.5rem;flex-wrap:wrap;}
.pf-btn{font-size:0.63rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;padding:0.4rem 0.95rem;border-radius:2px;border:1px solid var(--border);background:transparent;color:var(--text-muted);cursor:pointer;transition:all 0.2s;font-family:'DM Sans',sans-serif;}
.pf-btn:hover,.pf-btn.active{border-color:var(--border-accent);color:var(--accent);}
.pub-list{margin-bottom:3rem;}
.pub-item{display:grid;grid-template-columns:60px 1fr 96px;gap:1.5rem;align-items:start;padding:1.8rem 0;border-bottom:1px solid var(--border);}
.pub-item.hidden{display:none;}
.pub-item:first-child{border-top:1px solid var(--border);}
.pub-year{font-family:'IBM Plex Mono',monospace;font-size:0.67rem;color:var(--text-muted);padding-top:0.2rem;}
.pub-title{font-family:'Cormorant Garamond',serif;font-size:1.05rem;font-weight:400;color:var(--text);line-height:1.45;margin-bottom:0.38rem;transition:color 0.2s;}
.pub-item:hover .pub-title{color:var(--accent);}
.pub-authors{font-size:0.8rem;font-weight:300;color:var(--text-muted);margin-bottom:0.3rem;line-height:1.55;}
.pub-venue{font-size:0.8rem;font-style:italic;color:var(--accent);opacity:0.75;}
.pub-badge{font-size:0.56rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;padding:0.25rem 0.6rem;border-radius:2px;white-space:nowrap;align-self:start;margin-top:0.15rem;text-align:center;}
.b-nat{background:rgba(196,154,80,0.1);color:var(--accent-warm);border:1px solid rgba(196,154,80,0.22);}
.b-jmps{background:rgba(78,135,200,0.08);color:var(--accent);border:1px solid var(--border-accent);}
.b-cell{background:rgba(110,180,130,0.08);color:#7ec49a;border:1px solid rgba(110,180,130,0.2);}
.b-prl{background:rgba(190,110,190,0.08);color:#c47ec4;border:1px solid rgba(190,110,190,0.2);}
.b-epj{background:rgba(160,130,100,0.08);color:#b8956a;border:1px solid rgba(160,130,100,0.2);}
.b-misc{background:rgba(255,255,255,0.04);color:var(--text-muted);border:1px solid var(--border);}
.b-prep{background:rgba(78,135,200,0.04);color:var(--text-muted);border:1px solid var(--border);font-style:italic;}
.prep-section{margin-top:5rem;}
.prep-intro{font-size:1rem;font-weight:300;color:var(--text-dim);line-height:1.85;max-width:600px;margin-bottom:2.5rem;}
.prep-item{display:grid;grid-template-columns:60px 1fr;gap:1.5rem;padding:1.4rem 0;border-bottom:1px solid var(--border);}
.prep-item:first-child{border-top:1px solid var(--border);}
.prep-year{font-family:'IBM Plex Mono',monospace;font-size:0.67rem;color:var(--text-muted);padding-top:0.2rem;}
.prep-title{font-family:'Cormorant Garamond',serif;font-size:1.02rem;font-weight:400;font-style:italic;color:var(--text-dim);line-height:1.45;margin-bottom:0.35rem;}
.prep-authors{font-size:0.8rem;font-weight:300;color:var(--text-muted);line-height:1.55;}

/* ============================================================
   PEOPLE / TEAM
   ============================================================ */
.team-layout{display:grid;grid-template-columns:290px 1fr;gap:7rem;align-items:start;}
.pi-sidebar{position:sticky;top:7rem;}
.pi-portrait{width:100%;aspect-ratio:4/5;background:var(--surface-2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;font-family:'Cormorant Garamond',serif;font-size:4rem;font-weight:300;color:var(--text-muted);}
.pi-name{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:400;line-height:1.2;margin-bottom:0.3rem;}
.pi-title{font-family:'IBM Plex Mono',monospace;font-size:0.57rem;color:var(--accent);letter-spacing:0.13em;text-transform:uppercase;margin-bottom:1rem;}
.pi-affil{font-size:0.87rem;font-weight:300;color:var(--text-muted);line-height:1.85;}
.pi-contact{margin-top:1.5rem;display:flex;flex-wrap:wrap;gap:0.9rem;}
.pi-lnk{font-size:0.65rem;font-weight:500;letter-spacing:0.09em;text-transform:uppercase;color:var(--text-muted);text-decoration:none;border-bottom:1px solid var(--border);padding-bottom:2px;transition:all 0.2s;}
.pi-lnk:hover{color:var(--accent);border-color:var(--border-accent);}
.bio-section{margin-bottom:3rem;padding-bottom:3rem;border-bottom:1px solid var(--border);}
.bio-section:last-child{border-bottom:none;padding-bottom:0;margin-bottom:0;}
.bio-title{font-family:'Cormorant Garamond',serif;font-size:1.15rem;font-weight:400;color:var(--text);margin-bottom:0.9rem;}
.bio-text{font-size:0.95rem;font-weight:300;color:var(--text-dim);line-height:1.95;}
.train-list{list-style:none;margin-top:0.4rem;}
.train-row{display:flex;gap:1.5rem;padding:1rem 0;border-bottom:1px solid var(--border);}
.train-row:first-child{border-top:1px solid var(--border);}
.train-yr{font-family:'IBM Plex Mono',monospace;font-size:0.64rem;color:var(--text-muted);white-space:nowrap;padding-top:0.15rem;min-width:56px;}
.train-deg{font-size:0.92rem;color:var(--text);margin-bottom:0.2rem;font-weight:400;}
.train-inst{font-size:0.82rem;font-weight:300;color:var(--text-muted);}
.award-row{display:flex;gap:1.5rem;padding:0.9rem 0;border-bottom:1px solid var(--border);}
.award-row:first-child{border-top:1px solid var(--border);}
.award-yr{font-family:'IBM Plex Mono',monospace;font-size:0.64rem;color:var(--text-muted);white-space:nowrap;padding-top:0.1rem;min-width:56px;}
.award-txt{font-size:0.88rem;font-weight:300;color:var(--text-dim);line-height:1.65;}
.member-section{margin-top:3.5rem;padding-top:3.5rem;border-top:1px solid var(--border);}
.member-head{display:flex;align-items:end;justify-content:space-between;gap:2rem;margin-bottom:1.5rem;}
.member-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;}
.member-card{min-height:190px;border:1px solid var(--border);background:rgba(255,255,255,0.012);padding:1.5rem;display:flex;flex-direction:column;justify-content:space-between;transition:border-color 0.2s,background 0.2s;}
.member-card:hover{border-color:var(--border-accent);background:var(--surface-2);}
.member-role{font-family:'IBM Plex Mono',monospace;font-size:0.57rem;color:var(--accent);letter-spacing:0.13em;text-transform:uppercase;margin-bottom:0.9rem;}
.member-name{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:400;color:var(--text);line-height:1.2;margin-bottom:0.55rem;}
.member-focus{font-size:0.87rem;font-weight:300;color:var(--text-dim);line-height:1.75;}
.member-status{margin-top:1.5rem;font-size:0.6rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;color:var(--text-muted);}
.member-card.open .member-name{color:var(--text-dim);font-style:italic;}

/* ============================================================
   JOIN
   ============================================================ */
.join-intro-block{max-width:700px;margin-bottom:5rem;}
.join-intro-block p{font-size:1rem;font-weight:300;color:var(--text-dim);line-height:1.95;margin-bottom:1.1rem;}
.join-sections{display:flex;flex-direction:column;gap:5.5rem;}
.join-sec-head{margin-bottom:2.5rem;}
.join-sec-head h2{font-family:'Cormorant Garamond',serif;font-size:clamp(1.6rem,2.5vw,2rem);font-weight:300;color:var(--text);margin-bottom:0.6rem;}
.join-sec-head p{font-size:0.97rem;font-weight:300;color:var(--text-dim);line-height:1.85;max-width:620px;}
.project-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);}
.project-card{background:var(--bg);padding:2.5rem 2.2rem;}
.pc-num{font-family:'IBM Plex Mono',monospace;font-size:0.55rem;color:var(--accent);margin-bottom:1.3rem;opacity:0.6;}
.pc-title{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:400;color:var(--text);margin-bottom:0.75rem;line-height:1.25;}
.pc-body{font-size:0.93rem;font-weight:300;color:var(--text-dim);line-height:1.9;}
.learn-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;}
.learn-item{display:flex;gap:1.3rem;padding:1.7rem;border:1px solid var(--border);background:var(--surface);}
.learn-icon{font-family:'IBM Plex Mono',monospace;font-size:0.65rem;color:var(--accent);white-space:nowrap;padding-top:0.15rem;}
.learn-text h3{font-size:0.97rem;font-weight:400;color:var(--text);margin-bottom:0.38rem;}
.learn-text p{font-size:0.87rem;font-weight:300;color:var(--text-dim);line-height:1.75;}
.pos-type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;}
.pos-type-card{border:1px solid var(--border);padding:2.2rem 2rem;}
.ptc-role{font-family:'IBM Plex Mono',monospace;font-size:0.57rem;color:var(--accent);letter-spacing:0.15em;text-transform:uppercase;margin-bottom:0.8rem;}
.ptc-title{font-family:'Cormorant Garamond',serif;font-size:1.15rem;font-weight:400;color:var(--text);margin-bottom:0.7rem;}
.ptc-body{font-size:0.9rem;font-weight:300;color:var(--text-dim);line-height:1.85;margin-bottom:1.3rem;}
.ptc-funding{font-size:0.82rem;font-weight:300;color:var(--green);padding:0.55rem 0.9rem;border:1px solid var(--green-border);background:rgba(126,196,154,0.05);margin-bottom:1.3rem;}
.ptc-reqs{list-style:none;display:flex;flex-direction:column;gap:0.5rem;}
.ptc-reqs li{font-size:0.87rem;font-weight:300;color:var(--text-dim);padding-left:1rem;position:relative;line-height:1.6;}
.ptc-reqs li::before{content:'—';position:absolute;left:0;color:var(--text-muted);opacity:0.5;}
.fit-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;}
.fit-block{padding:2.5rem;border:1px solid var(--border);}
.fit-block.good{border-color:rgba(126,196,154,0.25);background:rgba(126,196,154,0.03);}
.fit-block.bad{border-color:rgba(255,100,80,0.15);background:rgba(255,100,80,0.02);}
.fit-label{font-family:'IBM Plex Mono',monospace;font-size:0.57rem;letter-spacing:0.15em;text-transform:uppercase;margin-bottom:1.2rem;}
.fit-block.good .fit-label{color:var(--green);}
.fit-block.bad .fit-label{color:#c47e7e;}
.fit-list{list-style:none;display:flex;flex-direction:column;gap:0.65rem;}
.fit-list li{font-size:0.92rem;font-weight:300;color:var(--text-dim);padding-left:1.3rem;position:relative;line-height:1.65;}
.fit-block.good .fit-list li::before{content:'✓';position:absolute;left:0;color:var(--green);font-size:0.7rem;}
.fit-block.bad .fit-list li::before{content:'✗';position:absolute;left:0;color:#c47e7e;font-size:0.7rem;}
.faq-list{display:flex;flex-direction:column;}
.faq-item{border-bottom:1px solid var(--border);padding:1.8rem 0;}
.faq-item:first-child{border-top:1px solid var(--border);}
.faq-q{font-family:'Cormorant Garamond',serif;font-size:1.12rem;font-weight:400;color:var(--text);margin-bottom:0.65rem;}
.faq-a{font-size:0.95rem;font-weight:300;color:var(--text-dim);line-height:1.9;max-width:740px;}
.faq-a a{color:var(--accent);text-decoration:none;border-bottom:1px solid rgba(78,135,200,0.3);}
.join-cta-block{margin-top:5rem;padding:3.5rem;border:1px solid var(--border-accent);background:rgba(78,135,200,0.04);display:flex;align-items:start;justify-content:space-between;gap:3rem;flex-wrap:wrap;}
.jcta-text h2{font-family:'Cormorant Garamond',serif;font-size:1.7rem;font-weight:300;margin-bottom:0.6rem;}
.jcta-text p{font-size:0.97rem;font-weight:300;color:var(--text-dim);line-height:1.85;max-width:520px;}
.jcta-actions{display:flex;flex-direction:column;gap:0.75rem;min-width:195px;}

/* ============================================================
   TEACHING
   ============================================================ */
.teaching-intro{max-width:680px;margin-bottom:4.5rem;}
.teaching-intro p{font-size:1rem;font-weight:300;color:var(--text-dim);line-height:1.95;}
.course-group{margin-bottom:4rem;}
.course-group-label{margin-bottom:1.5rem;}
.course-list{display:flex;flex-direction:column;gap:1px;background:var(--border);border:1px solid var(--border);}
.course-item{background:var(--bg);padding:2.2rem 2.5rem;display:grid;grid-template-columns:110px 1fr auto;gap:2rem;align-items:start;transition:background 0.2s;}
.course-item:hover{background:var(--surface-2);}
.ci-sem{font-family:'IBM Plex Mono',monospace;font-size:0.62rem;color:var(--text-muted);padding-top:0.15rem;white-space:nowrap;}
.ci-code{font-family:'IBM Plex Mono',monospace;font-size:0.59rem;color:var(--accent);letter-spacing:0.1em;margin-bottom:0.5rem;}
.ci-name{font-family:'Cormorant Garamond',serif;font-size:1.15rem;font-weight:400;color:var(--text);margin-bottom:0.35rem;}
.ci-desc{font-size:0.9rem;font-weight:300;color:var(--text-dim);line-height:1.8;max-width:580px;}
.ci-rating{font-family:'IBM Plex Mono',monospace;font-size:0.62rem;color:var(--text-muted);white-space:nowrap;text-align:right;}
.ci-rating span{display:block;color:var(--accent);font-size:0.82rem;margin-top:0.15rem;}
.teaching-philosophy{padding:2.8rem;border:1px solid var(--border);background:var(--surface);max-width:700px;margin-top:4rem;}
.teaching-philosophy p{font-size:0.97rem;font-weight:300;color:var(--text-dim);line-height:1.95;}

/* ============================================================
   FOOTER
   ============================================================ */
footer{background:var(--surface);border-top:1px solid var(--border);padding:5rem 4rem 3rem;}
.footer-layout{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:4rem;}
.f-lab{font-family:'Cormorant Garamond',serif;font-size:1.12rem;font-weight:400;margin-bottom:0.6rem;}
.f-tag{font-size:0.87rem;font-weight:300;font-style:italic;color:var(--text-muted);line-height:1.75;max-width:270px;}
.f-umn{margin-top:1.4rem;font-size:0.72rem;color:var(--text-muted);}
.fcol-head{font-family:'IBM Plex Mono',monospace;font-size:0.57rem;color:var(--accent);letter-spacing:0.18em;text-transform:uppercase;margin-bottom:1.2rem;}
.fcol address{font-style:normal;font-size:0.87rem;font-weight:300;color:var(--text-muted);line-height:1.9;}
.fcol address a{color:var(--text-muted);text-decoration:none;transition:color 0.2s;}
.fcol address a:hover{color:var(--accent);}
.fnav{list-style:none;display:flex;flex-direction:column;gap:0.7rem;}
.fnav a{font-size:0.87rem;font-weight:300;color:var(--text-muted);text-decoration:none;transition:color 0.2s;}
.fnav a:hover{color:var(--accent);}
.footer-bottom{max-width:1100px;margin:3.5rem auto 0;padding-top:2rem;border-top:1px solid var(--border);display:flex;justify-content:space-between;font-size:0.72rem;font-weight:300;color:var(--text-muted);}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:960px){
  nav{padding:1rem 1.5rem;}
  .nav-links{gap:1.5rem;}
  .sec{padding:5.5rem 1.5rem;}
  .mini-pillars,.pillars,.project-cards,.pos-type-grid{grid-template-columns:1fr;}
  .pillar{border-right:none;border-bottom:1px solid var(--border);}
  .pillar:last-child{border-bottom:none;}
  .join-teaser{grid-template-columns:1fr;gap:3rem;}
  .learn-grid,.fit-grid{grid-template-columns:1fr;}
  .team-layout{grid-template-columns:1fr;gap:3rem;}
  .pi-sidebar{position:static;}
  .member-grid{grid-template-columns:1fr;}
  .course-item{grid-template-columns:1fr;}
  .ci-rating{text-align:left;}
  .pub-item{grid-template-columns:50px 1fr;}
  .pub-badge{display:none;}
  .prep-item{grid-template-columns:50px 1fr;}
  .footer-layout{grid-template-columns:1fr;}
  footer{padding:4rem 1.5rem 2.5rem;}
  .join-cta-block{flex-direction:column;}
}

@media(max-width:700px){
  nav{
    align-items:flex-start;
    flex-direction:column;
    gap:0.62rem;
    padding:0.72rem 1.05rem 0.78rem;
  }
  .nav-logo{
    width:100%;
    min-width:0;
  }
  .nav-logo-main{
    font-size:0.98rem;
    line-height:1.12;
    letter-spacing:0;
  }
  .nav-logo-sub{
    font-size:0.5rem;
    line-height:1.35;
  }
  .nav-links{
    width:100%;
    flex-wrap:wrap;
    gap:0.36rem 0.9rem;
    justify-content:flex-start;
  }
  .nav-links a{
    font-size:0.58rem;
    line-height:1.2;
    letter-spacing:0.08em;
  }
  .page-body{
    padding-top:112px;
  }

  #hero{
    min-height:100svh;
    padding:7.7rem 1.05rem 5.8rem;
    align-items:center;
  }
  .hero-inner{
    max-width:26rem;
    padding:0;
  }
  .hero-badge{
    font-size:0.5rem;
    letter-spacing:0.11em;
    margin-bottom:1.7rem;
    padding:0.35rem 0.82rem;
  }
  .hero-title{
    font-size:3.15rem;
    line-height:1.02;
    letter-spacing:0;
    margin-bottom:1.3rem;
  }
  .hero-divider{
    margin-bottom:1.35rem;
  }
  .hero-tagline{
    font-size:1.13rem;
    line-height:1.62;
    margin-bottom:2rem;
  }
  .hero-tagline br{
    display:none;
  }
  .hero-cta{
    align-items:stretch;
    flex-direction:column;
    gap:0.72rem;
    max-width:17rem;
    margin:0 auto;
  }
  .hero-cta .btn{
    width:100%;
    text-align:center;
  }
  .scroll-cue{
    bottom:1.05rem;
  }
}

@media(max-width:390px){
  .hero-title{
    font-size:2.8rem;
  }
  .hero-tagline{
    font-size:1.04rem;
  }
  .btn{
    padding-left:1.2rem;
    padding-right:1.2rem;
  }
}
