
:root{
  --cream:#f5f1e8;
  --ink:#21233E;
  --ink-soft:#4a423a;
  --gold:#b8860b;
  --rule:#d9d1bf;
  --maxw:640px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--cream);
  color:var(--ink);
  font-family:"Lora",Georgia,serif;
  font-size:18px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  animation:fadeIn .6s ease both;
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

a{color:var(--ink);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
a:hover{color:var(--gold)}

/* Topbar */
.topbar{
  display:flex;align-items:baseline;justify-content:space-between;
  padding:1rem 1.5rem;
  border-bottom:1px solid var(--rule);
  font-family:"Cormorant Garamond",Georgia,serif;
}
.topbar .brand{
  text-decoration:none;
  font-size:1.15rem;
  font-weight:600;
  letter-spacing:normal;
}
.topbar nav{display:flex;gap:1.75rem;font-size:1rem}
.topbar nav a{text-decoration:none;color:var(--ink);font-weight:500}
.topbar nav a:hover{color:var(--gold)}
/* Title break: below the mobile breakpoint, "from the I Ching" drops
   to a second line so the title doesn't collide with the right-side
   nav links. At ≥768px the span renders inline and the title is one line. */
.title-second-line{display:block}
@media(min-width:768px){
  .title-second-line{display:inline}
}

/* Page wrapper */
.page{max-width:1080px;margin:0 auto;padding:2.5rem 1.5rem 4rem}

/* Footer */
.page-footer{
  border-top:1px solid var(--rule);
  padding:1.5rem 1.5rem 3rem;
  margin:3rem auto 0;
  max-width:1080px;
  font-size:.9rem;
  color:var(--ink-soft);
  text-align:center;
}
.page-footer p{margin:0}
.page-footer a{color:var(--ink-soft)}
.page-footer a:hover{color:var(--gold)}

/* Hero (index) */
.hero{
  max-width:720px;margin:0 auto;
  text-align:center;
  padding:3rem 1rem 2rem;
}
.hero-eyebrow{
  font-family:"Cormorant Garamond",Georgia,serif;
  letter-spacing:.3em;text-transform:uppercase;
  color:var(--gold);font-size:.85rem;margin:0 0 1rem;
}
.hero-title{
  font-family:"Cormorant Garamond",Georgia,serif;
  font-weight:500;
  font-size:clamp(2.2rem,6vw,3.6rem);
  line-height:1.1;margin:0 0 1rem;
}
.hero-byline{
  font-style:italic;color:var(--ink-soft);margin:0 0 2rem;
}
.hero-blurb{font-size:1.1rem;line-height:1.7;color:var(--ink-soft);max-width:36rem;margin:0 auto 2.5rem}
.hero-ctas{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}
.cta{
  display:inline-block;padding:.7rem 1.4rem;
  border:1px solid var(--ink);border-radius:2px;
  text-decoration:none;color:var(--ink);
  font-family:"Cormorant Garamond",Georgia,serif;
  font-size:1.05rem;letter-spacing:.04em;
  transition:background .2s,color .2s,border-color .2s;
}
.cta:hover{background:var(--ink);color:var(--cream)}
.cta-primary{background:var(--ink);color:var(--cream)}
.cta-primary:hover{background:var(--gold);border-color:var(--gold);color:var(--cream)}

/* Reflection page */
.page-reflection .page{padding-top:1.5rem}
.reflection{
  display:grid;
  grid-template-columns:1fr;
  gap:2rem;
}
.reflection-image{
  margin:0;
}
.reflection-image img{
  display:block;width:100%;height:auto;
  border-radius:2px;
  box-shadow:0 4px 24px rgba(0,0,0,0.12);
}
.reflection-text{
  max-width:var(--maxw);
  margin:0 auto;
}
.counter{
  font-family:"Cormorant Garamond",Georgia,serif;
  letter-spacing:.08em;text-transform:uppercase;
  font-variant-numeric:lining-nums;
  color:var(--ink);font-size:1.05rem;font-weight:700;
  margin:0 0 1.5rem;
}
.reflection-title{
  font-family:"Cormorant Garamond",Georgia,serif;
  font-weight:500;
  font-size:clamp(1.8rem,4vw,2.6rem);
  line-height:1.15;margin:0 0 1.75rem;
}
.reflection-text p{margin:0 0 1.1rem}
.reflection-text p.first{margin-top:0}
.reflection-text p.first::first-letter,
.reflection-text .dropcap{
  font-family:"Cormorant Garamond",Georgia,serif;
  color:var(--gold);
  float:left;
  font-size:3.6rem;
  line-height:.85;
  padding:.35rem .55rem 0 0;
  font-weight:500;
}
/* If our explicit dropcap span is present, suppress the ::first-letter rule */
.reflection-text p.first:has(.dropcap)::first-letter{
  all:unset;
  font-family:"Lora",Georgia,serif;
  color:var(--ink);
  float:none;font-size:inherit;line-height:inherit;padding:0;
}

@media(min-width:768px){
  .reflection{
    grid-template-columns:minmax(0,1fr) minmax(0,1fr);
    align-items:start;
    gap:3rem;
  }
  .reflection-image{position:sticky;top:1.5rem}
  .reflection-text{margin:0}
}

/* Page nav */
.page-nav{
  max-width:var(--maxw);
  margin:3.5rem auto 0;
  display:grid;
  grid-template-columns:1fr auto 1fr;
  gap:1rem;
  align-items:center;
  padding-top:1.5rem;
  border-top:1px solid var(--rule);
  font-family:"Cormorant Garamond",Georgia,serif;
}
.page-nav a{text-decoration:none;color:var(--ink-soft);display:block}
.page-nav a:hover{color:var(--gold)}
.nav-prev{text-align:left}
.nav-next{text-align:right}
.nav-contents{text-align:center;font-style:italic}
.nav-arrow{display:block;font-size:1.2rem;color:var(--gold)}
.nav-label{display:block;font-size:.95rem;line-height:1.3}
.nav-disabled{display:block}

@media(min-width:768px){
  .page-reflection .page-nav{max-width:1080px}
}

/* Contents */
.contents-page{max-width:780px;margin:0 auto;padding:1rem}
.contents-page h1{
  font-family:"Cormorant Garamond",Georgia,serif;
  font-weight:500;font-size:clamp(2rem,5vw,3rem);
  text-align:center;margin:0 0 .75rem;
}
.contents-blurb{
  text-align:center;color:var(--ink-soft);
  max-width:36rem;margin:0 auto 2.5rem;
  font-style:italic;
}
.contents-list{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:1fr;gap:.25rem;
}
.contents-list li a{
  display:grid;grid-template-columns:3rem 1fr;
  gap:1rem;
  padding:.6rem .5rem;
  text-decoration:none;
  border-bottom:1px dotted var(--rule);
  color:var(--ink);
  align-items:baseline;
}
.contents-list li a:hover{background:rgba(184,134,11,0.08);color:var(--ink)}
.contents-list li a:hover .contents-title{color:var(--gold)}
.contents-num{
  font-family:"Cormorant Garamond",Georgia,serif;
  color:var(--gold);font-size:1.05rem;text-align:right;
}
.contents-title{font-family:"Cormorant Garamond",Georgia,serif;font-size:1.15rem}
.contents-special a{
  grid-template-columns:1fr;
  font-style:italic;
}
.contents-special a .contents-title{text-align:center}

/* Bookends (Introduction / Epilogue) above and below the 126 */
.contents-bookends{
  list-style:none;padding:0;margin:0 0 1.25rem;
  display:flex;justify-content:center;
}
.contents-bookends-bottom{margin:1.25rem 0 0}
.contents-bookends li a{
  display:inline-block;
  padding:.55rem 1.25rem;
  font-family:"Cormorant Garamond",Georgia,serif;
  font-style:italic;font-size:1.15rem;
  color:var(--ink);
  text-decoration:none;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  letter-spacing:.04em;
}
.contents-bookends li a:hover{color:var(--gold)}

/* The 126 reflections in two columns on wide screens, one on narrow */
.contents-list-numbered{
  display:block;
  list-style:none;padding:0;margin:0;
  columns:280px;
  column-gap:3rem;
}
.contents-list-numbered li{
  break-inside:avoid;
  margin:0;
}
.contents-list-numbered li a{
  display:grid;
  grid-template-columns:2.4rem 1fr;
  gap:.7rem;
  padding:.35rem .25rem;
  text-decoration:none;
  color:var(--ink);
  align-items:baseline;
  border-bottom:none;
}
.contents-list-numbered li a:hover{background:rgba(184,134,11,0.08)}
.contents-list-numbered li a:hover .contents-title{color:var(--gold)}
.contents-list-numbered .contents-num{
  font-family:"Cormorant Garamond",Georgia,serif;
  color:var(--gold);font-size:1.05rem;text-align:right;
}
.contents-list-numbered .contents-title{
  font-family:"Cormorant Garamond",Georgia,serif;font-size:1.1rem;line-height:1.25;
}

/* Special pages (intro, epilogue) — centred prose, no image grid */
.page-special .reflection{
  display:block;
}
.page-special .reflection-image{margin:0 auto 2rem;max-width:640px}
.page-special .reflection-text{
  max-width:var(--maxw);
  margin:0 auto;
}
@media(min-width:768px){
  .page-special .reflection{grid-template-columns:none}
  .page-special .reflection-text{margin:0 auto}
}

/* Provenance pill */
.provenance-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px;
  margin:0 0 1rem;
  background:transparent;
  border:1px solid #d4cdb8;
  border-radius:999px;
  font-size:.85rem;
  color:var(--ink);
  font-family:"Lora",Georgia,serif;
  line-height:1;
}
.provenance-pill .pill-mark rect{fill:var(--gold)}
.provenance-pill span{display:inline-block;letter-spacing:.01em}

