/* =====================================================================
   Prof. Gregory E. Erhabor — Academic Portfolio Theme
   Design: "The Editorial" — warm ivory, midnight ink, antique gold.
   Fonts:  Playfair Display (display) · Cormorant Garamond (editorial)
           · Inter (UI / labels)
   ===================================================================== */

:root{
  --paper:#F7F2EA;
  --paper-2:#F0E8DA;
  --paper-3:#EAE0CF;
  --ink:#16202C;
  --ink-2:#2C3947;
  --ink-soft:#55636F;
  --gold:#B5893C;
  --gold-lt:#CBA456;
  --gold-deep:#8C6526;
  --line:rgba(22,32,44,.14);
  --line-2:rgba(22,32,44,.08);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:var(--paper);color:var(--ink);line-height:1.7;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;line-height:1.12;letter-spacing:-.01em;color:var(--ink)}
.wrap{width:min(1240px,90vw);margin-inline:auto}
.kicker{font-family:'Inter',sans-serif;font-size:.7rem;font-weight:600;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-deep)}
.idx{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;color:var(--gold);font-size:1.5rem}

/* ---------- SCROLL PROGRESS ---------- */
.progress{position:fixed;top:0;left:0;right:0;height:2px;z-index:120;background:transparent}
.progress__bar{height:100%;width:0;background:linear-gradient(90deg,var(--gold-deep),var(--gold-lt));transition:width .08s linear}

/* ---------- HEADER / MASTHEAD ---------- */
header.mast{position:fixed;top:0;left:0;right:0;z-index:60;border-bottom:1px solid transparent;
  transition:background .35s var(--ease),box-shadow .35s var(--ease),border-color .35s}
header.mast.scrolled{background:rgba(247,242,234,.88);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
  border-bottom-color:var(--line);box-shadow:0 10px 30px -22px rgba(22,32,44,.5)}
.mast .wrap{display:flex;align-items:center;justify-content:space-between;height:96px;transition:height .35s var(--ease)}
header.mast.scrolled .wrap{height:68px}
.wordmark{display:flex;align-items:center;gap:13px}
.wordmark .mono{width:44px;height:44px;border:1.5px solid var(--gold);display:grid;place-items:center;
  font-family:'Playfair Display',serif;font-weight:800;color:var(--gold-deep);font-size:1.05rem;border-radius:2px;flex:none}
.wordmark .bt{display:flex;flex-direction:column;line-height:1.2}
.wordmark b{font-family:'Playfair Display',serif;font-weight:700;font-size:1.06rem;letter-spacing:.01em}
.wordmark small{font-family:'Inter',sans-serif;font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-deep);margin-top:2px}
.mast nav ul{list-style:none;display:flex;gap:34px;align-items:center}
.mast nav a{position:relative;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2);font-weight:500;padding-bottom:4px;transition:color .2s}
.mast nav a::after{content:"";position:absolute;left:0;bottom:-4px;height:1.5px;width:0;background:var(--gold);transition:width .3s var(--ease)}
.mast nav a:hover,.mast nav a.active{color:var(--gold-deep)}
.mast nav a:hover::after,.mast nav a.active::after{width:100%}
.mcta{border:1px solid var(--ink);padding:10px 20px;border-radius:999px;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;transition:.25s var(--ease)}
.mcta:hover{background:var(--ink);color:var(--paper)}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:0;padding:4px}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s var(--ease),opacity .2s}

/* ---------- HERO ---------- */
.hero{position:relative;padding:148px 0 80px;overflow:hidden}
.hero::before{content:"";position:absolute;top:-10%;right:-6%;width:560px;height:560px;border-radius:50%;
  background:radial-gradient(circle,rgba(181,137,60,.16),transparent 65%);pointer-events:none}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero .side-label{position:absolute;left:-58px;top:50%;transform:rotate(-90deg);transform-origin:center;
  font-size:.66rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold-deep);white-space:nowrap}
.hero .kicker{margin-bottom:22px;display:inline-block}
.hero h1{font-size:clamp(3rem,7vw,6rem);font-weight:800;letter-spacing:-.025em}
.hero h1 .it{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;color:var(--gold-deep);display:block;font-size:.62em;letter-spacing:0;margin-bottom:-.06em}
.hero .sub{font-family:'Cormorant Garamond',serif;font-size:1.5rem;color:var(--ink-2);line-height:1.5;max-width:30ch;margin:26px 0 30px;font-weight:400}
.hero .sub em{color:var(--gold-deep);font-style:italic}
.signature{font-family:'Great Vibes',cursive;font-size:clamp(2.2rem,4vw,3rem);color:var(--ink);line-height:1;margin:30px 0 6px;opacity:.92;transform:rotate(-3deg);transform-origin:left center}
.sig-cap{font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-deep);font-weight:600;display:block;margin-bottom:24px}
.hero .h-actions{display:flex;align-items:center;gap:26px;flex-wrap:wrap}
.link-arrow{font-size:.82rem;letter-spacing:.06em;font-weight:600;color:var(--ink);display:inline-flex;align-items:center;gap:9px;padding-bottom:4px;border-bottom:1.5px solid var(--gold);transition:gap .2s var(--ease)}
.link-arrow:hover{gap:15px}
.link-plain{font-size:.82rem;letter-spacing:.06em;color:var(--ink-soft);font-weight:500}
.link-plain:hover{color:var(--gold-deep)}

