/* ============================================================================
   The Thomas F. McDaniel Archive — "scholar's manuscript"
   Parchment ground · Cinzel inscriptional caps · EB Garamond reading face
   Oxblood rubrication · antique-gold hairlines
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;500;600&family=EB+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&display=swap');

:root{
  --paper:#f3ecdc;          /* aged parchment ground            */
  --paper-2:#f8f2e6;        /* lighter card surface             */
  --paper-edge:#e7dcc4;     /* subtle panel / border fill       */
  --ink:#262119;            /* warm near-black body text        */
  --ink-soft:#574d3c;       /* secondary text                   */
  --ink-faint:#857862;      /* meta / captions                  */
  --indigo:#22324d;         /* iron-gall ink — headings/masthead*/
  --indigo-deep:#1a2740;
  --rubric:#8a2f24;         /* oxblood — links, marks, accents  */
  --rubric-deep:#6f241c;
  --gold:#9c7b3c;           /* antique gold — hairlines/details */
  --gold-soft:#bfa066;
  --rule:#d8cbac;           /* hairline color                   */

  --measure:38rem;          /* reading width                    */
  --shadow:0 1px 2px rgba(38,33,25,.06), 0 12px 34px -16px rgba(38,33,25,.28);
  --shadow-lift:0 2px 4px rgba(38,33,25,.08), 0 22px 48px -18px rgba(38,33,25,.38);

  --serif:'EB Garamond', Georgia, 'Times New Roman', serif;
  --display:'Cinzel', 'EB Garamond', Georgia, serif;
}

/* ---- reset ---------------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--serif);
  font-size:clamp(1.06rem,.98rem + .35vw,1.22rem);
  line-height:1.66;
  color:var(--ink);
  background-color:var(--paper);
  /* layered atmosphere: warm vignette + faint paper grain */
  background-image:
    radial-gradient(120% 80% at 50% -10%, rgba(255,250,238,.85), rgba(243,236,220,0) 60%),
    radial-gradient(130% 120% at 100% 0%, rgba(156,123,60,.06), rgba(243,236,220,0) 55%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' 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.045'/%3E%3C/svg%3E");
  background-attachment:fixed,fixed,fixed;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  overflow-wrap:break-word;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--rubric);text-decoration:none}

/* ---- typographic rhythm -------------------------------------------------- */
h1,h2,h3,h4{font-weight:500;line-height:1.16;color:var(--indigo);margin:0 0 .4em}
h2,h3,h4{font-family:var(--serif)}
p{margin:0 0 1.1em}
em,i{font-style:italic}

.eyebrow{
  font-family:var(--display);
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:.32em;
  font-size:.7rem;
  color:var(--rubric);
  margin:0 0 1.1rem;
}
.lede{font-size:1.16em;color:var(--ink-soft)}
.muted{color:var(--ink-faint)}

/* hebrew/greek inline runs keep a comfortable size */
.script{font-size:1.05em}

/* ---- layout -------------------------------------------------------------- */
.wrap{width:100%;max-width:72rem;margin:0 auto;padding:0 clamp(1.1rem,4vw,2.5rem)}
.narrow{max-width:52rem}
section{padding-top:clamp(3rem,7vw,5.5rem);padding-bottom:clamp(3rem,7vw,5.5rem)}
.rule{border:0;height:1px;background:var(--rule);margin:0}
.section-head{margin-bottom:2.2rem}
.section-head h2{font-size:clamp(1.7rem,1.3rem + 1.6vw,2.5rem)}

/* ornamental divider (gold diamond between rules) */
.ornament{display:flex;align-items:center;gap:1rem;color:var(--gold);margin:0 auto}
.ornament::before,.ornament::after{content:"";height:1px;background:var(--rule);flex:1}
.ornament span{font-size:.8rem;letter-spacing:.2em}

/* ---- masthead / nav ------------------------------------------------------ */
.masthead{
  position:sticky;top:0;z-index:40;
  background:rgba(243,236,220,.86);
  backdrop-filter:saturate(140%) blur(8px);
  -webkit-backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--rule);
}
.masthead__inner{display:flex;align-items:center;justify-content:space-between;gap:1.2rem;padding-top:.85rem;padding-bottom:.85rem}
.brand{display:flex;flex-direction:column;line-height:1.05;color:var(--indigo)}
.brand__name{font-family:var(--display);font-weight:600;letter-spacing:.06em;font-size:1.04rem;text-transform:uppercase}
.brand__sub{font-size:.72rem;letter-spacing:.12em;color:var(--ink-faint);text-transform:uppercase;margin-top:.2rem}
.nav{display:flex;align-items:center;gap:1.4rem}
.nav a{
  color:var(--ink-soft);font-size:.95rem;letter-spacing:.02em;
  padding:.15rem 0;position:relative;
}
.nav a::after{
  content:"";position:absolute;left:0;right:100%;bottom:-2px;height:1.5px;
  background:var(--rubric);transition:right .28s ease;
}
.nav a:hover,.nav a[aria-current="page"]{color:var(--rubric)}
.nav a:hover::after,.nav a[aria-current="page"]::after{right:0}
.nav__toggle{display:none}

