:root{
  --paper:#FAF7F2;
  --paper-warm:#F3EDE2;
  --paper-deep:#EBE3D3;
  --ink:#1F3A2D;
  --ink-soft:#2C4A3B;
  --sepia:#8B6E4E;
  --sepia-deep:#5D462D;
  --rule:#D9D0BD;
  --gray:#6B655B;
  --gray-soft:#8A8478;
  --shadow:rgba(60, 45, 25, 0.10);
  --serif:"Source Serif 4", "Source Serif Pro", Georgia, serif;
  --display:"Cormorant Garamond", "EB Garamond", Georgia, serif;
  --mono:"JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--serif);
  font-size:18px;
  line-height:1.65;
  font-feature-settings:"liga","kern","onum";
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
::selection{background:var(--ink);color:var(--paper)}

/* ---------- LAYOUT ---------- */
.wrap{max-width:1100px;margin:0 auto;padding:0 32px}
.narrow{max-width:720px;margin:0 auto;padding:0 32px}
section{padding:120px 0;border-top:1px solid var(--rule)}
section:first-of-type{border-top:none}
.eyebrow{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--sepia);
  margin:0 0 28px;
}
h1,h2,h3,h4{font-family:var(--display);font-weight:500;color:var(--ink);margin:0;line-height:1.1;letter-spacing:-0.01em}
h2{font-size:64px;font-weight:500}
h2 em{font-style:italic;font-weight:400;color:var(--sepia-deep)}
h3{font-size:36px;font-weight:500;margin-bottom:24px}
h4{font-size:24px;font-weight:600;letter-spacing:0.01em}
p{margin:0 0 1.2em}
p.lede{font-size:24px;line-height:1.5;color:var(--ink-soft);font-family:var(--display);font-weight:400}
p.lede em{color:var(--sepia-deep)}
a{color:var(--sepia-deep);text-decoration:none;border-bottom:1px solid var(--rule);transition:border-color .2s}
a:hover{border-bottom-color:var(--sepia-deep)}
hr.ornament{border:none;text-align:center;margin:64px 0;color:var(--sepia)}
hr.ornament::before{content:"·    ·    ·";font-family:var(--display);font-size:20px;letter-spacing:0.4em;color:var(--sepia)}

/* ---------- HERO ---------- */
.hero{
  min-height:100vh;
  padding:80px 0 100px;
  display:flex;flex-direction:column;justify-content:space-between;
  border-top:none;
  background:
    radial-gradient(ellipse at top, rgba(139,110,78,0.06), transparent 60%),
    var(--paper);
}
.hero-top{display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gray-soft)}
.hero-top .dot{width:6px;height:6px;background:var(--sepia);border-radius:50%;display:inline-block;margin:0 12px;vertical-align:middle}
.hero-center{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding:80px 0}
.hero-kicker{font-family:var(--mono);font-size:12px;letter-spacing:0.22em;text-transform:uppercase;color:var(--sepia);margin-bottom:40px}
.hero h1{
  font-family:var(--display);
  font-size:clamp(72px, 11vw, 168px);
  line-height:0.92;
  font-weight:400;
  letter-spacing:-0.02em;
  margin:0;
}
.hero h1 .to{font-style:italic;font-weight:400;color:var(--sepia-deep)}
.hero-sub{font-family:var(--display);font-style:italic;font-size:36px;color:var(--ink-soft);margin-top:48px;font-weight:400}
.hero-frame{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-top:80px;align-items:end}
.hero-frame p{font-size:18px;color:var(--ink-soft);margin:0;max-width:36ch}
.hero-frame .meta{font-family:var(--mono);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gray-soft);text-align:right}
.hero-frame .meta div + div{margin-top:8px}
.scroll-cue{font-family:var(--mono);font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--gray-soft);margin-top:64px;display:flex;align-items:center;gap:14px}
.scroll-cue::before{content:"";width:48px;height:1px;background:var(--gray-soft)}

