/*
Theme Name: Terra Cracovianum
Theme URI: https://terracracovianum.org
Author: Terra Cracovianum
Description: Editorial-cartographic theme for the Terra Cracovianum think tank. Custom post types for Publications and Fellows, fully editable content, Polylang-ready language switcher, GSAP + Three.js hero.
Version: 1.3.1
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: terra
*/
:root{
  --parchment:#f3eee3;
  --parchment-deep:#e9e2d2;
  --ink:#181c17;
  --ink-soft:#3c4238;
  --moss:#2e4636;
  --sienna:#c2451e;
  --hairline:rgba(24,28,23,.18);
  --serif:"Fraunces", Georgia, serif;
  --sans:"Instrument Sans", -apple-system, sans-serif;
  --mono:"Spline Sans Mono", ui-monospace, monospace;
  --gutter:clamp(20px, 4vw, 64px);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--parchment);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--sienna);color:var(--parchment)}

/* ---------- grain ---------- */
.grain{
  position:fixed;inset:-100%;z-index:999;pointer-events:none;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.06'/%3E%3C/svg%3E");
  animation:grain 8s steps(10) infinite;
}
@keyframes grain{
  0%,100%{transform:translate(0,0)} 10%{transform:translate(-5%,-10%)}
  20%{transform:translate(-15%,5%)} 30%{transform:translate(7%,-25%)}
  40%{transform:translate(-5%,25%)} 50%{transform:translate(-15%,10%)}
  60%{transform:translate(15%,0)} 70%{transform:translate(0,15%)}
  80%{transform:translate(3%,35%)} 90%{transform:translate(-10%,10%)}
}

/* ---------- header ---------- */
header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px var(--gutter);
  color:var(--ink);
  background:rgba(243,238,227,.78);
  -webkit-backdrop-filter:blur(14px) saturate(1.15);
  backdrop-filter:blur(14px) saturate(1.15);
  border-bottom:1px solid var(--hairline);
}
.brand{display:flex;align-items:center;text-decoration:none;color:var(--ink)}
.brand-logo{
  display:block;height:clamp(34px,4vw,46px);width:auto;
}
nav.desktop{display:flex;gap:34px}
nav.desktop a{
  font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink);text-decoration:none;position:relative;
}
nav.desktop a::after{
  content:"";position:absolute;left:0;bottom:-4px;height:1px;width:0;background:var(--sienna);
  transition:width .35s cubic-bezier(.22,1,.36,1);
}
nav.desktop a:hover::after,
nav.desktop a[aria-current="page"]::after{width:100%}
.menu-btn{
  display:none;background:none;border:1.5px solid var(--ink);border-radius:999px;
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink);padding:8px 16px;cursor:pointer;
}
.header-right{display:flex;align-items:center;gap:clamp(14px,2.4vw,34px)}

/* language switcher */
.lang{position:relative}
.lang-btn{
  display:flex;align-items:center;gap:8px;
  background:none;border:1.5px solid var(--ink);border-radius:999px;
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink);padding:8px 14px;cursor:pointer;
  transition:background .3s,color .3s;
}
.lang-btn::after{content:"▾";font-size:9px;line-height:1}
.lang-btn:hover,.lang.open .lang-btn{background:var(--ink);color:var(--parchment)}
.lang-menu{
  position:absolute;top:calc(100% + 10px);right:0;min-width:185px;
  background:var(--parchment);border:1px solid var(--ink);border-radius:16px;
  padding:6px;list-style:none;margin:0;z-index:150;
  box-shadow:0 18px 44px rgba(24,28,23,.18);
  opacity:0;visibility:hidden;transform:translateY(-8px);
  transition:opacity .3s,visibility .3s,transform .3s cubic-bezier(.22,1,.36,1);
}
.lang.open .lang-menu{opacity:1;visibility:visible;transform:none}
.lang-menu button,.lang-menu a{
  width:100%;display:flex;justify-content:space-between;align-items:center;gap:18px;
  background:none;border:0;border-radius:10px;padding:10px 12px;
  font-family:var(--sans);font-size:14px;color:var(--ink);cursor:pointer;text-align:left;
  text-decoration:none;box-sizing:border-box;
  transition:background .2s,color .2s;
}
.lang-menu li{list-style:none}
.lang-menu .code{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;color:var(--ink-soft)}
.lang-menu button:hover,.lang-menu a:hover{background:var(--ink);color:var(--parchment)}
.lang-menu button:hover .code,.lang-menu a:hover .code{color:rgba(243,238,227,.6)}
.lang-menu [aria-selected="true"] .code{color:var(--sienna)}

