:root{
  --bg-rgb:247,243,234;
  --surface-rgb:250,248,242;
  --ink-rgb:17,17,17;
  --bg:rgb(var(--bg-rgb));
  --panel:rgb(var(--bg-rgb));
  --text:rgb(var(--ink-rgb));
  --muted:rgba(var(--ink-rgb),.8);
  --muted-soft:rgba(var(--ink-rgb),.72);
  --line:rgba(var(--ink-rgb),.12);
  --line-soft:rgba(var(--ink-rgb),.08);
  --surface:rgba(var(--surface-rgb),.9);
  --surface-strong:rgba(var(--surface-rgb),.96);
  --button-hover:rgba(var(--ink-rgb),.06);
  --button-hover-strong:rgba(var(--ink-rgb),.1);
  --shadow:0 24px 80px rgba(0,0,0,.12);
  --timeline-shadow:0 10px 40px rgba(0,0,0,.08);
  --warm-rgb:163,138,95;
  --warm-soft-rgb:239,233,220;
}

html[data-theme="dark"]{
  --bg-rgb:16,17,19;
  --surface-rgb:23,25,29;
  --ink-rgb:242,238,230;
  --bg:rgb(var(--bg-rgb));
  --panel:rgb(var(--bg-rgb));
  --text:rgb(var(--ink-rgb));
  --muted:rgba(var(--ink-rgb),.84);
  --muted-soft:rgba(var(--ink-rgb),.76);
  --line:rgba(var(--ink-rgb),.14);
  --line-soft:rgba(var(--ink-rgb),.1);
  --surface:rgba(var(--surface-rgb),.9);
  --surface-strong:rgba(var(--surface-rgb),.96);
  --button-hover:rgba(var(--ink-rgb),.08);
  --button-hover-strong:rgba(var(--ink-rgb),.14);
  --shadow:0 24px 80px rgba(0,0,0,.4);
  --timeline-shadow:0 10px 40px rgba(0,0,0,.3);
  --warm-rgb:163,138,95;
  --warm-soft-rgb:44,38,31;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text)}
body{min-height:100vh;overflow-x:hidden;font-family:"Crimson Text", Georgia, serif;transition:background-color .28s ease,color .28s ease}
a{text-decoration:none;color:inherit}
main{padding-bottom:120px;}

.topbar{
  position:fixed;inset:0 0 auto 0;z-index:30;height:64px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 24px 0 28px;
  background:linear-gradient(to bottom, rgba(var(--bg-rgb),.94), rgba(var(--bg-rgb),.72));
  backdrop-filter:saturate(160%) blur(18px);
  border-bottom:1px solid var(--line-soft);
  transition:transform .28s ease, background .28s ease, border-color .28s ease;
}
.topbar.hidden{transform:translateY(-100%)}
.brand{font:600 1.18rem/1 "Crimson Pro", Georgia, serif;letter-spacing:.01em}
.topbar-actions{display:flex;align-items:center;gap:10px}
.menu-wrap{position:relative}
.menu-button,
.theme-toggle{
  border:0;
  color:var(--text);
  cursor:pointer;
  transition:background .25s ease, border-color .25s ease, color .25s ease;
}
.menu-button{
  background:transparent;
  width:40px;height:40px;border-radius:999px;display:grid;place-items:center;
}
.theme-toggle{
  width:40px;
  height:40px;
  padding:0;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:transparent;
  border:1px solid transparent;
  opacity:.68;
  transition:background .25s ease, border-color .25s ease, color .25s ease, opacity .22s ease, transform .22s ease;
}
.theme-toggle-icon{
  width:18px;
  height:18px;
  display:block;
}
.theme-toggle:hover,
.theme-toggle:focus-visible{
  opacity:1;
  transform:scale(1.06);
}
.theme-toggle:active{transform:scale(.96)}
.menu-button:hover,
.menu-button[aria-expanded="true"]{background:var(--button-hover)}
.theme-toggle:hover,
.theme-toggle:focus-visible{
  background:var(--button-hover);
  border-color:var(--line-soft);
}
.theme-toggle[aria-pressed="true"]{
  background:var(--button-hover-strong);
  border-color:var(--line);
}
.menu-button svg{width:24px;height:24px}
.resource-menu{position:absolute;right:0;top:48px;width:min(390px,82vw);background:var(--surface-strong);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:18px}
.resource-menu-inner{padding:18px}
.menu-eyebrow{font:600 .95rem/1.2 "Crimson Pro", Georgia, serif;color:var(--muted);margin-bottom:12px}
.resource-menu a{display:block;padding:10px 0;border-bottom:1px solid var(--line-soft);font:400 1rem/1.3 "Crimson Text", Georgia, serif}
.resource-menu a:last-child{border-bottom:0}