/* Draw-button loading state */
.js-draw.is-loading{opacity:.55;pointer-events:none;cursor:wait}
.js-draw.is-loading .js-draw-label::after{
  content:"";
  display:inline-block;
  width:.7em;height:.7em;
  margin-left:.5em;
  border:2px solid currentColor;
  border-right-color:transparent;
  border-radius:50%;
  vertical-align:-2px;
  animation:spin .8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* Side chevrons (reading-flow navigation)
   Mobile default = cream-pill button treatment so the chevrons read clearly
   over photograph content. Desktop override (≥768px) = ghost-icon treatment
   over the cream margin. */
.side-chevron{
  position:fixed;
  top:50%;
  transform:translateY(-50%);
  display:flex;
  align-items:center;
  justify-content:center;
  width:44px;height:44px;
  color:var(--gold);
  /* Mobile: button-pill, fully visible. Restraint lives in the pill's
     90% cream opacity, not in the icon's opacity. */
  opacity:1;
  background:rgba(245,241,232,0.9);
  border-radius:999px;
  box-shadow:0 2px 8px rgba(0,0,0,0.15);
  z-index:50;
  text-decoration:none;
  transition:opacity .2s ease, background .2s ease, box-shadow .2s ease;
  -webkit-tap-highlight-color:transparent;
}
.side-chevron svg{display:block;width:30px;height:30px}
/* Mobile: sit chevrons at the inner edge of the swipe handler's safe zone
   (60px), so they double as a visual cue for where to begin a swipe. */
.side-chevron-prev{left:60px}
.side-chevron-next{right:60px}
@media(min-width:768px){
  /* Desktop: outer margin is wide enough that gesture-zone alignment
     doesn't apply; ghost-icon, no pill, no shadow. Hover handles
     discoverability. */
  .side-chevron{
    opacity:0.25;
    background:transparent;
    box-shadow:none;
  }
  .side-chevron svg{width:24px;height:24px}
  .side-chevron-prev{left:1rem}
  .side-chevron-next{right:1rem}
}
@media (hover:hover){
  .side-chevron:hover{opacity:1}
}
.side-chevron:focus-visible{
  opacity:1;
  outline:2px solid var(--gold);
  outline-offset:4px;
}

/* Footnotes */
.footnotes{
  margin-top:2.5rem;padding-top:1.25rem;
  border-top:1px solid var(--rule);
  font-size:.9rem;color:var(--ink-soft);
}
.footnotes ol{padding-left:1.25rem;margin:0}
.footnotes li{margin:0 0 .4rem}
.footnotes a{color:var(--ink-soft);word-break:break-word}
.fn-ref a{
  color:var(--gold);text-decoration:none;
  padding:0 .15em;font-size:.7em;vertical-align:super;
}
.fn-ref a:hover{text-decoration:underline}