/* ---- hero ---------------------------------------------------------------- */
.hero{position:relative;padding-top:clamp(3rem,8vw,6.5rem);padding-bottom:clamp(2.5rem,6vw,4rem)}
.hero__grid{display:grid;grid-template-columns:1.5fr .9fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.hero h1{
  font-family:var(--display);font-weight:600;
  font-size:clamp(2.2rem,1.4rem + 4vw,4.1rem);
  letter-spacing:.01em;line-height:1.04;color:var(--indigo-deep);
  margin:0 0 .5em;
}
.hero h1 .sm{display:block;font-size:.34em;letter-spacing:.34em;color:var(--rubric);margin-bottom:.9rem;text-transform:uppercase}
.hero__role{font-size:1.18em;color:var(--ink-soft);font-style:italic;margin-bottom:1.4rem}
.hero__portrait{position:relative}
.hero__portrait img{
  width:100%;border-radius:2px;
  box-shadow:var(--shadow-lift);
  filter:sepia(.12) saturate(.92);
  border:1px solid var(--paper-edge);
}
.hero__portrait figcaption{font-size:.78rem;color:var(--ink-faint);text-align:center;margin-top:.6rem;letter-spacing:.04em}
.hero__frame{position:absolute;inset:-.7rem;border:1px solid var(--gold-soft);border-radius:3px;pointer-events:none;opacity:.6}

/* multiscript banner */
.scripts{display:flex;flex-wrap:wrap;gap:1.4rem 2rem;align-items:center;justify-content:center;padding:1.4rem 0;opacity:.9}
.scripts img{height:1.5rem;width:auto;opacity:.78;filter:sepia(.3) brightness(.4) saturate(1.6)}

/* ---- buttons ------------------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--serif);font-size:1rem;letter-spacing:.02em;
  padding:.6rem 1.25rem;border-radius:2px;cursor:pointer;
  transition:transform .18s ease, background .2s ease, color .2s ease, box-shadow .2s ease;
}
.btn--primary{background:var(--rubric);color:#f8f2e6;border:1px solid var(--rubric-deep)}
.btn--primary:hover{background:var(--rubric-deep);transform:translateY(-1px);box-shadow:var(--shadow)}
.btn--ghost{background:transparent;color:var(--indigo);border:1px solid var(--rule)}
.btn--ghost:hover{border-color:var(--rubric);color:var(--rubric)}
.btn--sm{padding:.4rem .85rem;font-size:.9rem}
.btn-row{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.5rem}

/* inline read link with drawn underline */
.ilink{color:var(--rubric);background-image:linear-gradient(var(--gold-soft),var(--gold-soft));background-size:0 1px;background-position:0 100%;background-repeat:no-repeat;transition:background-size .3s ease}
.ilink:hover{background-size:100% 1px}

/* ---- volumes grid -------------------------------------------------------- */
.volumes{display:grid;grid-template-columns:repeat(auto-fill,minmax(17rem,1fr));gap:1.4rem}
.vcard{
  position:relative;display:flex;flex-direction:column;
  background:var(--paper-2);border:1px solid var(--paper-edge);border-radius:3px;
  padding:1.6rem 1.5rem 1.4rem;box-shadow:var(--shadow);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  overflow:hidden;
}
.vcard::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(var(--rubric),var(--rubric-deep))}
.vcard:hover{transform:translateY(-3px);box-shadow:var(--shadow-lift);border-color:var(--gold-soft)}
.vcard__no{font-family:var(--display);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--rubric)}
.vcard__title{font-size:1.32rem;line-height:1.18;margin:.5rem 0 .4rem;color:var(--indigo)}
.vcard__meta{font-size:.82rem;color:var(--ink-faint);letter-spacing:.04em;margin-bottom:.8rem}
.vcard__blurb{font-size:.98rem;color:var(--ink-soft);margin-bottom:1.1rem;flex:1}
.vcard__links{display:flex;gap:.5rem;flex-wrap:wrap}