/* mobile overlay nav */
.mobile-nav{
  position:fixed;inset:0;z-index:200;background:var(--ink);color:var(--parchment);
  display:flex;flex-direction:column;justify-content:center;padding:0 var(--gutter);
  clip-path:inset(0 0 100% 0);transition:clip-path .6s cubic-bezier(.76,0,.24,1);
}
.mobile-nav.open{clip-path:inset(0 0 0% 0)}
.mobile-nav a{
  font-family:var(--serif);font-size:clamp(38px,10vw,64px);font-weight:300;
  color:var(--parchment);text-decoration:none;padding:10px 0;border-bottom:1px solid rgba(243,238,227,.15);
}
.mobile-nav a em{font-family:var(--mono);font-style:normal;font-size:12px;vertical-align:super;color:var(--sienna);margin-right:14px}
.mobile-close{
  position:absolute;top:18px;right:var(--gutter);background:none;border:1.5px solid var(--parchment);
  border-radius:999px;color:var(--parchment);font-family:var(--mono);font-size:11px;
  letter-spacing:.12em;text-transform:uppercase;padding:8px 16px;cursor:pointer;
}

/* ---------- index hero ---------- */
.hero{
  position:relative;min-height:100svh;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:0 var(--gutter) clamp(28px,5vh,56px);
}
#terra-canvas{position:absolute;inset:0;width:100%;height:100%;display:block}
.hero-content{position:relative;z-index:2;pointer-events:none}
.hero-over{
  font-family:var(--mono);font-size:clamp(11px,1.2vw,13px);letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-soft);margin-bottom:clamp(14px,2vh,26px);
  display:flex;gap:14px;align-items:center;flex-wrap:wrap;
}
.hero-over .rule{display:inline-block;width:48px;height:1px;background:var(--sienna)}
h1{
  font-family:var(--serif);font-weight:340;
  font-size:clamp(36px, 11.5vw, 196px);
  line-height:.92;letter-spacing:-.025em;
  text-transform:uppercase;
}
h1 .line{display:block;overflow:hidden}
h1 .line > span{display:inline-block;will-change:transform}
h1 .indent{padding-left:clamp(24px,8vw,220px)}
h1 em{font-style:italic;font-weight:300;color:var(--moss)}
.hero-foot{
  position:relative;z-index:2;display:flex;justify-content:space-between;align-items:flex-end;
  gap:24px;margin-top:clamp(22px,4vh,44px);flex-wrap:wrap;
}
.hero-lede{max-width:420px;font-size:clamp(15px,1.4vw,18px);color:var(--ink-soft)}
.hero-coords{
  font-family:var(--mono);font-size:12px;letter-spacing:.08em;color:var(--ink-soft);
  text-align:right;line-height:1.9;
}
.hero-coords b{color:var(--sienna);font-weight:500}
.scroll-cue{
  position:absolute;right:var(--gutter);top:50%;z-index:2;
  font-family:var(--mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;
  writing-mode:vertical-rl;color:var(--ink-soft);
}
.scroll-cue::after{
  content:"";display:block;width:1px;height:54px;background:var(--ink);margin:14px auto 0;
  animation:cue 2.2s ease-in-out infinite;transform-origin:top;
}
@keyframes cue{0%,100%{transform:scaleY(.3)}50%{transform:scaleY(1)}}

/* ---------- subpage hero ---------- */
.page-hero{
  padding:clamp(130px,22vh,210px) var(--gutter) clamp(34px,6vh,64px);
  border-bottom:1px solid var(--ink);
  position:relative;overflow:hidden;
}
.page-hero .kicker{display:block;margin-bottom:18px}
.page-hero h1{font-size:clamp(44px,9vw,150px);text-transform:none}
.page-hero h1 .line{overflow:hidden}
.page-hero-foot{
  display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;
  margin-top:clamp(20px,4vh,40px);
}
.page-hero-lede{max-width:520px;font-size:clamp(15px,1.4vw,18px);color:var(--ink-soft)}
.page-hero-index{
  font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-soft);text-align:right;line-height:1.9;
}
.page-hero-index b{color:var(--sienna);font-weight:500}

