/* ============================================================
   Amir Zaheri — Editorial site  ·  shared stylesheet
   Used by index.html, bio.html, contact.html
   ============================================================ */
:root{
  --bg:#faf6ec;
  --bg-alt:#f3ecdd;
  --ink:#211e1a;
  --muted:#6c6253;
  --line:#ddd2bf;
  --accent:#7c2d2d;
  --accent-press:#5f2020;
  --maxw:1120px;
  --pad:clamp(1.25rem,5vw,3rem);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;
  font-family:"Libre Caslon Text",Georgia,"Times New Roman",serif;
  color:var(--ink);
  background:var(--bg);
  font-size:1.06rem;
  line-height:1.68;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
header.site .wrap{max-width:1320px}
.serif-display{font-family:"Libre Caslon Text",Georgia,serif}

.skip{position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;padding:.6rem 1rem;z-index:200}
.skip:focus{left:0}

.eyebrow{font-size:.78rem;letter-spacing:.32em;text-transform:uppercase;color:var(--accent);font-weight:600;margin:0 0 1.4rem;font-family:"Libre Caslon Text",serif}
.muted{color:var(--muted)}

/* nav */
header.site{position:sticky;top:0;z-index:100;background:rgba(250,246,236,.9);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{font-family:"Libre Caslon Text",serif;font-weight:600;font-size:1.18rem;letter-spacing:.01em}
.nav-links{display:flex;gap:1.05rem;align-items:center}
.nav-links a{font-size:.86rem;color:var(--muted);position:relative}
.nav-links a:hover,.nav-links a:focus-visible{color:var(--ink)}
.nav-links a.active{color:var(--ink)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-3px;height:1px;width:0;background:var(--accent);transition:width .25s ease}
.nav-links a:hover::after,.nav-links a:focus-visible::after,.nav-links a.active::after{width:100%}
.nav-cta{border:1px solid var(--ink);padding:.45rem 1.15rem !important;border-radius:2px}
.nav-cta::after{display:none}
.nav-cta:hover{background:var(--ink);color:var(--bg)!important}
.menu-btn{display:none;background:none;border:0;cursor:pointer;padding:.5rem;color:var(--ink)}

/* hero (home) */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.hero::before{display:none}
.hero-inner{position:relative;padding:clamp(3.5rem,9vw,7rem) 0 clamp(3rem,6vw,5rem);display:grid;grid-template-columns:1.4fr .85fr;gap:clamp(2rem,5vw,4rem);align-items:center}
h1.name{font-family:"Libre Caslon Text",serif;font-weight:600;font-size:clamp(2.4rem,5.6vw,4.2rem);line-height:1.03;letter-spacing:-.015em;margin:.3rem 0 1.3rem}
.lede{font-size:clamp(1.05rem,1.5vw,1.3rem);font-style:italic;color:#4a4338;max-width:32ch;margin:0 0 2.2rem;line-height:1.55}
.rule-sm{width:64px;height:2px;background:var(--accent);margin:0 0 2rem}
.btns{display:flex;flex-wrap:wrap;gap:1rem}
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:"Libre Caslon Text",serif;font-size:1.05rem;font-weight:600;padding:.7rem 1.6rem;border:1px solid var(--ink);border-radius:2px;transition:all .2s ease;cursor:pointer;letter-spacing:.01em}
.btn-primary{background:var(--ink);color:var(--bg)}
.btn-primary:hover{background:var(--accent);border-color:var(--accent)}
.btn-ghost:hover{background:var(--ink);color:var(--bg)}
.portrait{aspect-ratio:4/5;border:1px solid var(--line);background:var(--bg-alt);display:flex;align-items:flex-end;position:relative}
.portrait .mono{font-family:"Libre Caslon Text",serif;position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:clamp(4rem,9vw,6.5rem);color:#cfc3ac}
.portrait .cap{position:relative;z-index:1;width:100%;text-align:center;font-size:.8rem;letter-spacing:.04em;color:var(--muted);padding:.7rem;background:rgba(250,246,236,.78);border-top:1px solid var(--line)}

/* interior page banner */
.pagehero{border-bottom:1px solid var(--line);background:var(--bg-alt)}
.pagehero .wrap{padding-top:clamp(2.8rem,6vw,4.5rem);padding-bottom:clamp(2.2rem,5vw,3.5rem)}
.pagehero h1{font-family:"Libre Caslon Text",serif;font-weight:600;font-size:clamp(2rem,4.4vw,3.2rem);line-height:1.05;margin:.2rem 0 .6rem}
.pagehero p{margin:0;color:var(--muted);font-style:italic;font-size:1.15rem;max-width:54ch}
.pagehero h1+p{max-width:none;text-wrap:balance}
.pagehero .eyebrow{max-width:none}
.foot-grid .muted{text-wrap:balance}
.backlink{display:inline-block;margin-bottom:1rem;color:var(--accent);font-size:1rem}
.backlink:hover{text-decoration:underline}

/* credibility */
.cred{background:var(--bg-alt);border-bottom:1px solid var(--line)}
.cred-inner{display:flex;flex-wrap:wrap;gap:.8rem 2rem;justify-content:center;align-items:center;padding:1.3rem 0}
.cred-inner span{font-size:.82rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-style:normal}
.cred-inner .dot{letter-spacing:0;color:var(--accent)}

section.block{padding:clamp(3.5rem,8vw,6rem) 0}
.block.alt{background:var(--bg-alt);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.sec-head{margin-bottom:2.8rem;max-width:62ch}
h2{font-family:"Libre Caslon Text",serif;font-weight:600;font-size:clamp(1.55rem,2.8vw,2.15rem);line-height:1.14;margin:.2rem 0 .8rem}
.sec-head p{color:var(--muted);font-size:1.08rem;margin:0;font-style:italic}

/* listen */
.listen-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.5rem,4vw,3rem);align-items:center}
.spotify-embed{border:1px solid var(--line);background:#fff;padding:6px}
.spotify-embed iframe{display:block;width:100%;border:0}
.platforms{display:flex;flex-direction:column}
.plat{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem .4rem;border-bottom:1px solid var(--line);font-size:1.1rem;transition:padding .2s ease,color .2s ease}
.plat:first-child{border-top:1px solid var(--line)}
.plat:hover{padding-left:1rem;color:var(--accent)}
.plat .arrow{color:var(--accent);transition:transform .2s ease}
.plat:hover .arrow{transform:translateX(4px)}

/* works index */
.index{border-top:1px solid var(--ink)}
.ix{display:grid;grid-template-columns:54px 1fr auto;gap:1.4rem;align-items:baseline;padding:1.5rem .2rem;border-bottom:1px solid var(--line);transition:padding .25s ease}
.ix:hover{padding-left:1rem;background:rgba(124,45,45,.03)}
.ix .num{font-family:"Libre Caslon Text",serif;color:var(--accent);font-size:1.05rem}
.ix h3{font-family:"Libre Caslon Text",serif;font-weight:600;font-size:1.18rem;margin:0 0 .25rem}
.ix p{margin:0;color:var(--muted);font-size:1.02rem}
.ix .ex{font-style:italic;color:#4a4338;text-align:right;max-width:30ch;font-size:1rem}

/* about teaser */
.about-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.about-portrait{aspect-ratio:1/1;border:1px solid var(--line);background:var(--bg-alt);display:flex;align-items:center;justify-content:center;font-family:"Libre Caslon Text",serif;font-size:5rem;color:#cfc3ac}
.about-grid p{font-size:1.08rem;margin:0 0 1.2rem}
.about-grid p.lead::first-letter{font-family:"Libre Caslon Text",serif;float:left;font-size:3rem;line-height:.8;padding:.35rem .5rem 0 0;color:var(--accent)}

/* long-form prose (bio) */
.prose{max-width:70ch;margin:0 auto}
.prose p{font-size:1.1rem;margin:0 0 1.35rem}
.prose p.lead{font-size:1.24rem;font-style:italic;color:#4a4338;line-height:1.5;margin-bottom:2rem}
.prose p.lead::first-letter{font-family:"Libre Caslon Text",serif;float:left;font-size:3.1rem;line-height:.82;padding:.4rem .55rem 0 0;color:var(--accent);font-style:normal}
.prose h2{font-size:clamp(1.3rem,2.4vw,1.7rem);margin:2.6rem 0 1rem}
.prose .hr{border:0;border-top:1px solid var(--line);margin:2.6rem 0}
.pull{font-family:"Libre Caslon Text",serif;font-weight:500;font-size:clamp(1.2rem,2.1vw,1.6rem);line-height:1.3;color:var(--ink);border-left:3px solid var(--accent);padding:.2rem 0 .2rem 1.4rem;margin:2.4rem 0}
.note{background:var(--bg-alt);border:1px solid var(--line);border-radius:3px;padding:1rem 1.2rem;font-size:1rem;font-style:italic;color:var(--muted);margin:1.6rem 0}

/* facts list */
.facts{list-style:none;padding:0;margin:1.4rem 0 0;border-top:1px solid var(--line)}
.facts li{display:grid;grid-template-columns:170px 1fr;gap:1.2rem;padding:.85rem 0;border-bottom:1px solid var(--line);font-size:1.06rem}
.facts li b{font-family:"Libre Caslon Text",serif;font-weight:600;color:var(--accent)}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.form .field{margin-bottom:1.3rem}
.form label{display:block;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem}
.form input,.form textarea{width:100%;font-family:inherit;font-size:1.08rem;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:2px;padding:.8rem .9rem}
.form input:focus,.form textarea:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}
.form textarea{min-height:160px;resize:vertical}
.hp{position:absolute;left:-9999px}

/* highlights timeline */
.timeline{border-top:1px solid var(--ink)}
.tl-row{display:grid;grid-template-columns:110px 1fr;gap:1.6rem;padding:1.5rem 0;border-bottom:1px solid var(--line)}
.tl-row .yr{font-family:"Libre Caslon Text",serif;font-weight:700;color:var(--accent);font-size:1.3rem}
.tl-row .ev{margin:0}
.tl-row .ev strong{font-weight:600}
.tl-row .ev span{display:block;color:var(--muted);font-style:italic;margin-top:.25rem;font-size:1.02rem}

/* CTA */
.cta{background:var(--ink);color:var(--bg);padding:clamp(2.6rem,5vw,4rem);text-align:center;border:1px solid var(--ink)}
.cta h2{color:var(--bg)}
.cta p{color:#d8cdb8;max-width:48ch;margin:0 auto 2rem;font-style:italic;font-size:1.18rem}
.cta .btn{border-color:var(--bg);color:var(--bg)}
.cta .btn-primary{background:var(--bg);color:var(--ink)}
.cta .btn-primary:hover{background:#fff}
.cta .btn-ghost:hover{background:rgba(255,255,255,.12)}

footer.site{padding:clamp(2.5rem,5vw,4rem) 0 2.5rem;border-top:1px solid var(--line)}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:2rem}
.foot-grid h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.22em;color:var(--muted);margin:0 0 1rem;font-weight:600}
.foot-grid a{display:block;color:var(--muted);padding:.3rem 0}
.foot-grid a:hover{color:var(--accent)}
.foot-brand{font-family:"Libre Caslon Text",serif;font-weight:600;font-size:1.28rem;margin:0 0 .5rem}
.foot-bottom{margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:.5rem 1.5rem;justify-content:space-between;color:var(--muted);font-size:.95rem}

.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}
.no-js .reveal{opacity:1;transform:none}

@media (max-width:900px){
  .hero-inner{grid-template-columns:1fr}
  .portrait{max-width:340px;order:-1}
  .listen-grid{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr}
  .about-portrait{max-width:300px}
  .ix{grid-template-columns:40px 1fr;gap:1rem}
  .ix .ex{grid-column:2;text-align:left;margin-top:.4rem}
  .contact-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:1280px){
  .nav-links{position:fixed;inset:74px 0 auto 0;background:var(--bg);border-bottom:1px solid var(--line);flex-direction:column;align-items:flex-start;gap:0;padding:.5rem var(--pad) 1.2rem;transform:translateY(-130%);transition:transform .3s ease}
  .nav-links.open{transform:none}
  .nav-links a{width:100%;padding:.9rem 0;border-bottom:1px solid var(--line);font-size:1rem}
  .nav-links a::after{display:none}
  .nav-cta{margin-top:.8rem;text-align:center;width:100%}
  .menu-btn{display:block}
}
@media (max-width:680px){
  .facts li{grid-template-columns:1fr;gap:.2rem}
  .tl-row{grid-template-columns:70px 1fr;gap:1rem}
  .foot-grid{grid-template-columns:1fr}
}

/* ---- rebuild additions ---- */
.tagline-motto{font-family:"Libre Caslon Text",serif;font-style:italic;font-size:clamp(1.15rem,1.9vw,1.55rem);color:var(--accent);margin:.1rem 0 1.4rem}
.hero-roles{font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:600;margin:0 0 1rem}

/* listen feature (home) */
.listen-feature{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-top:.5rem;align-items:start}
.spotify-embed iframe{display:block;width:100%;border:0;border-radius:10px}

/* compositions */
.comp-cat{padding:2.4rem 0;border-bottom:1px solid var(--line)}
.comp-cat:last-child{border-bottom:0}
.comp-cat .ct{color:var(--muted);font-style:italic;margin:.2rem 0 1.4rem;max-width:62ch}
.embeds{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;align-items:start}
.embed{border:1px solid var(--line);background:#fff;border-radius:10px;overflow:hidden}
.embed.spotify{padding:6px}
.embed.spotify iframe{display:block;width:100%;border:0;border-radius:8px}
.embed.video{position:relative;aspect-ratio:16/9;background:#000}
.embed.video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.cat-jump{display:flex;flex-wrap:wrap;gap:.55rem .7rem;margin:1.6rem 0 0;border-top:1px solid var(--line);padding-top:1.6rem}
.cat-jump a{font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line);border-radius:100px;padding:.45rem 1rem}
.cat-jump a:hover{border-color:var(--ink);color:var(--ink)}

/* woven student-quote band */
.quote-band{background:var(--bg-alt);border-top:1px solid var(--line);border-bottom:1px solid var(--line);text-align:center}
.quote-band .wrap{padding:clamp(2.4rem,5vw,3.6rem) var(--pad)}
.quote-band blockquote{font-family:"Libre Caslon Text",serif;font-weight:500;font-size:clamp(1.25rem,2.3vw,1.8rem);line-height:1.32;max-width:32ch;margin:0 auto;color:var(--ink)}
.quote-band cite{display:block;margin-top:1.1rem;font-style:italic;color:var(--muted);font-size:.98rem}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem}
.gtile{aspect-ratio:1;border:1px solid var(--line);background:linear-gradient(150deg,#efe9dc,#f6f1e6);display:flex;align-items:center;justify-content:center;color:#b7a98d;font-family:"Libre Caslon Text",serif;font-size:.92rem;text-align:center;padding:1rem}

/* ===================== high-class refinements ===================== */
/* cross-page fade transition (progressive enhancement) */
@view-transition{ navigation: auto; }

/* typographic craft: kerning, ligatures, old-style figures, hanging punctuation */
body{font-feature-settings:"kern" 1,"liga" 1,"calt" 1,"onum" 1;-webkit-font-feature-settings:"kern" 1,"liga" 1,"calt" 1,"onum" 1;hanging-punctuation:first allow-end last}
h1,h2,.name,.pagehero h1,.lede,.tagline-motto,.sec-head p,.cta h2,.cta p,.quote-band blockquote,.ix h3{text-wrap:balance}
.prose p,.about-grid p,.ix p,.tl-row .ev,.ct,.facts li span{text-wrap:pretty}

/* catalogue-style numbering (Compositions) */
body{counter-reset:catnum}
.comp-cat{counter-increment:catnum}
.comp-cat h2::before{content:"No. " counter(catnum,decimal-leading-zero);display:block;font-family:"Libre Caslon Text",serif;font-style:italic;font-size:.92rem;letter-spacing:.06em;color:var(--accent);margin-bottom:.3rem;font-feature-settings:"lnum" 1}

/* signature staff-line motif */
.staff-rule{height:18px;width:120px;margin:0 0 2rem;background:repeating-linear-gradient(0deg,var(--accent) 0 1px,transparent 1px 5px);opacity:.5}
.hero-staff{display:block;width:min(440px,86%);height:auto;margin:.5rem 0 2rem;overflow:visible}
.hero-staff line,.hero-staff .bar{stroke:var(--ink);stroke-width:1;opacity:.45}
.hero-staff .ink{stroke-dasharray:430;stroke-dashoffset:430;animation:staffdraw 1.5s cubic-bezier(.7,0,.2,1) .3s forwards}
.hero-staff .bar{stroke-dasharray:40;stroke-dashoffset:40;animation:staffdraw 1.5s ease .3s forwards}
.hero-staff .note{opacity:0;animation:notein .55s ease forwards}
.hero-staff .note ellipse{fill:var(--accent)}
.hero-staff .note line{stroke:var(--accent);stroke-width:1.5;opacity:.85}
.hero-staff .note:nth-of-type(1){animation-delay:1.1s}
.hero-staff .note:nth-of-type(2){animation-delay:1.24s}
.hero-staff .note:nth-of-type(3){animation-delay:1.38s}
.hero-staff .note:nth-of-type(4){animation-delay:1.52s}
.hero-staff .note:nth-of-type(5){animation-delay:1.66s}
.hero-staff .note:nth-of-type(6){animation-delay:1.8s}
@keyframes notein{from{opacity:0;transform:translateY(-7px)}to{opacity:.9;transform:none}}
@keyframes staffdraw{to{stroke-dashoffset:0}}
footer.site .wrap::before{content:"";display:block;height:16px;width:120px;margin:0 auto clamp(1.6rem,4vw,2.6rem);background:repeating-linear-gradient(0deg,var(--line) 0 1px,transparent 1px 5px)}

/* condensing header */
header.site{transition:background .3s ease,box-shadow .3s ease}
.nav{transition:height .28s ease}
header.site.scrolled{background:rgba(250,246,236,.96);box-shadow:0 8px 30px rgba(33,30,26,.08)}
header.site.scrolled .nav{height:60px}

/* scroll-progress hairline */
.scroll-progress{position:fixed;top:0;left:0;height:2px;width:100%;transform:scaleX(0);transform-origin:0 50%;background:var(--accent);z-index:300;will-change:transform}

/* paper grain (barely there) */
body::after{content:"";position:fixed;inset:0;z-index:60;pointer-events:none;opacity:.05;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:180px}

/* duotone treatment for photos (add class="duotone" to an <img>) */
.duotone{filter:grayscale(1) sepia(.26) contrast(1.03) brightness(1.02);transition:filter .4s ease}
.duotone:hover{filter:grayscale(.45) sepia(.12) contrast(1.03)}

/* dramatic dark feature band */
.quote-band.dark{background:var(--ink);border-color:var(--ink)}
.quote-band.dark blockquote{color:#fbf7ee}
.quote-band.dark cite{color:#c9bfa8}

/* refined focus + selection */
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:2px}
::selection{background:rgba(124,45,45,.16)}

/* print */
@media print{
  header.site,.menu-btn,.scroll-progress,.cta,.btns,.btn,.cat-jump,.embeds,.spotify-embed,.listen-feature,.quote-band,footer.site{display:none!important}
  body{background:#fff;color:#000;font-size:11.5pt}
  body::after{display:none}
  .pagehero{border:0}
  .wrap{max-width:none;padding:0 1.5rem}
  .prose{max-width:38em}
  a{color:#000;text-decoration:none}
  h1,h2{color:#000}
}
@media (prefers-reduced-motion:reduce){
  .hero-staff .ink{animation:none;stroke-dashoffset:0}
  .nav,header.site{transition:none}
  .scroll-progress{display:none}
}

/* ===================== Didone identity + counterpoint ===================== */
/* the serif "voice": lead and accent italics over the grotesque body */
.lede,.prose p.lead,.tagline-motto,.sec-head p,.ct,.quote-band cite,.cred-inner span{font-family:"Libre Caslon Text",Georgia,serif}
/* high-contrast display tuning */
.name,.pagehero h1,h1,h2,.brand,.foot-brand,.pull{letter-spacing:-.005em}
.name,.pagehero h1{font-weight:600}
/* canon: imitative, staggered hero entrance (voice, then answer) */
.hero-intro>*{opacity:0;animation:rise .9s cubic-bezier(.2,.7,.2,1) forwards}
.hero-intro .hero-roles{animation-delay:.04s}
.hero-intro .name{animation-delay:.16s}
.hero-intro .hero-staff{animation-delay:.3s}
.hero-intro .tagline-motto{animation-delay:.5s}
.hero-intro .lede{animation-delay:.62s}
.hero-intro .btns{animation-delay:.74s}
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){
  .hero-intro>*{opacity:1;animation:none}
  .hero-staff .note{opacity:.9;animation:none}
  .hero-staff .bar{stroke-dashoffset:0;animation:none}
}

/* ===================== Type system D — Libre Caslon + Libre Franklin ===================== */
body{font-family:"Libre Caslon Text",Georgia,"Times New Roman",serif}
h1,h2,.name,.pagehero h1,.cta h2,.quote-band blockquote,.serif-display,.prose p.lead::first-letter,.about-grid p.lead::first-letter{font-family:"Libre Caslon Display","Libre Caslon Text",Georgia,serif;font-weight:400}
h3,.ix h3,.pull,.tl-row .yr,.facts li b,.brand,.foot-brand{font-family:"Libre Caslon Text",Georgia,serif;font-weight:700}
.eyebrow,.hero-roles,.nav-links a,.foot-grid h4,.cat-jump a,.form label,.btn,.menu-btn,.work .ex,.ix .num{font-family:"Libre Caslon Text",Georgia,serif;font-weight:400}
.lede,.prose p.lead,.tagline-motto,.sec-head p,.ct,.quote-band cite,.cred-inner span,.comp-cat h2::before{font-family:"Libre Caslon Text",Georgia,serif}
h1.name,.pagehero h1{font-family:"Libre Caslon Display","Libre Caslon Text",Georgia,serif;font-weight:400;letter-spacing:0}
.lede{line-height:1.5}

/* ---- Portrait imagery ---- */
.portrait{overflow:hidden}
.portrait img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.about-portrait{position:relative;overflow:hidden;padding:0}
.about-portrait img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 22%;display:block}
.portrait-figure{float:right;width:min(42%,300px);margin:.3rem 0 1.1rem 1.8rem;border:1px solid var(--line);background:var(--bg-alt)}
.portrait-figure img{display:block;width:100%;height:auto}
@media (max-width:680px){.portrait-figure{float:none;width:100%;max-width:320px;margin:0 auto 1.4rem}}
.gtile-img{padding:0;overflow:hidden}
.gtile-img img{width:100%;height:100%;object-fit:cover;display:block}
.prose h2{clear:right}
.gtile-img img{object-position:center 16%}

/* ---- Section feature images & worship strip ---- */
.feature-photo{margin:0 auto 1.8rem;border:1px solid var(--line);background:var(--bg-alt);max-width:560px}
.feature-photo img{display:block;width:100%;height:auto}
.feature-photo figcaption{font-size:.78rem;color:var(--muted);letter-spacing:.04em;text-align:center;padding:.55rem .6rem;border-top:1px solid var(--line)}
.photo-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.5rem}
.photo-strip figure{margin:0;border:1px solid var(--line);overflow:hidden;position:relative}
.photo-strip img{width:100%;aspect-ratio:1;object-fit:cover;object-position:center 30%;display:block}
.photo-strip figcaption{position:absolute;left:0;right:0;bottom:0;font-size:.72rem;letter-spacing:.05em;color:#f4ecdc;background:linear-gradient(to top,rgba(20,18,16,.85),rgba(20,18,16,0));padding:1rem .5rem .45rem;text-align:center}
.gtile-img img{object-position:center 25%}
.portrait-figure.left{float:left;margin:.3rem 1.8rem 1.1rem 0}
.portrait-figure figcaption{font-size:.72rem;color:var(--muted);letter-spacing:.03em;text-align:center;padding:.45rem .5rem;border-top:1px solid var(--line)}
.prose hr{clear:both}
@media (max-width:680px){.portrait-figure.left{float:none;width:100%;max-width:320px;margin:0 auto 1.4rem}}
.foot-fineprint{margin:1.6rem 0 0;font-size:.74rem;line-height:1.55;color:var(--muted);opacity:.82;max-width:84ch}