/* ---- book page ----------------------------------------------------------- */
.book{display:grid;grid-template-columns:18rem 1fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.book__aside{position:sticky;top:5.2rem}
.book__cover{background:var(--paper-2);border:1px solid var(--paper-edge);border-radius:3px;padding:1.6rem;box-shadow:var(--shadow);text-align:center}
.book__cover .vcard__no{display:block;margin-bottom:.6rem}
.book__cover h1{font-size:1.55rem;color:var(--indigo)}
.book__facts{list-style:none;margin:1.3rem 0 0;padding:1.3rem 0 0;border-top:1px solid var(--rule);font-size:.9rem}
.book__facts li{display:flex;justify-content:space-between;gap:1rem;padding:.28rem 0;color:var(--ink-soft)}
.book__facts li span:first-child{color:var(--ink-faint);letter-spacing:.04em}
.book__intro{max-width:var(--measure)}
.book__intro .lede{font-size:1.22em}

/* table of contents */
.toc{margin-top:2rem}
.toc h2{font-size:1.05rem;text-transform:uppercase;letter-spacing:.18em;color:var(--ink-faint);font-weight:500;margin-bottom:.4rem}
.toc__list{list-style:none;margin:0;padding:0;border-top:1px solid var(--rule)}
.toc__item{display:flex;align-items:baseline;gap:1rem;padding:.72rem 0;border-bottom:1px solid var(--rule);transition:padding-left .2s ease}
.toc__item:hover{padding-left:.4rem}
.toc__num{flex:0 0 2.4rem;font-family:var(--display);color:var(--rubric);font-size:.95rem;text-align:right;letter-spacing:.02em}
.toc__item.is-front .toc__num{color:var(--gold);font-size:.78rem}
.toc__link{color:var(--ink);flex:1;line-height:1.35}
.toc__link:hover{color:var(--rubric)}
.toc__sub{display:block;margin-top:.2rem}
.toc__sub a{font-size:.82rem;color:var(--ink-faint);margin-right:.9rem}
.toc__sub a:hover{color:var(--rubric)}
.toc__pdf{flex:0 0 auto;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);opacity:0;transition:opacity .2s ease}
.toc__item:hover .toc__pdf{opacity:1}

/* generic apparatus list (bibliographies, indices, extras) */
.apparatus{margin-top:2.2rem}
.apparatus h2{font-size:1.05rem;text-transform:uppercase;letter-spacing:.18em;color:var(--ink-faint);font-weight:500}
.chiplist{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:.8rem}
.chip{display:inline-flex;align-items:center;gap:.4rem;font-size:.88rem;padding:.34rem .8rem;border:1px solid var(--rule);border-radius:2px;background:var(--paper-2);color:var(--ink-soft)}
.chip:hover{border-color:var(--rubric);color:var(--rubric)}

/* ---- chronological / index lists (writings, sermons) --------------------- */
.entries{list-style:none;margin:0;padding:0;max-width:54rem}
.entry{display:grid;grid-template-columns:5rem 1fr;gap:1.4rem;padding:1rem 0;border-bottom:1px solid var(--rule);align-items:baseline}
.entry__year{font-family:var(--display);color:var(--rubric);font-size:.92rem;letter-spacing:.06em}
.entry__title{color:var(--ink);line-height:1.4}
.entry__title a{color:var(--ink)}
.entry__title a:hover{color:var(--rubric)}
.entry__where{display:block;color:var(--ink-faint);font-size:.9rem;font-style:italic;margin-top:.15rem}
.tag{display:inline-block;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);border:1px solid var(--rule);border-radius:2px;padding:.05rem .4rem;margin-left:.5rem;vertical-align:.08em}
.tag--ext{color:var(--gold);border-color:var(--gold-soft)}

/* ---- resources cards ----------------------------------------------------- */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(18rem,1fr));gap:1.2rem}
.rcard{display:block;background:var(--paper-2);border:1px solid var(--paper-edge);border-radius:3px;padding:1.3rem 1.4rem;box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}
.rcard:hover{transform:translateY(-2px);box-shadow:var(--shadow-lift);border-color:var(--gold-soft)}
.rcard h3{font-size:1.12rem;color:var(--indigo);margin-bottom:.35rem}
.rcard p{font-size:.92rem;color:var(--ink-soft);margin:0}
.rcard__cue{display:inline-block;margin-top:.7rem;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--rubric)}