/* ---------- marquee ---------- */
.marquee{
  border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);
  background:var(--ink);color:var(--parchment);
  overflow:hidden;white-space:nowrap;padding:13px 0;
}
.marquee-track{display:inline-flex;gap:0;will-change:transform}
.marquee span{
  font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  padding:0 28px;display:inline-flex;align-items:center;gap:28px;
}
.marquee i{font-style:normal;color:var(--sienna)}

/* ---------- section scaffolding ---------- */
section{position:relative}
.section-head{
  display:flex;align-items:baseline;justify-content:space-between;gap:16px;
  padding:clamp(48px,8vh,90px) var(--gutter) clamp(22px,4vh,40px);
  border-bottom:1px solid var(--hairline);
}
.kicker{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--sienna)}
.kicker.dim{color:var(--ink-soft)}
.kicker a{color:inherit;text-decoration:none;border-bottom:1px solid var(--sienna)}

/* ---------- institute teaser (home) ---------- */
.institute{padding:clamp(80px,14vh,170px) var(--gutter)}
.institute-inner{max-width:1180px;margin:0 auto}
.institute p.lead{
  font-family:var(--serif);font-weight:340;
  font-size:clamp(26px,4.4vw,58px);line-height:1.22;letter-spacing:-.015em;
}
.institute p.lead em{font-style:italic;color:var(--sienna)}
.institute-links{
  margin-top:clamp(32px,5vh,56px);display:flex;gap:18px;flex-wrap:wrap;
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:14px;
  font-family:var(--mono);font-size:13px;letter-spacing:.14em;text-transform:uppercase;
  text-decoration:none;padding:18px 34px;border-radius:999px;
  position:relative;overflow:hidden;isolation:isolate;cursor:pointer;
  transition:color .35s;
}
.btn::before{
  content:"";position:absolute;inset:0;background:var(--sienna);z-index:-1;
  transform:translateY(101%);transition:transform .45s cubic-bezier(.76,0,.24,1);border-radius:inherit;
}
.btn:hover::before{transform:translateY(0)}
.btn-solid{background:var(--ink);color:var(--parchment)}
.btn-line{border:1.5px solid var(--ink);color:var(--ink)}
.btn-line:hover{color:var(--parchment)}

/* ---------- publications cards (home) ---------- */
.pubs-grid{display:grid;grid-template-columns:repeat(3,1fr);border-left:1px solid var(--hairline)}
.pub{
  border-right:1px solid var(--hairline);
  padding:clamp(26px,3.5vw,44px);
  display:flex;flex-direction:column;gap:18px;min-height:380px;
  text-decoration:none;color:var(--ink);position:relative;
  transition:background .4s;
}
.pub:hover{background:var(--parchment-deep)}
.pub-tag{
  align-self:flex-start;font-family:var(--mono);font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;border:1px solid var(--ink);border-radius:999px;padding:5px 12px;
}
.pub-tag.accent{border-color:var(--sienna);color:var(--sienna)}
.pub h3{
  font-family:var(--serif);font-weight:400;font-size:clamp(22px,2.3vw,30px);
  line-height:1.18;letter-spacing:-.015em;margin-top:auto;
}
.pub p{font-size:14px;color:var(--ink-soft)}
.pub-meta{
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-soft);display:flex;justify-content:space-between;
  border-top:1px solid var(--hairline);padding-top:14px;
}
.pub-meta b{color:var(--sienna);font-weight:500}