.hero-portrait{position:relative;justify-self:end}
.hero-portrait .pf{width:clamp(280px,34vw,420px);aspect-ratio:3/3.7;position:relative;
  background:linear-gradient(160deg,#1B2836,#101924);overflow:hidden;border-radius:2px;box-shadow:0 50px 90px -40px rgba(22,32,44,.6)}
.hero-portrait .pf img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-portrait .pf .ph{position:absolute;inset:0;display:grid;place-items:center;gap:12px;color:#3C4D60;text-align:center}
.hero-portrait .pf .ph svg{width:92px;height:92px;opacity:.6}
.hero-portrait .pf .ph small{font-size:.66rem;letter-spacing:.24em;text-transform:uppercase}
.hero-portrait .pf::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.07;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.hero-portrait .border{position:absolute;inset:16px;border:1px solid rgba(181,137,60,.55);border-radius:2px;pointer-events:none}
.hero-portrait .tab{position:absolute;bottom:26px;left:-26px;background:var(--paper);padding:16px 22px;box-shadow:0 20px 40px -22px rgba(22,32,44,.5);border-left:2px solid var(--gold)}
.hero-portrait .tab .k{font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-deep);font-weight:600}
.hero-portrait .tab .v{font-family:'Playfair Display',serif;font-weight:700;font-size:1.05rem;color:var(--ink)}
.hero-portrait .est{position:absolute;top:-18px;right:24px;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.05rem;color:var(--gold-deep)}

/* ---------- CREDENTIAL LINE ---------- */
.creds{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--paper-2)}
.creds .wrap{display:flex;flex-wrap:wrap;justify-content:center;gap:10px 30px;padding:24px 0;text-align:center}
.creds span{font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);font-weight:500;display:inline-flex;align-items:center;gap:30px}
.creds span::after{content:"\25C6";color:var(--gold);font-size:.52rem}
.creds span:last-child::after{display:none}