/* ---------- JOURNEY ---------- */
.journey{background:var(--paper-warm)}
.journey-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.journey-text h2{font-size:56px;margin-bottom:32px}
.journey-stat{display:flex;gap:32px;margin-top:48px;padding-top:32px;border-top:1px solid var(--rule)}
.journey-stat > div{flex:1}
.journey-stat .num{font-family:var(--display);font-size:56px;color:var(--sepia-deep);line-height:1;font-weight:500}
.journey-stat .lbl{font-family:var(--mono);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gray);margin-top:10px}
/* simple map — SVG inline */
.map{
  background:var(--paper);
  border:1px solid var(--rule);
  aspect-ratio:5/4;
  position:relative;
  padding:32px;
}
.map svg{width:100%;height:100%;display:block}
.map-cap{font-family:var(--mono);font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--gray-soft);position:absolute;bottom:16px;left:32px;right:32px;display:flex;justify-content:space-between}

/* ---------- TREE ---------- */
.tree-wrap{overflow-x:auto;padding:16px 0 32px;-webkit-overflow-scrolling:touch}
.tree{
  min-width:1040px;
  display:grid;
  grid-template-columns:repeat(8, 1fr);
  gap:14px 10px;
  font-family:var(--serif);
}
.person{
  border:1px solid var(--rule);
  background:var(--paper-warm);
  padding:14px 14px 12px;
  cursor:pointer;
  transition:background .15s, border-color .15s, transform .15s;
  position:relative;
}
.person:hover{background:var(--paper-deep);border-color:var(--sepia)}
.person.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.person.active .num,.person.active .meta-line{color:var(--paper-warm)}
.person .num{font-family:var(--mono);font-size:10px;letter-spacing:0.18em;color:var(--sepia);margin-bottom:6px}
.person .name{font-family:var(--display);font-size:18px;line-height:1.15;font-weight:500;color:inherit}
.person .meta-line{font-family:var(--mono);font-size:10px;letter-spacing:0.04em;color:var(--gray);margin-top:6px;line-height:1.4}
.tree-row-label{font-family:var(--mono);font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--sepia);margin:36px 0 14px}
.tree-row-label:first-child{margin-top:0}
.gen1{grid-column:1 / -1;max-width:340px;margin:0 auto}
.gen2{grid-column:span 4}
.gen3{grid-column:span 2}
.gen4{grid-column:span 1;font-size:12px}
.gen4 .name{font-size:14px}
.gen4 .meta-line{display:none}
.person-detail{
  margin-top:36px;
  background:var(--paper-warm);
  border:1px solid var(--rule);
  padding:32px 40px;
  min-height:160px;
  display:grid;
  grid-template-columns:auto 1fr;
  gap:32px 48px;
}
.person-detail .key{font-family:var(--mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--sepia)}
.person-detail .val{font-family:var(--serif);font-size:17px;color:var(--ink-soft)}
.person-detail .name-big{grid-column:1/-1;font-family:var(--display);font-size:36px;color:var(--ink);font-weight:500;line-height:1.1;margin-bottom:4px}
.person-detail .name-big .sup{font-family:var(--mono);font-size:13px;color:var(--sepia);margin-right:14px;letter-spacing:0.18em;vertical-align:0.45em}

/* ---------- THREADS ---------- */
.thread-head{display:grid;grid-template-columns:auto 1fr;gap:48px;align-items:baseline;margin-bottom:64px}
.thread-num{font-family:var(--display);font-style:italic;font-size:120px;color:var(--sepia);line-height:0.9;font-weight:400}
.thread-head h2{font-size:64px;max-width:18ch}
.thread-body{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.thread-body.single{grid-template-columns:1fr;max-width:760px;margin:0 auto}
.thread-body p{font-size:19px}
.thread-body p.lede{font-size:26px}

/* ---------- HOUSEHOLD CARD ---------- */
.household{
  background:var(--paper-warm);
  border:1px solid var(--rule);
  padding:40px;
}
.household h4{font-family:var(--mono);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--sepia);font-weight:500;margin-bottom:24px}
.roll{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}
.roll li{display:grid;grid-template-columns:auto 1fr auto;gap:20px;align-items:baseline;padding-bottom:14px;border-bottom:1px dotted var(--rule)}
.roll li:last-child{border-bottom:none}
.roll .who{font-family:var(--display);font-size:22px;font-weight:500;color:var(--ink)}
.roll .role{font-family:var(--serif);font-size:14px;color:var(--gray);font-style:italic}
.roll .age{font-family:var(--mono);font-size:13px;color:var(--sepia-deep);letter-spacing:0.05em}