/* ---------- publications page: filters + register ---------- */
.filters{
  display:flex;gap:10px;flex-wrap:wrap;
  padding:clamp(20px,3vh,30px) var(--gutter);
  border-bottom:1px solid var(--hairline);
}
.filter{
  background:none;border:1px solid var(--hairline);border-radius:999px;
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-soft);padding:8px 18px;cursor:pointer;
  transition:all .3s;
}
.filter:hover{border-color:var(--ink);color:var(--ink)}
.filter.active{background:var(--ink);border-color:var(--ink);color:var(--parchment)}

.featured-pub{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,80px);
  padding:clamp(48px,8vh,90px) var(--gutter);
  border-bottom:1px solid var(--ink);
  text-decoration:none;color:var(--ink);
}
.featured-pub h2{
  font-family:var(--serif);font-weight:360;font-size:clamp(32px,4.8vw,68px);
  line-height:1.05;letter-spacing:-.02em;margin-top:18px;
}
.featured-pub h2 em{font-style:italic;color:var(--moss)}
.featured-right{display:flex;flex-direction:column;justify-content:flex-end;gap:22px}
.featured-right p{font-size:clamp(15px,1.3vw,17px);color:var(--ink-soft);max-width:46ch}
.featured-meta{
  font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-soft);display:flex;gap:28px;flex-wrap:wrap;
}
.featured-meta b{color:var(--sienna);font-weight:500}
.featured-pub:hover h2 em{color:var(--sienna)}

.register{border-bottom:1px solid var(--hairline)}
.pub-row{
  display:grid;
  grid-template-columns:minmax(70px,110px) minmax(90px,130px) 1fr minmax(90px,130px) 40px;
  align-items:baseline;gap:clamp(14px,2.5vw,40px);
  padding:clamp(22px,3.6vh,38px) var(--gutter);
  border-top:1px solid var(--hairline);
  text-decoration:none;color:var(--ink);
  position:relative;isolation:isolate;overflow:hidden;
}
.pub-row::before{
  content:"";position:absolute;inset:0;background:var(--ink);z-index:-1;
  transform:scaleY(0);transform-origin:bottom;
  transition:transform .45s cubic-bezier(.76,0,.24,1);
}
.pub-row:hover::before{transform:scaleY(1);transform-origin:top}
.pub-row:hover{color:var(--parchment)}
.pub-row:hover .pub-row-abstract{color:rgba(243,238,227,.7)}
.pub-row:hover .pub-row-arrow{transform:translateX(8px) rotate(-45deg);color:var(--sienna)}
.pub-row-id{font-family:var(--mono);font-size:12px;letter-spacing:.08em;color:var(--sienna)}
.pub-row-tag{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:inherit;opacity:.75}
.pub-row-title{
  display:block;
  font-family:var(--serif);font-weight:400;font-size:clamp(19px,2.2vw,30px);
  line-height:1.15;letter-spacing:-.015em;
}
.pub-row-abstract{display:block;font-size:13.5px;color:var(--ink-soft);margin-top:8px;max-width:60ch;transition:color .4s}
.pub-row-date{font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-align:right;opacity:.85}
.pub-row-arrow{
  font-family:var(--serif);font-size:clamp(20px,2.2vw,28px);font-weight:300;
  transition:transform .45s cubic-bezier(.22,1,.36,1);justify-self:end;
}
.pub-row.hidden,.featured-pub.hidden{display:none}
.register-empty{
  padding:clamp(40px,7vh,70px) var(--gutter);
  font-family:var(--mono);font-size:13px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-soft);display:none;
}