/* ---------- SECTION SHELL ---------- */
.section{padding:clamp(70px,9vw,128px) 0}
section[id]{scroll-margin-top:88px}
.section--paper2{background:var(--paper-2)}
.section--ink{background:var(--ink);color:#C9D2DC}
.section--ink h2,.section--ink h3,.section--ink h4{color:#fff}
.section--ink .idx,.section--ink .kicker{color:var(--gold-lt)}
.section--ink .link-arrow{color:#fff}
.sec-head{display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:baseline;margin-bottom:54px}
.sec-head .idx{padding-top:4px}
.sec-head .kicker{display:block;margin-bottom:12px}
.sec-head h2{font-size:clamp(2.1rem,4.4vw,3.4rem);font-weight:800;position:relative}
.sec-head h2::after{content:"";display:block;height:2px;width:0;margin-top:20px;background:linear-gradient(90deg,var(--gold-deep),var(--gold-lt));transition:width 1.1s var(--ease) .25s}
.sec-head.in h2::after{width:88px}
body:not(.has-reveal) .sec-head h2::after{width:88px}
.sec-head .lead{font-family:'Cormorant Garamond',serif;font-size:1.35rem;color:var(--ink-soft);max-width:46ch;margin-top:14px;line-height:1.5}
.section--ink .sec-head .lead{color:#9FB0C2}
.sec-foot{margin-top:48px;text-align:center}
.sec-foot--left{text-align:left;margin-top:36px}

/* ---------- PROFILE ---------- */
.profile{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.profile p{font-family:'Cormorant Garamond',serif;font-size:1.24rem;line-height:1.6;color:var(--ink-2);margin-bottom:18px}
.profile > div:first-child > p:first-of-type::first-letter{font-family:'Playfair Display',serif;font-weight:800;float:left;font-size:4.4rem;line-height:.78;padding:6px 14px 0 0;color:var(--gold-deep)}
.profile .pull{margin-top:8px;padding:30px 0 6px;border-top:1px solid var(--line)}
.profile .pull q{font-family:'Playfair Display',serif;font-style:italic;font-size:1.7rem;line-height:1.3;color:var(--ink);quotes:none}
.profile .pull .by{display:block;margin-top:16px;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-deep);font-weight:600}
.fact-list{display:flex;flex-direction:column}
.fact{display:grid;grid-template-columns:auto 1fr;gap:24px;padding:20px 0;border-bottom:1px solid var(--line)}
.fact:first-child{border-top:1px solid var(--line)}
.fact .fk{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);font-weight:600;padding-top:4px;min-width:118px}
.fact .fv{font-family:'Playfair Display',serif;font-size:1.12rem;color:var(--ink);font-weight:600}
.fact .fv small{display:block;font-family:'Inter',sans-serif;font-size:.82rem;font-weight:400;color:var(--ink-soft);letter-spacing:0;text-transform:none;margin-top:2px}

/* ---------- TIMELINE ---------- */
.tl{display:grid;gap:0;max-width:920px;margin-inline:auto}
.tl-row{display:grid;grid-template-columns:160px 1fr;gap:40px;padding:30px 0;border-top:1px solid var(--line);align-items:start;transition:padding-left .3s var(--ease)}
.tl-row:last-child{border-bottom:1px solid var(--line)}
.tl-row:hover{padding-left:10px}
.tl-row .yr{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:700;color:var(--gold-deep)}
.tl-row .tc h4{font-size:1.35rem;margin-bottom:6px}
.tl-row .tc p{font-family:'Cormorant Garamond',serif;font-size:1.16rem;color:var(--ink-soft);line-height:1.5}

/* ---------- RESEARCH METRICS + SHELF ---------- */
.metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-bottom:64px;border:1px solid var(--line)}
.metric{padding:40px 34px;border-right:1px solid var(--line)}
.metric:last-child{border-right:0}
.metric .big{font-family:'Playfair Display',serif;font-size:3.4rem;font-weight:800;color:var(--ink);line-height:1}
.metric .lbl{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep);font-weight:600;margin-top:8px}
.metric p{font-family:'Cormorant Garamond',serif;font-size:1.12rem;color:var(--ink-soft);margin-top:10px;line-height:1.5}
.shelf{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.vol .cover{aspect-ratio:3/4.2;background:linear-gradient(155deg,#1C2A39,#101822);position:relative;display:flex;flex-direction:column;justify-content:space-between;padding:24px 22px;border-radius:2px;box-shadow:0 26px 50px -28px rgba(22,32,44,.6);overflow:hidden}
.vol .cover::after{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--gold)}
.vol .cover .c-top{font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-lt)}
.vol .cover b{font-family:'Playfair Display',serif;color:#fff;font-size:1.18rem;line-height:1.25}
.vol .meta{margin-top:14px}
.vol .meta .t{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep);font-weight:600}
.vol .meta p{font-family:'Cormorant Garamond',serif;font-size:1.05rem;color:var(--ink-soft);margin-top:3px}

/* ---------- LEADERSHIP ROLES (ink) ---------- */
.roles{display:grid;grid-template-columns:1fr 1fr;gap:0 56px}
.role{display:grid;grid-template-columns:auto 1fr;gap:22px;padding:24px 0;border-top:1px solid rgba(255,255,255,.12);align-items:start}
.role .rk{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-lt);font-weight:600;min-width:84px;padding-top:5px}
.role .rv b{font-family:'Playfair Display',serif;font-size:1.18rem;color:#fff;font-weight:600;display:block}
.role .rv span{font-family:'Cormorant Garamond',serif;font-size:1.1rem;color:#9FB0C2;line-height:1.45}

/* ---------- COACHING ---------- */
.coach{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.coach p{font-family:'Cormorant Garamond',serif;font-size:1.24rem;line-height:1.6;color:var(--ink-2);margin-bottom:18px}
.coach .hi{display:flex;flex-direction:column;gap:0;margin-top:8px}
.coach .hi .h{display:grid;grid-template-columns:auto 1fr;gap:20px;padding:22px 0;border-top:1px solid var(--line);align-items:center}
.coach .hi .h:last-child{border-bottom:1px solid var(--line)}
.coach .hi .h .yr{font-family:'Playfair Display',serif;font-style:italic;color:var(--gold-deep);font-size:1.2rem;min-width:90px}
.coach .hi .h b{font-family:'Playfair Display',serif;font-size:1.12rem;color:var(--ink);font-weight:600;display:block}
.coach .hi .h span{font-size:.92rem;color:var(--ink-soft)}
.litbook{background:var(--paper);border:1px solid var(--line);padding:34px;border-radius:2px}
.litbook .t{font-family:'Playfair Display',serif;font-size:1.5rem;margin-bottom:4px}
.litbook .s{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-deep);font-weight:600;margin-bottom:22px}
.litbook ul{list-style:none;display:flex;flex-direction:column}
.litbook li{font-family:'Cormorant Garamond',serif;font-size:1.22rem;color:var(--ink-2);padding:12px 0 12px 26px;border-top:1px solid var(--line-2);position:relative}
.litbook li:first-of-type{border-top:0}
.litbook li::before{content:"";position:absolute;left:0;top:20px;width:8px;height:8px;background:var(--gold);transform:rotate(45deg)}
.litbook li em{color:var(--gold-deep);font-size:.92rem;font-style:italic}

/* ---------- BOOKS / STOREFRONT ---------- */
.shop{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.bookcard{display:grid;grid-template-columns:98px 1fr;gap:20px;background:var(--paper);border:1px solid var(--line);border-radius:4px;padding:22px;align-items:start;transition:transform .25s var(--ease),box-shadow .25s,border-color .25s}
.bookcard:hover{transform:translateY(-5px);box-shadow:0 30px 60px -34px rgba(0,0,0,.45);border-color:rgba(181,137,60,.45)}
.bookcard .cover{width:98px;aspect-ratio:3/4;background:linear-gradient(155deg,#1C2A39,#101822);border-radius:2px;position:relative;flex:none;overflow:hidden}
.bookcard .cover::after{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--gold);z-index:2}
.bookcard .cover img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.bookcard .cover .cmini{position:absolute;inset:0;display:grid;place-items:center;padding:12px 10px;text-align:center;color:#E4EAF2;font-family:'Playfair Display',serif;font-weight:600;font-size:.76rem;line-height:1.22}
.bookcard .bc .tag{font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);font-weight:700}
.bookcard .bc h3{font-size:1.14rem;color:var(--ink);margin:5px 0 8px;line-height:1.2}
.bookcard .bc p{font-family:'Cormorant Garamond',serif;font-size:1.08rem;color:var(--ink-soft);line-height:1.45;margin-bottom:15px}
.buy{display:inline-flex;align-items:center;gap:8px;background:var(--ink);color:var(--paper);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;padding:10px 16px;border-radius:999px;transition:background .2s,transform .2s var(--ease)}
.buy:hover{background:var(--gold-deep);transform:translateY(-1px)}
.buy svg{width:15px;height:15px}
.buy--soon{background:transparent;color:var(--ink-soft);border:1px solid var(--line);cursor:default}
.buy--soon:hover{background:transparent;color:var(--ink-soft);transform:none}
.bookgroup{margin-bottom:54px;scroll-margin-top:96px}
.bookgroup .kicker{display:block;margin-bottom:10px}
.bookgroup h2{font-size:clamp(1.7rem,3.4vw,2.3rem);font-weight:800;margin-bottom:24px;position:relative}
.bookgroup h2::after{content:"";display:block;width:64px;height:2px;background:linear-gradient(90deg,var(--gold-deep),var(--gold-lt));margin-top:16px}

/* ---------- SPEAKING / BLOG CARDS ---------- */
.talks{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.talk{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);border-radius:3px;overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s,border-color .3s}
.talk:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(22,32,44,.5);border-color:rgba(181,137,60,.45)}
.talk .thumb{aspect-ratio:16/10;background:linear-gradient(155deg,#1C2A39,#101822);position:relative;display:grid;place-items:center;color:#3C4D60}
.talk .thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.talk .thumb>svg{width:46px;height:46px;opacity:.5}
.talk .thumb .cat{position:absolute;top:14px;left:14px;background:var(--paper);color:var(--gold-deep);font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;padding:6px 12px;border-radius:999px;z-index:2}
.talk .thumb .play{position:absolute;width:54px;height:54px;border-radius:50%;background:rgba(247,242,234,.92);display:grid;place-items:center;color:var(--gold-deep);box-shadow:0 10px 24px -10px rgba(0,0,0,.5);z-index:2}
.talk .thumb .play svg{width:22px;height:22px;margin-left:3px}
.talk .tk{padding:24px 24px 28px;display:flex;flex-direction:column;flex:1}
.talk .tmeta{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep);font-weight:600;margin-bottom:11px}
.talk h3{font-size:1.32rem;line-height:1.2;margin-bottom:10px}
.talk p{font-family:'Cormorant Garamond',serif;font-size:1.12rem;color:var(--ink-soft);line-height:1.5;margin-bottom:18px}
.talk .read{margin-top:auto;align-self:flex-start;font-size:.76rem;letter-spacing:.08em;font-weight:600;color:var(--ink);display:inline-flex;gap:8px;align-items:center;border-bottom:1.5px solid var(--gold);padding-bottom:3px;transition:gap .2s var(--ease)}
.talk:hover .read{gap:14px}

/* ---------- AWARDS / HONOURS ---------- */
.honours{display:grid;grid-template-columns:repeat(2,1fr);gap:0 56px}
.honour{display:grid;grid-template-columns:auto 1fr;gap:24px;padding:28px 0;border-top:1px solid var(--line);align-items:start}
.honour .yb{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:700;color:var(--gold-deep);min-width:72px}
.honour .hb b{font-family:'Playfair Display',serif;font-size:1.22rem;color:var(--ink);display:block;margin-bottom:3px}
.honour .hb span{font-family:'Cormorant Garamond',serif;font-size:1.12rem;color:var(--ink-soft)}

/* ---------- FEATURED-IN PRESS STRIP ---------- */
.press{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--paper)}
.press .wrap{padding:42px 0;text-align:center}
.press .lbl{font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-deep);font-weight:600;margin-bottom:26px}
.press .logos{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:18px 44px}
.press .logos span{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:600;color:var(--ink-soft);opacity:.6;letter-spacing:.01em;transition:opacity .25s,color .25s}
.press .logos span:hover{opacity:1;color:var(--gold-deep)}

/* ---------- MINISTRY ---------- */
.ministry{position:relative;overflow:hidden;color:#E4EAF2;border-radius:3px;
  background:radial-gradient(700px 400px at 85% 15%,rgba(181,137,60,.2),transparent 60%),linear-gradient(150deg,#06121F,#0F2A4A);
  padding:clamp(48px,7vw,84px);box-shadow:0 40px 80px -44px rgba(22,32,44,.7)}
.ministry::before{content:"";position:absolute;top:-30%;right:-10%;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(181,137,60,.22),transparent 65%)}
.ministry .mg{position:relative;display:grid;grid-template-columns:1.25fr .75fr;gap:54px;align-items:center}
.ministry .kicker{color:var(--gold-lt)}
.ministry h2{color:#fff;font-size:clamp(2rem,3.6vw,2.9rem);margin:14px 0 18px}
.ministry p{font-family:'Cormorant Garamond',serif;font-size:1.28rem;color:#A9B7C6;line-height:1.55;max-width:48ch;margin-bottom:20px}
.ministry .mtags{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0 30px}
.ministry .mtags span{font-size:.78rem;letter-spacing:.04em;color:#CBD5E2;border:1px solid rgba(255,255,255,.18);padding:8px 14px;border-radius:999px}
.mcard{text-align:center;border:1px solid rgba(181,137,60,.4);border-radius:3px;padding:36px 30px;background:rgba(255,255,255,.03)}
.mcard .mono{width:62px;height:62px;border:1.5px solid var(--gold-lt);margin:0 auto 18px;display:grid;place-items:center;font-family:'Playfair Display',serif;font-weight:800;font-size:1.5rem;color:var(--gold-lt);border-radius:2px}
.mcard b{font-family:'Playfair Display',serif;color:#fff;font-size:1.2rem;display:block}
.mcard small{display:block;color:#9FB0C2;font-family:'Cormorant Garamond',serif;font-size:1.08rem;margin:8px 0 22px}
.btn-gold{display:inline-flex;align-items:center;gap:9px;background:var(--gold);color:var(--ink);font-weight:600;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;padding:14px 24px;border-radius:999px;transition:.25s var(--ease)}
.btn-gold:hover{background:var(--gold-lt);transform:translateY(-2px)}
.btn-line{display:inline-flex;align-items:center;justify-content:center;gap:9px;border:1px solid rgba(255,255,255,.3);color:#fff;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;padding:13px 24px;border-radius:999px;width:100%;transition:.25s}
.btn-line:hover{background:rgba(255,255,255,.08);border-color:var(--gold-lt)}

/* ---------- CONTACT ---------- */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.contact-left .sec-head{margin-bottom:40px}
.cinfo .ci{padding:22px 0;border-top:1px solid var(--line)}
.cinfo .ci:last-child{border-bottom:1px solid var(--line)}
.cinfo .ci .k{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);font-weight:600;margin-bottom:5px}
.cinfo .ci .v{font-family:'Playfair Display',serif;font-size:1.22rem;color:var(--ink)}
.cinfo .ci .v small{display:block;font-family:'Cormorant Garamond',serif;font-size:1.05rem;color:var(--ink-soft);margin-top:2px}
.cform{background:var(--paper);border:1px solid var(--line);padding:38px;border-radius:3px}
.cform .f{margin-bottom:18px}
.cform label{display:block;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep);font-weight:600;margin-bottom:7px}
.cform input,.cform textarea{width:100%;border:0;border-bottom:1px solid var(--line);background:transparent;padding:10px 2px;font-family:'Cormorant Garamond',serif;font-size:1.15rem;color:var(--ink);transition:border-color .2s}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--gold)}
.cform textarea{min-height:90px;resize:vertical}
.cform .btn-ink{margin-top:8px;width:100%;justify-content:center;display:inline-flex;align-items:center;gap:9px;background:var(--ink);color:var(--paper);border:0;font-family:'Inter',sans-serif;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;padding:15px;border-radius:999px;cursor:pointer;transition:.25s}
.cform .btn-ink:hover{background:var(--gold-deep)}
.cform__note{margin-top:14px;font-size:.85rem;text-align:center}
.cform__note.is-error{color:#a3331f}
.cform__note.is-success{color:#2f6b3a}

/* ---------- FOOTER ---------- */
footer.foot{background:var(--ink);color:#8FA0B2;padding:72px 0 30px}
.foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:42px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot .wordmark b{color:#fff}.foot .wordmark .mono{border-color:var(--gold-lt);color:var(--gold-lt)}
.foot .wordmark small{color:var(--gold-lt)}
.foot p{font-family:'Cormorant Garamond',serif;font-size:1.12rem;max-width:32ch;margin-top:16px;color:#9FB0C2}
.foot h4{color:#fff;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px}
.foot ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.foot ul a{font-size:.92rem;color:#A9B7C6}.foot ul a:hover{color:var(--gold-lt)}
.foot .social{display:flex;gap:10px;margin-top:14px}
.foot .social a{width:38px;height:38px;border-radius:10px;border:1px solid rgba(255,255,255,.15);display:grid;place-items:center;color:#C7D2E1;transition:.2s}
.foot .social a:hover{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.foot-bot{padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.78rem;letter-spacing:.04em}

/* =====================================================================
   DETAIL PAGES ("Read more") + SINGLE TALK — shared rich content
   ===================================================================== */
.phero{padding:140px 0 40px;border-bottom:1px solid var(--line)}
.phero .breadcrumb{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-deep);font-weight:600;margin-bottom:18px}
.phero .breadcrumb a{color:var(--ink-soft)}.phero .breadcrumb a:hover{color:var(--gold-deep)}
.phero h1{font-size:clamp(2.4rem,6vw,4.4rem);font-weight:800;margin-bottom:18px}
.phero .lede{font-family:'Cormorant Garamond',serif;font-size:1.5rem;color:var(--ink-2);line-height:1.5;max-width:60ch}

.detail-layout{display:grid;grid-template-columns:230px 1fr;gap:60px;padding:56px 0 80px;align-items:start}
.toc{position:sticky;top:96px}
.toc .tlabel{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-deep);font-weight:600;margin-bottom:16px}
.toc ul{list-style:none;display:flex;flex-direction:column;gap:2px;border-left:1px solid var(--line)}
.toc a{display:block;padding:9px 16px;font-size:.86rem;color:var(--ink-soft);margin-left:-1px;border-left:2px solid transparent;transition:.2s}
.toc a:hover{color:var(--ink)}
.toc a.active{color:var(--gold-deep);border-left-color:var(--gold);font-weight:600}

/* shared rich content (page/post the_content output) */
.entry-content{max-width:760px}
.entry-content > *{max-width:720px}
.entry-content h2{font-size:clamp(1.7rem,3.4vw,2.4rem);font-weight:800;margin:48px 0 18px;scroll-margin-top:96px;position:relative}
.entry-content h2:first-child{margin-top:0}
.entry-content h2::after{content:"";display:block;width:64px;height:2px;background:linear-gradient(90deg,var(--gold-deep),var(--gold-lt));margin-top:16px}
.entry-content h3{font-size:1.4rem;margin:32px 0 12px}
.entry-content p{font-family:'Cormorant Garamond',serif;font-size:1.28rem;line-height:1.7;color:var(--ink-2);margin-bottom:22px}
.entry-content ul,.entry-content ol{list-style:none;margin:6px 0 24px;padding:0}
.entry-content ul li,.entry-content ol li{font-family:'Cormorant Garamond',serif;font-size:1.22rem;color:var(--ink-2);padding:10px 0 10px 28px;position:relative;border-top:1px solid var(--line-2)}
.entry-content ul li:first-child,.entry-content ol li:first-child{border-top:0}
.entry-content ul li::before{content:"";position:absolute;left:0;top:19px;width:8px;height:8px;background:var(--gold);transform:rotate(45deg)}
.entry-content ol{counter-reset:li}
.entry-content ol li::before{counter-increment:li;content:counter(li);position:absolute;left:0;top:10px;font-family:'Playfair Display',serif;font-style:italic;color:var(--gold);font-size:1rem}
.entry-content blockquote{margin:32px 0;padding:6px 0 6px 28px;border-left:3px solid var(--gold)}
.entry-content blockquote p{font-family:'Playfair Display',serif;font-style:italic;font-size:1.6rem;line-height:1.35;color:var(--ink)}
.entry-content blockquote cite{display:block;margin-top:10px;font-style:normal;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);font-weight:600;font-family:'Inter',sans-serif}
.entry-content img,.entry-content figure{border-radius:4px;margin:30px 0}
.entry-content figcaption{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.02rem;color:var(--ink-soft);text-align:center;margin-top:10px}
.entry-content .wp-block-embed,.entry-content iframe{margin:32px 0}
.entry-content a:not(.buy):not(.btn-gold){color:var(--gold-deep);border-bottom:1px solid var(--line);transition:border-color .2s}
.entry-content a:not(.buy):not(.btn-gold):hover{border-color:var(--gold)}
.detail-dropcap .entry-content > p:first-of-type::first-letter{font-family:'Playfair Display',serif;font-weight:800;float:left;font-size:3.8rem;line-height:.78;padding:6px 12px 0 0;color:var(--gold-deep)}

/* explore-more cross-links */
.more{background:var(--paper-2);border-top:1px solid var(--line);padding:64px 0}
.more .mhead{margin-bottom:30px}
.more h2{font-size:2rem;margin-bottom:8px}
.more p{font-family:'Cormorant Garamond',serif;font-size:1.2rem;color:var(--ink-soft)}
.more .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.more .mcard{background:var(--paper);border:1px solid var(--line);border-radius:3px;padding:26px 22px;transition:transform .25s var(--ease),box-shadow .25s,border-color .25s;display:flex;flex-direction:column;gap:8px;text-align:left}
.more .mcard:hover{transform:translateY(-5px);box-shadow:0 26px 50px -30px rgba(22,32,44,.5);border-color:rgba(181,137,60,.45)}
.more .mcard .k{font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);font-weight:600}
.more .mcard h3{font-size:1.22rem}
.more .mcard .go{margin-top:6px;font-size:.76rem;letter-spacing:.08em;font-weight:600;color:var(--ink);display:inline-flex;gap:7px;border-bottom:1.5px solid var(--gold);padding-bottom:3px;align-self:flex-start;transition:gap .2s var(--ease)}
.more .mcard:hover .go{gap:13px}

/* single talk article extras */
.article{padding:140px 0 40px}
.article .col{width:min(760px,90vw);margin-inline:auto}
.article h1{font-size:clamp(2.2rem,5.2vw,3.5rem);font-weight:800;margin-bottom:22px}
.article .lede{font-family:'Cormorant Garamond',serif;font-size:1.45rem;color:var(--ink-2);line-height:1.5;margin-bottom:28px}
.byline{display:flex;flex-wrap:wrap;align-items:center;gap:14px 22px;padding:18px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.byline .who{display:flex;align-items:center;gap:12px}
.byline .av{width:44px;height:44px;border-radius:50%;background:linear-gradient(145deg,var(--gold-lt),var(--gold));display:grid;place-items:center;font-family:'Playfair Display',serif;font-weight:800;color:var(--ink);font-size:.95rem}
.byline .who b{font-family:'Playfair Display',serif;font-size:1rem}
.byline .who span{display:block;font-size:.78rem;color:var(--ink-soft)}
.byline .facts{display:flex;flex-wrap:wrap;gap:8px 20px;margin-left:auto;font-size:.8rem;letter-spacing:.04em;color:var(--ink-soft)}
.byline .facts b{color:var(--gold-deep);font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:.68rem;margin-right:6px}
.feature{margin:34px auto;width:min(1040px,92vw)}
.feature img{border-radius:4px;width:100%}
.endbar{width:min(760px,90vw);margin:46px auto 0;padding-top:26px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:18px;justify-content:space-between;align-items:center}
.tags{display:flex;flex-wrap:wrap;gap:9px}
.tags a{font-size:.74rem;letter-spacing:.06em;color:var(--ink-soft);border:1px solid var(--line);padding:7px 13px;border-radius:999px}
.tags a:hover{border-color:var(--gold);color:var(--gold-deep)}
.related{background:var(--paper-2);border-top:1px solid var(--line);padding:64px 0}
.related .head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:34px;gap:16px;flex-wrap:wrap}
.related h2{font-size:2rem}

/* ---------- MOTION · scroll reveal ---------- */
.has-reveal .reveal{opacity:0;transform:translateY(28px);transition:opacity .85s var(--ease),transform .85s var(--ease)}
.has-reveal .reveal.in{opacity:1;transform:none}
.has-reveal .hero h1,.has-reveal .hero .kicker,.has-reveal .hero .sub,.has-reveal .hero .h-actions,.has-reveal .hero-portrait{opacity:0;transform:translateY(22px);animation:heroIn .9s var(--ease) forwards}
.has-reveal .hero .kicker{animation-delay:.05s}
.has-reveal .hero h1{animation-delay:.15s}
.has-reveal .hero .sub{animation-delay:.3s}
.has-reveal .hero .h-actions{animation-delay:.42s}
.has-reveal .hero-portrait{animation-delay:.25s}
@keyframes heroIn{to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){
  .has-reveal .reveal,.has-reveal .hero h1,.has-reveal .hero .kicker,.has-reveal .hero .sub,.has-reveal .hero .h-actions,.has-reveal .hero-portrait{opacity:1!important;transform:none!important;animation:none!important;transition:none!important}
  html{scroll-behavior:auto}
}

/* ---------- RESPONSIVE ---------- */
@media(max-width:1000px){
  .mast .mcta{display:none}
  .burger{display:flex;z-index:70}
  .mast nav{position:absolute;top:100%;left:0;right:0;background:rgba(247,242,234,.98);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-top:1px solid var(--line);border-bottom:1px solid var(--line);box-shadow:0 22px 44px -26px rgba(22,32,44,.55);max-height:0;overflow:hidden;transition:max-height .42s var(--ease)}
  header.mast.nav-open nav{max-height:75vh}
  .mast nav ul{flex-direction:column;gap:0;padding:6px 0}
  .mast nav a{display:block;padding:16px 7vw;font-size:.82rem;border-bottom:1px solid var(--line-2)}
  .mast nav a::after{display:none}
  .mast nav li:last-child a{border-bottom:0}
  header.mast.nav-open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  header.mast.nav-open .burger span:nth-child(2){opacity:0}
  header.mast.nav-open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .mast .wrap{height:72px}
  header.mast.scrolled .wrap{height:62px}
  section[id]{scroll-margin-top:80px}
  .hero{padding:118px 0 64px}
  .hero .wrap,.profile,.coach,.contact,.ministry .mg{grid-template-columns:1fr;gap:42px}
  .hero-portrait{justify-self:center;order:-1}
  .hero .side-label{display:none}
  .metrics,.roles,.honours{grid-template-columns:1fr}
  .metric{border-right:0;border-bottom:1px solid var(--line)}
  .metric:last-child{border-bottom:0}
  .shelf{grid-template-columns:1fr 1fr}
  .talks{grid-template-columns:1fr 1fr}
  .shop{grid-template-columns:1fr}
  .role,.honour{border-top:1px solid var(--line)}
  .section--ink .role{border-top:1px solid rgba(255,255,255,.12)}
  .foot-top{grid-template-columns:1fr 1fr;gap:36px}
  .detail-layout{grid-template-columns:1fr;gap:30px}
  .toc{position:static;border:1px solid var(--line);border-radius:4px;padding:18px 20px;background:var(--paper-2)}
  .toc ul{border-left:0;flex-flow:row wrap;gap:6px 8px}
  .toc a{border-left:0;border:1px solid var(--line);border-radius:999px;padding:7px 13px;font-size:.78rem;margin:0}
  .toc a.active{border-color:var(--gold);background:var(--paper)}
  .more .grid{grid-template-columns:1fr 1fr}
  .phero{padding:120px 0 36px}
  .article{padding:118px 0 36px}
}
@media(max-width:620px){
  .talks{grid-template-columns:1fr}
}
@media(max-width:560px){
  .wrap{width:90vw}
  .hero{padding:108px 0 56px}
  .hero h1{font-size:clamp(2.3rem,11vw,3.4rem)}
  .hero h1 .it{font-size:.7em}
  .hero .sub{font-size:1.22rem;margin:22px 0 24px}
  .hero-portrait .pf{width:min(86vw,320px)}
  .hero-portrait .tab{left:8px;bottom:16px;padding:13px 16px}
  .hero-portrait .tab .v{font-size:.95rem}
  .hero-portrait .est{right:10px;font-size:.95rem}
  .signature{font-size:2.1rem}
  .creds .wrap{gap:10px 20px;padding:20px 0}
  .creds span{font-size:.72rem;letter-spacing:.1em;gap:0}
  .creds span::after{display:none}
  .sec-head{grid-template-columns:1fr;gap:6px}
  .sec-head .idx{font-size:1.2rem}
  .sec-head h2{font-size:clamp(1.8rem,7.5vw,2.3rem)}
  .sec-head .lead{font-size:1.18rem}
  .profile p,.coach p,.entry-content p{font-size:1.18rem}
  .profile > div:first-child > p:first-of-type::first-letter{font-size:3.6rem}
  .metric{padding:30px 24px}.metric .big{font-size:2.8rem}
  .shelf{grid-template-columns:1fr 1fr;gap:18px}
  .vol .cover b{font-size:1.02rem}
  .tl-row{grid-template-columns:1fr;gap:6px;padding:24px 0}
  .tl-row .yr{font-size:1.25rem}
  .fact{grid-template-columns:1fr;gap:4px}
  .fact .fk{padding-top:0}
  .litbook{padding:28px 24px}
  .ministry{padding:40px 24px}
  .press .logos{gap:14px 26px}.press .logos span{font-size:1.2rem}
  .cform{padding:28px 22px}
  .cinfo .ci .v{font-size:1.12rem}
  .foot-top{grid-template-columns:1fr;gap:30px}
  .foot-bot{flex-direction:column}
  .more .grid{grid-template-columns:1fr}
}
@media(max-width:380px){
  .shelf{grid-template-columns:1fr}
}