/* ---------- NAME ARC ---------- */
.name-arc{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin:80px 0 40px;border:1px solid var(--rule)}
.name-arc > div{padding:48px 36px;border-right:1px solid var(--rule);position:relative;background:var(--paper)}
.name-arc > div:last-child{border-right:none;background:var(--paper-warm)}
.name-arc .gen-tag{font-family:var(--mono);font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--sepia);margin-bottom:24px}
.name-arc .surname{font-family:var(--display);font-size:54px;line-height:1;font-weight:500;color:var(--ink);margin-bottom:8px}
.name-arc .gloss{font-family:var(--display);font-style:italic;font-size:18px;color:var(--gray);margin-bottom:24px}
.name-arc .why{font-size:15px;line-height:1.55;color:var(--ink-soft)}
.name-arc .arrow{position:absolute;right:-9px;top:50%;transform:translateY(-50%);width:18px;height:18px;background:var(--paper);border-top:1px solid var(--rule);border-right:1px solid var(--rule);transform-origin:center;transform:translate(50%,-50%) rotate(45deg);z-index:2}
.name-arc > div:last-child .arrow{display:none}

/* ---------- RECORD CARDS (scans) ---------- */
.scan{
  background:linear-gradient(135deg, #efe4cc 0%, #e3d3b3 50%, #d9c69e 100%);
  border:1px solid #b9a988;
  aspect-ratio:4/5;
  position:relative;
  overflow:hidden;
  box-shadow:0 4px 16px var(--shadow);
}
.scan::before{
  /* faux handwritten lines */
  content:"";
  position:absolute;inset:14% 12% 14% 12%;
  background-image:
    repeating-linear-gradient(transparent 0 14px, rgba(60,40,15,0.18) 14px 15px, transparent 15px 30px),
    repeating-linear-gradient(90deg, transparent 0 6%, rgba(60,40,15,0.10) 6% 6.4%, transparent 6.4% 18%);
  mask-image:linear-gradient(180deg, #000 0%, #000 88%, transparent 100%);
  opacity:0.8;
}
.scan::after{
  /* sepia speckle */
  content:"";
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 20% 30%, rgba(80,50,20,0.15) 0 1px, transparent 2px),
    radial-gradient(circle at 70% 65%, rgba(80,50,20,0.12) 0 1px, transparent 2px),
    radial-gradient(circle at 85% 20%, rgba(80,50,20,0.10) 0 1px, transparent 3px),
    radial-gradient(ellipse at 50% 50%, transparent 60%, rgba(60,40,15,0.18) 100%);
  pointer-events:none;
}
.scan .scan-head{
  position:absolute;top:14px;left:14px;right:14px;
  font-family:var(--display);font-style:italic;font-size:14px;color:#5b4422;
  text-align:center;letter-spacing:0.04em;
  z-index:1;
}
.scan .scan-stamp{
  position:absolute;bottom:16px;right:16px;
  font-family:var(--mono);font-size:9px;color:rgba(60,40,15,0.5);
  letter-spacing:0.1em;z-index:1;
}
.scan-caption{
  font-family:var(--mono);
  font-size:10px;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--gray);margin-top:14px;line-height:1.6;
}
.scan-caption .strong{color:var(--ink);display:block;margin-bottom:4px;font-size:11px}

.feature-record{display:grid;grid-template-columns:280px 1fr;gap:48px;margin-top:48px;align-items:start}
.feature-record .scan{aspect-ratio:3/4}
.feature-record .desc h4{font-family:var(--display);font-style:italic;font-size:24px;font-weight:400;margin-bottom:14px;color:var(--ink-soft)}
.feature-record .desc p{font-size:17px;color:var(--ink-soft)}
.feature-record .desc .ref{font-family:var(--mono);font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--sepia);margin-top:24px}

/* ---------- FIRE & FEVER ---------- */
.fire-quote{
  font-family:var(--display);
  font-style:italic;
  font-size:32px;
  line-height:1.35;
  color:var(--ink);
  border-left:2px solid var(--sepia);
  padding:8px 0 8px 40px;
  margin:48px 0;
  max-width:30ch;
}
.fire-quote .src{display:block;font-family:var(--mono);font-style:normal;font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--gray);margin-top:24px}