/* ---------- moss band ---------- */
.band{
  background:var(--moss);color:var(--parchment);
  padding:clamp(80px,14vh,160px) var(--gutter);
  position:relative;overflow:hidden;
}
.band::after{
  content:attr(data-watermark);
  position:absolute;right:-1.5vw;bottom:-2vw;
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(60px,11vw,170px);color:rgba(243,238,227,.07);
  white-space:nowrap;pointer-events:none;letter-spacing:-.03em;
}
.band-inner{max-width:1180px;margin:0 auto;position:relative;z-index:1}
.band .kicker{color:var(--parchment);opacity:.65}
.band h2{
  font-family:var(--serif);font-weight:340;font-size:clamp(34px,5.6vw,76px);
  line-height:1.06;letter-spacing:-.02em;margin:22px 0 36px;max-width:18ch;
}
.band h2 em{font-style:italic;color:#d9a06b}
.band p.band-body{max-width:54ch;color:rgba(243,238,227,.78);font-size:clamp(15px,1.3vw,17px)}
.stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(243,238,227,.2);
  border:1px solid rgba(243,238,227,.2);margin-top:clamp(40px,7vh,70px);
}
.stat{background:var(--moss);padding:clamp(20px,2.6vw,34px)}
.stat-n{
  font-family:var(--serif);font-weight:340;font-size:clamp(34px,4.4vw,60px);
  letter-spacing:-.02em;line-height:1;
}
.stat-n sup{font-size:.45em;color:#d9a06b}
.stat-l{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.65;margin-top:12px}

/* ---------- about: story ---------- */
.story{
  display:grid;grid-template-columns:minmax(200px,1fr) 2fr;gap:clamp(28px,6vw,100px);
  padding:clamp(70px,12vh,150px) var(--gutter);
}
.story-side{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);line-height:2.1}
.story-side b{color:var(--sienna);font-weight:500;display:block;margin-top:18px}
.story-side b:first-child{margin-top:0}
.story-main p{
  font-family:var(--serif);font-weight:350;
  font-size:clamp(20px,2.2vw,30px);line-height:1.45;letter-spacing:-.01em;
  max-width:30em;
}
.story-main p + p{margin-top:1.4em}
.story-main em{font-style:italic;color:var(--sienna)}

/* ---------- about: method ---------- */
.method{border-top:1px solid var(--ink)}
.method-grid{display:grid;grid-template-columns:repeat(3,1fr);border-left:1px solid var(--hairline)}
.method-item{
  border-right:1px solid var(--hairline);
  padding:clamp(28px,3.5vw,48px);min-height:340px;
  display:flex;flex-direction:column;
}
.method-num{font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:var(--sienna)}
.method-item h3{
  font-family:var(--serif);font-weight:380;font-size:clamp(24px,2.6vw,36px);
  letter-spacing:-.015em;line-height:1.1;margin:18px 0 14px;
}
.method-item h3 em{font-style:italic}
.method-item p{font-size:14.5px;color:var(--ink-soft);margin-top:auto;max-width:34ch}

/* ---------- about: fellows ---------- */
.fellows-grid{display:grid;grid-template-columns:repeat(3,1fr);border-left:1px solid var(--hairline)}
.fellow{
  border-right:1px solid var(--hairline);padding:clamp(22px,2.8vw,36px);
  min-height:300px;display:flex;flex-direction:column;
  transition:background .4s;
}
.fellow:hover{background:var(--parchment-deep)}
.fellow-top{display:flex;justify-content:flex-end;align-items:flex-start}
.fellow-num{font-family:var(--mono);font-size:11px;color:var(--sienna);letter-spacing:.1em}
.fellow-sigil{
  width:52px;height:52px;border:1.5px solid var(--ink);border-radius:50%;
  display:grid;place-items:center;
  font-family:var(--serif);font-weight:500;font-size:16px;font-style:italic;
  transition:all .4s;
}
.fellow:hover .fellow-sigil{background:var(--ink);color:var(--parchment);transform:rotate(-8deg)}
.fellow h4{
  font-family:var(--serif);font-weight:420;font-size:clamp(19px,1.8vw,24px);
  letter-spacing:-.01em;margin-top:auto;line-height:1.2;
}
.fellow .role{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--sienna);margin-top:8px;display:block}
.fellow .bio{font-size:13px;color:var(--ink-soft);margin-top:10px;line-height:1.5}