/* ---- prose / CV / essay -------------------------------------------------- */
.prose{max-width:var(--measure)}
.prose h2{font-size:1.5rem;margin-top:2.4rem;color:var(--indigo)}
.prose h3{font-size:1.05rem;text-transform:uppercase;letter-spacing:.16em;color:var(--rubric);font-weight:500;margin-top:2.2rem}
.cv-list{list-style:none;margin:.6rem 0 0;padding:0}
.cv-list li{position:relative;padding:.45rem 0 .45rem 1.4rem;border-bottom:1px solid var(--rule);color:var(--ink-soft)}
.cv-list li::before{content:"";position:absolute;left:0;top:1.1rem;width:.4rem;height:.4rem;background:var(--gold);transform:rotate(45deg)}

/* drop-cap rubricated initial */
.dropcap::first-letter{
  font-family:var(--display);font-weight:600;
  float:left;font-size:3.6em;line-height:.74;
  padding:.06em .12em 0 0;color:var(--rubric);
}
.epigraph{border-left:2px solid var(--gold-soft);padding:.2rem 0 .2rem 1.4rem;margin:0 0 2rem;font-style:italic;color:var(--ink-soft)}
.epigraph cite{display:block;font-style:normal;font-family:var(--display);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--rubric);margin-top:.7rem}

/* ---- callout / contact --------------------------------------------------- */
.callout{background:var(--paper-2);border:1px solid var(--paper-edge);border-left:4px solid var(--rubric);border-radius:3px;padding:1.6rem 1.8rem;box-shadow:var(--shadow)}

/* ---- footer -------------------------------------------------------------- */
.foot{border-top:1px solid var(--rule);background:linear-gradient(var(--paper),var(--paper-edge));margin-top:2rem}
.foot__inner{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem;padding-top:3rem;padding-bottom:2rem}
.foot h4{font-family:var(--display);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--rubric);margin-bottom:.9rem}
.foot a{color:var(--ink-soft);display:block;padding:.18rem 0;font-size:.95rem}
.foot a:hover{color:var(--rubric)}
.foot__brand .brand__name{color:var(--indigo);font-size:1.1rem}
.foot__legal{border-top:1px solid var(--rule);padding-top:1.2rem;padding-bottom:1.2rem;font-size:.82rem;color:var(--ink-faint);display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem}

/* ---- breadcrumb ---------------------------------------------------------- */
.crumbs{font-size:.82rem;letter-spacing:.04em;color:var(--ink-faint);padding-top:1.4rem}
.crumbs a{color:var(--ink-faint)}
.crumbs a:hover{color:var(--rubric)}
.crumbs span{margin:0 .5rem;color:var(--gold)}

/* ---- entrance animation -------------------------------------------------- */
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.reveal{opacity:0;animation:rise .8s cubic-bezier(.2,.7,.2,1) forwards}
.reveal.d1{animation-delay:.08s}
.reveal.d2{animation-delay:.18s}
.reveal.d3{animation-delay:.30s}
.reveal.d4{animation-delay:.42s}

/* ---- responsive ---------------------------------------------------------- */
@media (max-width:860px){
  .hero__grid{grid-template-columns:1fr}
  .hero__portrait{max-width:18rem;margin:0 auto}
  .book{grid-template-columns:1fr}
  .book__aside{position:static}
  .foot__inner{grid-template-columns:1fr 1fr}
}
@media (max-width:620px){
  .nav{
    position:fixed;inset:3.6rem 0 auto;flex-direction:column;align-items:flex-start;gap:0;
    background:var(--paper-2);border-bottom:1px solid var(--rule);padding:.5rem 1.4rem 1rem;
    box-shadow:var(--shadow);transform:translateY(-130%);transition:transform .3s ease;
  }
  .nav.open{transform:none}
  .nav a{width:100%;padding:.7rem 0;border-bottom:1px solid var(--rule)}
  .nav a::after{display:none}
  .nav__toggle{display:inline-flex;background:none;border:1px solid var(--rule);border-radius:2px;
    padding:.45rem .7rem;color:var(--indigo);font-family:var(--display);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;cursor:pointer}
  .entry{grid-template-columns:1fr;gap:.2rem}
  .entry__year{font-size:.8rem}
  .foot__inner{grid-template-columns:1fr}
}

/* ---- preferences --------------------------------------------------------- */
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;animation:none}
  *{transition:none !important}
}
:focus-visible{outline:2px solid var(--rubric);outline-offset:3px;border-radius:2px}

@media print{
  .masthead,.foot,.btn-row,.nav__toggle{display:none}
  body{background:#fff;color:#000}
}