.panel{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  padding:88px 0 128px;
  background-color:var(--panel);
  overflow:hidden;
}
.panel::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:var(--panel-image);
  background-size:cover;
  background-position:center center;
  filter:blur(33px) saturate(90%) brightness(.92);
  transform:scale(1.08);
  pointer-events:none;
}

.panel-media{
  position:relative;
  z-index:2;
  display:flex;
  align-items:center;
  justify-content:center;
  align-self:center;
  min-width:0;
  pointer-events:none;
  grid-column:2;
}
.panel.align-right .panel-media{
  grid-column:1;
}
.panel-media img{
  display:block;
  max-width:min(92%, 740px);
  max-height:70vh;
  width:auto;
  height:auto;
  object-fit:contain;
  object-position:center center;
  box-shadow:0 18px 48px rgba(0,0,0,.08);
}

.image-intro .panel-media img{
  max-width:min(98%, 820px);
  max-height:78vh;
  transform:translateY(-18px);
}
html[data-theme="dark"] .panel::before{
  filter:blur(36px) saturate(82%) brightness(.43);
}
html[data-theme="dark"] .panel-media img{
  box-shadow:0 20px 54px rgba(0,0,0,.28);
}

html[data-theme="dark"] .panel::after{
  background:linear-gradient(
    to left,
    rgba(var(--bg-rgb),0) 36%,
    rgba(var(--bg-rgb),0.18) 52%,
    rgba(var(--warm-soft-rgb),0.05) 60%,
    rgba(var(--bg-rgb),0.78) 82%,
    rgba(var(--bg-rgb),1) 100%
  );
}
html[data-theme="dark"] .panel.align-right::after{
  background:linear-gradient(
    to right,
    rgba(var(--bg-rgb),0) 36%,
    rgba(var(--bg-rgb),0.18) 52%,
    rgba(var(--warm-soft-rgb),0.05) 60%,
    rgba(var(--bg-rgb),0.78) 82%,
    rgba(var(--bg-rgb),1) 100%
  );
}
.panel::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(
    to left,
    rgba(var(--bg-rgb),0) 22%,
    rgba(var(--bg-rgb),0.18) 38%,
    rgba(var(--warm-soft-rgb),0.12) 50%,
    rgba(var(--bg-rgb),0.52) 64%,
    rgba(var(--bg-rgb),0.90) 82%,
    rgba(var(--bg-rgb),1) 100%
  );
  transition:background .28s ease;
}
.panel.align-right::after{
  background:linear-gradient(
    to right,
    rgba(var(--bg-rgb),0) 22%,
    rgba(var(--bg-rgb),0.18) 38%,
    rgba(var(--warm-soft-rgb),0.12) 50%,
    rgba(var(--bg-rgb),0.52) 64%,
    rgba(var(--bg-rgb),0.90) 82%,
    rgba(var(--bg-rgb),1) 100%
  );
}
.panel-layout{
  position:relative;
  z-index:2;
  width:min(1320px, calc(100vw - 48px));
  min-height:calc(100vh - 216px);
  margin:0 auto;
  display:grid;
  grid-template-columns:minmax(280px, 42%) minmax(0, 58%);
  align-items:center;
  column-gap:32px;
}
.panel.align-right .panel-layout{
  grid-template-columns:minmax(0, 58%) minmax(280px, 42%);
}
.panel-inner{
  position:relative;
  z-index:3;
  width:auto;
  margin:0;
  display:flex;
  align-self:center;
}
.panel-inner.left{
  justify-content:flex-start;
  grid-column:1;
}
.panel-inner.right{
  justify-content:flex-end;
  grid-column:2;
}
.panel.align-right .panel-inner.left{
  grid-column:1;
}
.panel.align-right .panel-inner.right{
  grid-column:2;
}
.text-block{max-width:760px;padding:26px 28px;border-radius:28px;background:transparent;backdrop-filter:none}
.text-block.narrow{max-width:650px}
.intro-copy{padding-bottom:8vh;max-width:920px;background:transparent}
.eyebrow{max-width:42ch;font:600 clamp(1.08rem,1.75vw,1.42rem)/1.18 "Crimson Pro", Georgia, serif;color:var(--text);margin-bottom:18px}
.hero-title,
h2{margin:0 0 16px;max-width:12ch;font:600 clamp(2.6rem,5vw,4.85rem)/.94 "Crimson Pro", Georgia, serif;letter-spacing:-.03em}
.hero-title{max-width:13ch;margin-bottom:30px}
.lede{margin:0;max-width:37ch;font:400 clamp(1.18rem,2vw,1.86rem)/1.34 "Crimson Text", Georgia, serif;color:var(--muted-soft)}
.year{font:700 1.06rem/1 "Crimson Pro", Georgia, serif;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.text-block p{margin:0;max-width:38ch;font:400 clamp(1.16rem,1.8vw,1.56rem)/1.4 "Crimson Text", Georgia, serif;color:var(--muted)}
.site-footer{
  position:relative;
  z-index:10;
  width:100%;
  margin-top:40px;
  padding:0 20px 110px;
}
.site-footer-inner{
  max-width:1320px;
  margin:0 auto;
  padding-top:0;
  padding-left:18px;
  border-top:0;
}
.site-note{
  font:400 .8rem/1.4 "Crimson Text", Georgia, serif;
  color:rgba(var(--ink-rgb),.64);
  margin-bottom:0;
  padding-bottom:10px;
  border-bottom:1px solid rgba(var(--ink-rgb),.16);
}
.site-credit{
  font:400 .83rem/1.4 "Crimson Text", Georgia, serif;
  color:rgba(var(--ink-rgb),.72);
  padding-top:9px;
}
.site-footer a:hover{text-decoration:underline}

.timeline-nav{
  position:fixed;left:50%;bottom:14px;transform:translateX(-50%);z-index:25;
  width:min(920px,calc(100vw - 36px));padding:18px;background:var(--surface);
  border:1px solid var(--line);border-radius:999px;backdrop-filter:saturate(150%) blur(14px);
  display:flex;justify-content:space-between;align-items:center;gap:8px;
  box-shadow:var(--timeline-shadow);
  transition:background .28s ease, border-color .28s ease, box-shadow .28s ease;
}
.timeline-track{position:absolute;left:28px;right:28px;top:50%;height:1px;background:var(--line);transform:translateY(-50%);z-index:-1}
.timeline-item{position:relative;display:flex;justify-content:center;align-items:center;width:22px;height:22px;flex:1 1 auto}
.timeline-item .dot{width:8px;height:8px;border-radius:999px;background:rgba(var(--ink-rgb),.3);transition:transform .25s ease, background .25s ease, box-shadow .25s ease}
.timeline-item:hover .dot{transform:scale(1.2);background:rgba(var(--ink-rgb),.46)}
.timeline-item.active .dot{
  transform:scale(1.5);
  background:rgba(var(--ink-rgb), .88);
  box-shadow:0 0 0 5px rgba(var(--ink-rgb), .08);
}
.timeline-item .timeline-label{display:none}


html[data-theme="dark"] .timeline-item:hover .dot{
  background:rgba(var(--ink-rgb),.56);
}
html[data-theme="dark"] .timeline-item.active .dot{
  background:rgba(236, 231, 220, .95);
  box-shadow:0 0 0 5px rgba(236, 231, 220, .10);
}


.image-intro{--panel-image:url('assets/panels_photos/intro.jpg')}
.image-1870{--panel-image:url('assets/panels_photos/1870.jpg')}
.image-1883{--panel-image:url('assets/panels_photos/1883.jpg')}
.image-1890{--panel-image:url('assets/panels_photos/1890.jpg')}
.image-1896{--panel-image:url('assets/panels_photos/1896.jpg')}
.image-1897{--panel-image:url('assets/panels_photos/1897.jpg')}
.image-1900{--panel-image:url('assets/panels_photos/1900.jpg')}
.image-1907{--panel-image:url('assets/panels_photos/1907.jpg')}
.image-1909{--panel-image:url('assets/panels_photos/1909.jpg')}
.image-1911{--panel-image:url('assets/panels_photos/1911.png')}
.image-1916{--panel-image:url('assets/panels_photos/1916.jpg')}
.image-1936{--panel-image:url('assets/panels_photos/1936.jpg')}
.image-1939{--panel-image:url('assets/panels_photos/1939.jpg')}
.image-1946{--panel-image:url('assets/panels_photos/1946.jpg')}
.image-1952{--panel-image:url('assets/panels_photos/1952.jpg')}






.image-intro .panel-media img{object-position:78% center;}
.image-1870 .panel-media img{object-position:78% center;}
.image-1883 .panel-media img{object-position:18% center;}
.image-1890 .panel-media img{object-position:82% center;}
.image-1896 .panel-media img{object-position:18% center;}
.image-1897 .panel-media img{object-position:82% center;}
.image-1900 .panel-media img{object-position:16% center;}
.image-1907 .panel-media img{object-position:72% center;}
.image-1909 .panel-media img{object-position:16% center;}
.image-1911 .panel-media img{object-position:78% center;}
.image-1916 .panel-media img{object-position:20% center;}
.image-1936 .panel-media img{object-position:72% center;}
.image-1939 .panel-media img{object-position:24% center;}
.image-1946 .panel-media img{object-position:74% center;}
.image-1952 .panel-media img{object-position:24% center;}








@media (max-width: 1180px) and (min-width: 901px){
  .panel{
    padding:88px 0 136px;
  }
  .panel-layout{
    width:calc(100vw - 40px);
    min-height:calc(100vh - 208px);
    grid-template-columns:minmax(240px, 40%) minmax(0, 60%);
    column-gap:24px;
  }
  .panel.align-right .panel-layout{
    grid-template-columns:minmax(0, 60%) minmax(240px, 40%);
  }
  .panel-media img{
    max-width:min(96%, 460px);
    max-height:min(56vh, 520px);
    transform:none;
  }
  .image-intro .panel-media img{
    max-width:min(98%, 520px);
    max-height:min(62vh, 620px);
    transform:translateY(-8px);
  }
  .text-block{
    max-width:620px;
    padding:18px 20px 18px 0;
  }
  .text-block.narrow{
    max-width:560px;
    padding:18px 20px 18px 0;
  }
  .panel.align-right .text-block,
  .panel.align-right .text-block.narrow{
    padding:18px 0 18px 20px;
  }
  h2{
    max-width:10ch;
  }

}



@media (min-width: 1300px){
  .panel.align-right .panel-layout{
    display:block;
    position:relative;
    width:min(1320px, calc(100vw - 56px));
    min-height:calc(100vh - 216px);
  }
  .panel.align-right .panel-media{
    position:absolute;
    left:0;
    top:0;
    width:40%;
    height:100%;
    display:flex;
    justify-content:center;
    align-items:flex-start;
    padding-top:24px;
    z-index:2;
  }
  .panel.align-right .panel-media img{
    max-width:min(90%, 440px);
    max-height:min(62vh, 700px);
    width:auto;
    height:auto;
    margin:0;
    transform:none;
  }
  .panel.align-right .panel-inner.right{
    width:min(46%, 640px);
    margin-left:auto;
    margin-right:clamp(40px, 5vw, 88px);
    justify-content:flex-start;
    align-self:auto;
    position:relative;
    z-index:3;
  }
  .panel.align-right .text-block,
  .panel.align-right .text-block.narrow{
    padding:18px 0 18px 52px;
  }
}

@media (max-width: 1299px) and (min-width: 901px){
  .panel.align-right .panel-layout{
    width:min(680px, calc(100vw - 40px));
    min-height:auto;
    display:grid !important;
    grid-template-columns:1fr;
    grid-template-rows:auto auto;
    align-items:start;
    row-gap:16px;
    column-gap:0;
    padding-inline:20px;
  }
  .panel.align-right .panel-media{
    position:relative;
    left:auto;
    top:auto;
    width:100%;
    height:auto;
    display:flex;
    justify-content:flex-start;
    align-items:flex-end;
    align-self:start;
    padding-top:10px;
    grid-column:1;
    grid-row:1;
  }
  .panel.align-right .panel-media img{
    max-width:min(62%, 420px);
    max-height:min(34vh, 320px);
    width:auto;
    height:auto;
    margin:0 0 10px 0;
    transform:none;
  }
  .panel.align-right .panel-inner.right{
    width:100%;
    margin:0;
    justify-content:flex-start;
    align-self:start;
    position:relative;
    z-index:3;
    grid-column:1;
    grid-row:2;
  }
  .panel.align-right .text-block,
  .panel.align-right .text-block.narrow{
    width:100%;
    max-width:none;
    margin:0;
    padding:18px 0 20px;
    text-align:left;
  }
  .panel.align-right .year,
  .panel.align-right h2,
  .panel.align-right .text-block p{
    text-align:left;
    margin-left:0;
    margin-right:0;
  }
}

@media (max-width: 900px){
  .site-footer{
    padding:0 18px 110px;
    margin-top:28px;
  }
  .site-footer-inner{
    padding-top:0;
    padding-left:0;
  }
  .site-note{font-size:.74rem}
  .site-credit{font-size:.78rem}

  .topbar{padding-inline:16px 18px}
  .topbar-actions{gap:8px}
  .theme-toggle{width:38px;height:38px}
  .panel{
    padding:92px 0 150px;
    min-height:100svh;
  }
  .panel::before{
    background-position:center center;
    filter:blur(27px) saturate(88%) brightness(.94);
    transform:scale(1.06);
  }
  .panel-layout{
    width:calc(100vw - 40px);
    min-height:auto;
    grid-template-columns:1fr;
    grid-template-rows:auto auto;
    row-gap:16px;
    column-gap:0;
    align-items:start;
  }
  .panel-inner,
  .panel-inner.left,
  .panel-inner.right{
    grid-column:1;
    grid-row:2;
    width:100%;
    justify-content:flex-start;
    align-self:start;
  }
  .panel-media,
  .panel.align-right .panel-media{
    position:relative;
    left:auto;
    top:auto;
    grid-column:1;
    grid-row:1;
    width:100%;
    height:auto;
    justify-content:center;
    align-items:flex-end;
    align-self:start;
    padding-top:10px;
  }
  .panel::after,
  .panel.align-right::after{
    background:linear-gradient(
      to top,
      rgba(var(--bg-rgb),1) 0%,
      rgba(var(--bg-rgb),.98) 26%,
      rgba(var(--bg-rgb),.88) 44%,
      rgba(var(--bg-rgb),.56) 62%,
      rgba(var(--bg-rgb),.18) 78%,
      rgba(var(--bg-rgb),0) 90%
    );
  }
  .panel-media img{
    max-width:min(84%, 500px);
    max-height:min(32vh, 300px);
    margin:0 auto 10px;
    transform:none;
  }
  .image-intro .panel-media img{
    max-width:min(88%, 560px);
    max-height:min(36vh, 340px);
    transform:none;
  }
  .text-block,
  .text-block.narrow,
  .intro-copy{
    width:100%;
    max-width:none;
    margin:0;
    padding:18px 0 20px;
    text-align:left;
  }
  .eyebrow,
  .hero-title,
  h2,
  .lede,
  .year,
  .text-block p{
    text-align:left;
    margin-left:0;
    margin-right:0;
  }
  .hero-title,
  h2{
    max-width:12ch;
  }
  .site-credit{left:18px;right:18px;bottom:106px}
  .timeline-nav{width:calc(100vw - 18px);padding-inline:12px}
}










.panel-inner .year{
  opacity:inherit;
}
.panel.is-visible .year{
  animation-delay:.04s;
}





/* Gentle per-panel scroll reveal */
.panel-inner .text-block,
.panel-media img{
  opacity:1;
  transform:translateY(0);
}

html.js-animate .panel-media img{
  opacity:0;
  transform:translateY(16px);
  transition:
    opacity 1700ms cubic-bezier(.22,1,.36,1),
    transform 1700ms cubic-bezier(.22,1,.36,1);
  will-change:opacity, transform;
}

html.js-animate .panel-inner .text-block{
  opacity:0;
  transform:translateY(20px);
  transition:
    opacity 1200ms cubic-bezier(.22,1,.36,1),
    transform 1200ms cubic-bezier(.22,1,.36,1);
  transition-delay:260ms;
  will-change:opacity, transform;
}

html.js-animate .panel.is-visible .text-block,
html.js-animate .panel.is-visible .panel-media img{
  opacity:1;
  transform:translateY(0);
}

@media (prefers-reduced-motion: reduce){
  .panel-inner .text-block,
  .panel-media img{
    opacity:1 !important;
    transform:none !important;
    transition:none !important;
    animation:none !important;
  }
}