/* ---------- fellow profile ---------- */
.profile-hero{
  display:grid;grid-template-columns:clamp(200px,24vw,320px) 1fr;
  gap:clamp(28px,5vw,80px);align-items:end;
  padding:clamp(120px,18vh,190px) var(--gutter) clamp(36px,6vh,64px);
  border-bottom:1px solid var(--ink);
}
.portrait{
  aspect-ratio:1;border-radius:50%;border:1.5px solid var(--ink);
  overflow:hidden;background:var(--parchment-deep);position:relative;
}
.portrait svg{display:block;width:100%;height:100%}
.profile-id h1{font-size:clamp(38px,6.4vw,104px);text-transform:none;line-height:.98}
.profile-id .kicker{display:block;margin-bottom:16px}
.profile-lede{
  max-width:560px;font-size:clamp(15px,1.4vw,18px);color:var(--ink-soft);
  margin-top:clamp(16px,3vh,28px);
}
.tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:clamp(18px,3vh,30px)}
.tag{
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  border:1px solid var(--hairline);border-radius:999px;padding:6px 14px;color:var(--ink-soft);
  transition:all .3s;
}
.tag:hover{border-color:var(--sienna);color:var(--sienna)}
.profile-body{
  display:grid;grid-template-columns:2fr minmax(220px,1fr);
  gap:clamp(28px,6vw,100px);
  padding:clamp(50px,9vh,100px) var(--gutter);
}
.profile-bio p{
  font-family:var(--serif);font-weight:350;
  font-size:clamp(18px,1.9vw,25px);line-height:1.5;letter-spacing:-.005em;
  max-width:34em;
}
.profile-bio p + p{margin-top:1.3em}
.profile-bio em{font-style:italic;color:var(--sienna)}
.profile-meta{
  font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-soft);line-height:2.1;align-self:start;
  border-left:1px solid var(--hairline);padding-left:clamp(18px,2.5vw,36px);
}
.profile-meta b{color:var(--sienna);font-weight:500;display:block;margin-top:18px}
.profile-meta b:first-child{margin-top:0}
.profile-meta a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--hairline)}
.fellow-pager{
  display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--ink);
}
.fellow-pager a{
  padding:clamp(26px,4.5vh,46px) var(--gutter);
  text-decoration:none;color:var(--ink);
  display:flex;flex-direction:column;gap:8px;
  transition:background .35s;
}
.fellow-pager a:hover{background:var(--parchment-deep)}
.fellow-pager a + a{border-left:1px solid var(--hairline);text-align:right;align-items:flex-end}
.fellow-pager .pager-label{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--sienna)}
.fellow-pager .pager-name{font-family:var(--serif);font-weight:380;font-size:clamp(20px,2.4vw,32px);letter-spacing:-.015em}
a.fellow{text-decoration:none;color:inherit;cursor:pointer}
a.fellow .read-more{
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--sienna);margin-top:14px;display:inline-flex;gap:8px;
  opacity:0;transform:translateX(-6px);transition:all .35s;
}
a.fellow:hover .read-more{opacity:1;transform:none}

/* ---------- publication detail ---------- */
.pub-hero{
  padding:clamp(120px,18vh,190px) var(--gutter) clamp(36px,6vh,64px);
  border-bottom:1px solid var(--ink);
}
.pub-hero .kicker{display:block;margin-bottom:18px}
.pub-hero h1{
  font-size:clamp(30px,5.2vw,78px);text-transform:none;line-height:1.04;
  max-width:20ch;
}
.pub-hero h1 em{color:var(--moss)}
.byline{
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  margin-top:clamp(22px,4vh,40px);
}
.byline-sigils{display:flex}
.byline-sigils .sigil{
  width:40px;height:40px;border:1.5px solid var(--ink);border-radius:50%;
  display:grid;place-items:center;background:var(--parchment);
  font-family:var(--serif);font-style:italic;font-weight:500;font-size:12px;
}
.byline-sigils .sigil + .sigil{margin-left:-11px}
.byline-text{
  font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-soft);line-height:1.9;
}
.byline-text b{color:var(--ink);font-weight:500}
.byline-text i{font-style:normal;color:var(--sienna)}