.fever{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
  margin:64px 0 32px;
}
.fever-card{
  border-top:1px solid var(--ink);
  padding-top:24px;
}
.fever-card .age{font-family:var(--mono);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--sepia);margin-bottom:14px}
.fever-card .name{font-family:var(--display);font-size:42px;font-weight:500;color:var(--ink);line-height:1.1;margin-bottom:8px}
.fever-card .date{font-family:var(--display);font-style:italic;font-size:24px;color:var(--ink-soft);margin-bottom:18px}
.fever-card .cause{font-family:var(--mono);font-size:12px;letter-spacing:0.14em;text-transform:uppercase;color:var(--sepia-deep)}
.fever-tail{font-family:var(--display);font-style:italic;font-size:24px;color:var(--ink-soft);max-width:36ch;margin:48px auto 0;text-align:center;line-height:1.4}

/* ---------- VILLAGES ---------- */
.villages-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:56px 64px;margin-top:64px}
.village h3{font-size:42px;margin-bottom:8px}
.village .parish{font-family:var(--mono);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--sepia);margin-bottom:18px}
.village p{font-size:17px;color:var(--ink-soft);margin-bottom:14px}
.village .gm{font-family:var(--mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase}

/* ---------- TIMELINE ---------- */
.timeline{position:relative;padding-left:40px;margin-top:48px}
.timeline::before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:1px;background:var(--rule)}
.tl-item{position:relative;padding:0 0 36px 32px}
.tl-item::before{content:"";position:absolute;left:-44px;top:10px;width:9px;height:9px;border-radius:50%;background:var(--paper);border:1.5px solid var(--sepia)}
.tl-item.key::before{background:var(--ink);border-color:var(--ink);width:11px;height:11px;left:-45px}
.tl-date{font-family:var(--mono);font-size:12px;letter-spacing:0.14em;text-transform:uppercase;color:var(--sepia-deep);margin-bottom:6px}
.tl-item.key .tl-date{color:var(--ink)}
.tl-event{font-family:var(--display);font-size:24px;line-height:1.3;color:var(--ink);font-weight:500}
.tl-item.key .tl-event{font-size:30px}
.tl-item.sub .tl-event{font-size:18px;color:var(--gray);font-weight:400}
.tl-item.sub .tl-date{color:var(--gray-soft)}

/* ---------- GALLERY ---------- */
.gallery{display:grid;grid-template-columns:repeat(4, 1fr);gap:32px 24px;margin-top:48px}
.gallery .scan{aspect-ratio:3/4}

/* ---------- FOOTER ---------- */
footer{background:var(--ink);color:var(--paper-warm);padding:96px 0 64px;margin-top:0;border-top:none}
footer .wrap{color:var(--paper-warm)}
footer h2{color:var(--paper);font-size:48px;margin-bottom:32px;font-style:italic;font-weight:400}
footer p{color:#c8c2b3;font-size:18px;max-width:60ch}
footer .credits{display:grid;grid-template-columns:repeat(3,1fr);gap:48px;margin-top:80px;padding-top:48px;border-top:1px solid rgba(255,255,255,0.12);font-family:var(--mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:#9a9484;line-height:1.8}
footer .credits a{color:#c8c2b3;border-bottom-color:rgba(255,255,255,0.18)}
footer .credits strong{display:block;color:var(--paper);font-weight:500;margin-bottom:10px}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 900px){
  section{padding:88px 0}
  h2{font-size:42px}
  .hero h1{font-size:clamp(56px, 14vw, 96px)}
  .hero-sub{font-size:26px}
  .hero-frame{grid-template-columns:1fr;gap:24px}
  .hero-frame .meta{text-align:left}
  .journey-grid,.thread-body,.fever,.villages-grid{grid-template-columns:1fr;gap:48px}
  .thread-head{grid-template-columns:1fr;gap:8px;margin-bottom:40px}
  .thread-num{font-size:80px}
  .thread-head h2{font-size:42px}
  .name-arc{grid-template-columns:1fr}
  .name-arc > div{border-right:none;border-bottom:1px solid var(--rule)}
  .name-arc > div:last-child{border-bottom:none}
  .name-arc .arrow{display:none}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .feature-record{grid-template-columns:1fr}
  .feature-record .scan{max-width:280px}
  .person-detail{grid-template-columns:1fr;gap:16px;padding:24px}
  .person-detail .name-big{font-size:28px}
}