/* article body */
.article-wrap{padding:clamp(50px,9vh,100px) var(--gutter) 0}
.article{max-width:740px;margin:0 auto}
.article p{
  font-family:var(--serif);font-weight:370;
  font-size:clamp(16.5px,1.35vw,19px);line-height:1.75;
}
.article p + p{margin-top:1.35em}
.article p.lead{
  font-size:clamp(20px,2vw,26px);line-height:1.5;font-weight:340;letter-spacing:-.005em;
}
.article em{font-style:italic;color:var(--sienna)}
.article h2{
  font-family:var(--serif);font-weight:430;
  font-size:clamp(23px,2.4vw,32px);letter-spacing:-.015em;line-height:1.15;
  margin:clamp(40px,6vh,64px) 0 .8em;
}
.article h2 em{color:var(--moss)}
.pullquote{
  font-family:var(--serif);font-style:italic;font-weight:330;
  font-size:clamp(22px,2.5vw,33px);line-height:1.35;color:var(--sienna);
  border-left:2px solid var(--sienna);
  padding-left:clamp(18px,3vw,36px);
  margin:clamp(40px,6vh,64px) 0;
}
.article-end{
  max-width:740px;margin:clamp(48px,8vh,80px) auto 0;
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,56px);
  border-top:1px solid var(--ink);
  padding:clamp(28px,5vh,48px) 0 clamp(50px,9vh,100px);
}
.article-end .profile-meta{border-left:0;padding-left:0;margin-top:28px}
.findings{margin:clamp(40px,6vh,64px) 0}
.findings h3{
  font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--sienna);font-weight:500;margin-bottom:8px;
}
.findings ol{list-style:none;counter-reset:finding}
.findings li{
  counter-increment:finding;
  display:grid;grid-template-columns:54px 1fr;gap:18px;align-items:baseline;
  padding:18px 0;border-bottom:1px solid var(--hairline);
  font-size:clamp(14.5px,1.3vw,16.5px);color:var(--ink-soft);max-width:60ch;
}
.findings li::before{
  content:"0" counter(finding);
  font-family:var(--serif);font-style:italic;font-size:clamp(20px,2vw,28px);
  color:var(--sienna);
}
.pub-side{align-self:start;display:flex;flex-direction:column;gap:clamp(28px,4vh,40px)}
.pub-side .profile-meta{border-left:1px solid var(--hairline);padding-left:clamp(18px,2.5vw,36px)}
.authors h3{
  font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--sienna);font-weight:500;margin-bottom:14px;
}
.author-link{
  display:flex;align-items:center;gap:14px;text-decoration:none;color:var(--ink);
  padding:10px 0;border-bottom:1px solid var(--hairline);
  transition:transform .3s;
}
.author-link:hover{transform:translateX(5px)}
.author-link .sigil{
  width:42px;height:42px;border:1.5px solid var(--ink);border-radius:50%;flex-shrink:0;
  display:grid;place-items:center;
  font-family:var(--serif);font-style:italic;font-weight:500;font-size:13px;
  transition:all .3s;
}
.author-link:hover .sigil{background:var(--ink);color:var(--parchment)}
.author-link .a-name{font-family:var(--serif);font-weight:420;font-size:16.5px;letter-spacing:-.01em;display:block;line-height:1.2}
.author-link .a-role{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.cite-box{
  border:1px solid var(--hairline);border-radius:14px;
  padding:18px 20px;
  font-family:var(--mono);font-size:12px;line-height:1.8;color:var(--ink-soft);
}
.cite-box b{
  display:block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--sienna);font-weight:500;margin-bottom:8px;
}


/* publication meta strip under the byline */
.pub-meta-strip{
  display:flex;flex-wrap:wrap;gap:clamp(20px,4vw,56px);
  margin-top:clamp(20px,3.5vh,34px);padding-top:20px;
  border-top:1px solid var(--hairline);
}
.pub-meta-strip b{
  display:block;font-family:var(--mono);font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--sienna);font-weight:500;margin-bottom:5px;
}
.pub-meta-strip div{
  font-family:var(--mono);font-size:12px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--ink-soft);
}


/* ---------- about: timeline ---------- */
.timeline{border-top:1px solid var(--hairline)}
.tl-row{
  display:grid;grid-template-columns:minmax(110px,180px) 1fr;gap:clamp(20px,4vw,70px);
  padding:clamp(20px,3vh,32px) var(--gutter);
  border-bottom:1px solid var(--hairline);align-items:baseline;
}
.tl-year{font-family:var(--serif);font-weight:340;font-size:clamp(24px,2.8vw,40px);font-style:italic;color:var(--sienna)}
.tl-event{font-size:clamp(14.5px,1.3vw,16.5px);color:var(--ink-soft);max-width:62ch}
.tl-event b{color:var(--ink);font-weight:600}

/* ---------- CTA ---------- */
.cta{
  padding:clamp(90px,16vh,190px) var(--gutter);text-align:center;
  border-top:1px solid var(--ink);
}
.cta .kicker{display:block;margin-bottom:26px}
.cta h2{
  font-family:var(--serif);font-weight:330;
  font-size:clamp(40px,8vw,118px);line-height:1;letter-spacing:-.025em;
}
.cta h2 em{font-style:italic;color:var(--moss)}
.cta .btn{margin-top:clamp(34px,6vh,60px)}

/* ---------- footer ---------- */
footer{background:var(--ink);color:var(--parchment);padding:clamp(54px,9vh,96px) var(--gutter) 28px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;margin-bottom:clamp(56px,10vh,110px)}
.foot-grid p{max-width:300px;font-size:14px;color:rgba(243,238,227,.6)}
.foot-col h5{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--sienna);margin-bottom:18px}
.foot-col a{display:block;color:var(--parchment);text-decoration:none;font-size:14px;padding:5px 0;opacity:.85;transition:opacity .25s,transform .25s}
.foot-col a:hover{opacity:1;transform:translateX(4px)}
.foot-mark{
  font-family:var(--serif);font-weight:330;text-transform:uppercase;
  font-size:clamp(40px,10.5vw,158px);letter-spacing:-.02em;line-height:.95;
  border-top:1px solid rgba(243,238,227,.18);padding-top:32px;
  display:block;
}
.foot-mark em{font-style:italic;color:var(--sienna)}
.foot-base{
  display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(243,238,227,.45);margin-top:30px;
}

/* ---------- responsive ---------- */
@media (max-width:900px){
  nav.desktop{display:none}
  .menu-btn{display:block}
  .pubs-grid{grid-template-columns:1fr}
  .pub{border-bottom:1px solid var(--hairline);min-height:0}
  .stats{grid-template-columns:repeat(2,1fr)}
  .fellows-grid{grid-template-columns:1fr 1fr}
  .fellow{min-height:240px;border-bottom:1px solid var(--hairline)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .scroll-cue{display:none}
  .hero-coords{text-align:left}
  .featured-pub{grid-template-columns:1fr}
  .pub-row{grid-template-columns:auto 1fr auto;row-gap:10px}
  .pub-row-main{grid-column:1 / -1}
  .pub-row-arrow{display:none}
  .profile-hero{grid-template-columns:1fr;align-items:start}
  .profile-hero .portrait{max-width:190px}
  .profile-body{grid-template-columns:1fr}
  .profile-meta{border-left:0;padding-left:0;border-top:1px solid var(--hairline);padding-top:24px}
  .article-end{grid-template-columns:1fr}
  .findings li{grid-template-columns:40px 1fr;gap:12px}
  .story{grid-template-columns:1fr}
  .story-side{display:flex;gap:24px;flex-wrap:wrap;line-height:1.8}
  .story-side b{margin-top:0}
  .method-grid{grid-template-columns:1fr}
  .method-item{min-height:0;border-bottom:1px solid var(--hairline)}
  .method-item p{margin-top:18px}
}
@media (max-width:540px){
  .fellows-grid{grid-template-columns:1fr}
  .fellow{min-height:0}
  .fellow h4{margin-top:22px}
  .brand-logo{height:30px}
}
@media (prefers-reduced-motion:reduce){
  .grain{animation:none}
  .scroll-cue::after{animation:none}
}
