:root{
  --bg:#100e0b; --bg2:#16130f; --ink:#ece3d4; --dim:#9a8f7d; --faint:#6b6354;
  --gold:#c9a24a; --line:#2c261d; --card:#1b1712; --fam:#c9a24a;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:Spectral,Georgia,serif;line-height:1.65;
  background-image:radial-gradient(120% 80% at 50% -10%, #1c1813 0%, var(--bg) 55%);}
a{color:var(--gold);text-decoration:none}
::selection{background:var(--gold);color:#1a1408}

/* ── hero ── */
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;
  padding:40px 22px;position:relative;
  background:radial-gradient(80% 60% at 50% 40%, rgba(201,162,74,.07), transparent 70%);}
.hero-inner{max-width:760px}
.home-link{position:absolute;top:20px;left:22px;z-index:2;font-family:Oswald,sans-serif;text-transform:uppercase;
  letter-spacing:.14em;font-size:12px;color:var(--dim);border:1px solid var(--line);border-radius:999px;padding:7px 16px;transition:.15s}
.home-link:hover{color:var(--ink);border-color:var(--gold)}
.kicker{font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.42em;font-size:12px;
  color:var(--gold);margin:0 0 22px;font-weight:500;padding-left:.42em}
.hero h1{font-family:Oswald,sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.04em;
  font-size:clamp(46px,12vw,118px);line-height:.96;margin:0;
  background:linear-gradient(180deg,#f3ead8,#bfa05a 70%,#8a6f33);-webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 2px 40px rgba(201,162,74,.12)}
.lede{font-size:clamp(16px,2.2vw,20px);color:var(--dim);max-width:620px;margin:24px auto 0}
.stats{display:flex;gap:42px;justify-content:center;margin:46px 0 0;flex-wrap:wrap}
.stats .num{font-family:Oswald,sans-serif;font-weight:600;font-size:42px;color:var(--ink);display:block;line-height:1}
.stats .lab{font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.18em;font-size:11px;color:var(--faint)}
.scrollcue{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);color:var(--faint);
  font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.3em;font-size:10px}
.scrollcue .arrow{width:1px;height:34px;margin:8px auto 0;background:linear-gradient(var(--gold),transparent);animation:cue 1.8s infinite}
@keyframes cue{0%,100%{opacity:.3;transform:scaleY(.7)}50%{opacity:1;transform:scaleY(1)}}

/* ── US map ── */
.mapsec{max-width:780px;margin:0 auto;padding:24px 22px 0;text-align:center}
.map-title{font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.05em;font-size:clamp(24px,4vw,34px);margin:0}
.map-sub{color:var(--dim);max-width:580px;margin:8px auto 16px;font-size:15px}
.map-wrap{position:relative;max-width:1000px;margin:0 auto}
.us-map{width:100%;height:auto;display:block;filter:drop-shadow(0 14px 34px rgba(0,0,0,.5))}
.us-map path{stroke:#0e0c0a;stroke-width:.7;transition:filter .15s,stroke .15s}
.us-map path:not(.op){stroke:#3a3322}
.us-map path.op{cursor:pointer}
.us-map path.op:hover{stroke:var(--gold);stroke-width:1.5;filter:drop-shadow(0 0 6px rgba(201,162,74,.65))}
.map-legend{display:flex;align-items:center;justify-content:center;gap:11px;margin-top:14px;
  font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.12em;font-size:11px;color:var(--dim)}
.map-grad{width:170px;height:9px;border-radius:5px;border:1px solid var(--line);background:linear-gradient(90deg,#3a2e15,#e9cd78)}

/* state hover popout */
.state-pop{position:fixed;z-index:40;min-width:180px;max-width:280px;background:var(--card);border:1px solid var(--line);
  border-radius:10px;box-shadow:0 12px 34px rgba(0,0,0,.5);padding:10px 12px;font-family:Oswald,sans-serif;
  opacity:0;visibility:hidden;transform:translateY(4px);transition:opacity .12s,transform .12s}
.state-pop.show{opacity:1;visibility:visible;transform:none}
.sp-state{font-size:12px;text-transform:uppercase;letter-spacing:.16em;color:var(--dim);margin-bottom:8px;border-bottom:1px solid var(--line);padding-bottom:6px}
.sp-fam{display:flex;align-items:center;gap:9px;padding:5px 4px;border-radius:7px;color:var(--ink);font-size:14px}
.sp-fam:hover{background:rgba(201,162,74,.12);text-decoration:none}
.sp-dot{width:9px;height:9px;border-radius:50%;background:var(--fam);flex:none}

/* tabs */
.tabs{position:sticky;top:0;z-index:30;display:flex;justify-content:center;gap:8px;padding:11px;
  background:rgba(16,14,11,.92);backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--line)}
.tab{font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.12em;font-size:13px;
  background:transparent;border:1px solid var(--line);color:var(--dim);padding:8px 22px;border-radius:999px;cursor:pointer;transition:.15s}
.tab:hover{color:var(--ink);border-color:var(--gold)}
.tab.active{background:var(--gold);color:#160f04;border-color:var(--gold)}

/* timeline view */
.tl-head{max-width:760px;margin:40px auto 0;padding:0 22px;text-align:center}
#timeline{max-width:760px;margin:26px auto 0;padding:0 22px 50px;position:relative}
#timeline::before{content:"";position:absolute;left:34px;top:8px;bottom:8px;width:2px;background:linear-gradient(var(--gold),rgba(255,255,255,.05));opacity:.4}
.tl-decade{font-family:Oswald,sans-serif;font-weight:700;font-size:21px;color:var(--gold);letter-spacing:.06em;margin:28px 0 12px;padding-left:56px}
.tl-item{position:relative;padding-left:56px;margin-bottom:12px}
.tl-dot{position:absolute;left:28px;top:22px;width:14px;height:14px;border-radius:50%;background:var(--fam);border:3px solid var(--bg);box-shadow:0 0 0 2px var(--fam)}
.tl-card{display:flex;gap:13px;background:linear-gradient(180deg,var(--card),#141009);border:1px solid var(--line);border-left:3px solid var(--fam);border-radius:10px;padding:12px 14px}
.tl-portrait{width:54px;height:66px;flex:none;object-fit:cover;border-radius:6px;filter:grayscale(.35) sepia(.15);background:#0c0a07;border:1px solid var(--line)}
.tl-portrait.noimg{display:flex;align-items:center;justify-content:center;font-family:Oswald,sans-serif;font-size:18px;font-weight:600;color:var(--faint)}
.tl-body{flex:1;min-width:0}
.tl-top{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.tl-name{font-family:Oswald,sans-serif;font-weight:600;font-size:17px;color:var(--ink)}
.tl-years{font-family:Oswald,sans-serif;font-size:12px;color:var(--fam);letter-spacing:.06em}
.tl-role{font-style:italic;color:var(--dim);font-size:13px;margin-top:3px}
.tl-lede{font-weight:500;color:var(--ink);opacity:.92}
.tl-event-body{margin-top:8px;font-family:Spectral,Georgia,serif;font-style:normal;color:var(--dim);font-size:13.5px;line-height:1.62}
.tl-event-body p{margin:0 0 8px}
.tl-event-body p:last-child{margin-bottom:0}
.tl-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:9px}
.tl-fam{font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.1em;font-size:10px;color:var(--fam)}
.tl-fam:hover{text-decoration:underline}
.tl-meta .pfate{margin-top:0}

/* timeline events (admin-added) */
.tl-dot.ev{border-radius:2px;transform:rotate(45deg);width:13px;height:13px}
.tl-item.tl-event .tl-card{border-left-width:4px;background:linear-gradient(180deg,rgba(201,162,74,.07),#141009)}
.tl-evtag{font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.13em;font-size:10px;color:var(--fam);
  background:rgba(255,255,255,.05);border:1px solid var(--fam);border-radius:4px;padding:1px 7px}

/* admin-attached media (image / video) under a person card or event */
.mb-media{margin-top:13px;display:flex;flex-direction:column;gap:11px}
.mb-img{width:100%;max-height:420px;object-fit:cover;border-radius:9px;border:1px solid var(--line);display:block}
.mb-video{width:100%;border-radius:9px;border:1px solid var(--line);background:#000;display:block}
.mb-embed{position:relative;width:100%;padding-top:56.25%;border-radius:9px;overflow:hidden;border:1px solid var(--line);background:#000}
.mb-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* admin-attached LoC newspaper links */
.mb-news{margin-top:12px;border-top:1px solid var(--line);padding-top:10px}
.mb-news-h{font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:11px;color:var(--gold);margin-bottom:6px}
.mb-news-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:5px}
.mb-news-list li{font-size:14px;line-height:1.4}
.mb-news-list a{color:var(--ink);border-bottom:1px dotted var(--faint)}
.mb-news-list a:hover{color:var(--gold)}
.mb-news-meta{color:var(--faint);font-size:12px;font-style:italic}

/* card historical-news + wiki links */
.card-links{display:flex;flex-wrap:wrap;gap:16px;margin-top:14px}
.card-links .wlink{margin-top:0}
.wlink.chron{color:var(--dim)}
.wlink.chron:hover{color:var(--gold)}

/* admin-uploaded dark scrolling photo backdrop */
.photo-bg{position:fixed;top:0;left:0;right:0;height:142vh;z-index:0;display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));grid-auto-rows:200px;gap:4px;
  opacity:.26;filter:grayscale(.55) sepia(.22) contrast(.95);pointer-events:none;will-change:transform}
.photo-bg img{width:100%;height:100%;object-fit:cover;display:block}
body.has-photobg::after{content:"";position:fixed;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,rgba(16,14,11,.8),rgba(16,14,11,.9) 60%,rgba(16,14,11,.97))}
body.has-photobg .hero,body.has-photobg .tabs,body.has-photobg #view-families,
body.has-photobg #view-timeline,body.has-photobg .foot{position:relative;z-index:2}

/* ── era banner ── */
.era{max-width:760px;margin:64px auto 0;padding:0 22px;text-align:center}
.era::before{content:"";display:block;width:1px;height:46px;margin:0 auto 22px;background:linear-gradient(var(--gold),transparent)}
.era-t{font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.16em;font-size:clamp(22px,4vw,30px);color:var(--gold);margin:0}
.era-s{color:var(--dim);font-size:15px;margin:9px 0 0;font-style:italic}

/* ── family section ── */
main{max-width:760px;margin:0 auto;padding:0 22px}
.fam{padding:60px 0 30px}
.fam-head{margin-bottom:30px}
.fam-rule{width:54px;height:5px;background:var(--fam);border-radius:3px;margin-bottom:14px;box-shadow:0 0 24px var(--fam)}
.fam-city{font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.2em;font-size:11px;color:var(--fam);margin-bottom:5px}
.fam-name{font-family:Oswald,sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.05em;
  font-size:clamp(28px,5vw,44px);margin:0;color:var(--ink)}
.fam-blurb{color:var(--dim);font-size:16px;margin:8px 0 0;max-width:600px}

/* ── timeline ── */
.timeline{position:relative;padding-left:30px}
.timeline::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;
  background:linear-gradient(var(--fam),rgba(255,255,255,.04));opacity:.6}
.node{position:relative;margin:0 0 22px}
.dot{position:absolute;left:-30px;top:24px;width:16px;height:16px;border-radius:50%;
  background:var(--fam);border:3px solid var(--bg);box-shadow:0 0 0 2px var(--fam),0 0 18px var(--fam)}
.dot.small{width:11px;height:11px;top:50%;transform:translateY(-50%);box-shadow:0 0 0 2px var(--fam)}

.card{display:flex;gap:18px;background:linear-gradient(180deg,var(--card),#141009);
  border:1px solid var(--line);border-left:3px solid var(--fam);border-radius:12px;padding:18px;
  box-shadow:0 18px 40px rgba(0,0,0,.4)}
.portrait{width:104px;height:128px;flex:none;object-fit:cover;border-radius:8px;
  filter:grayscale(.35) sepia(.18) contrast(1.02);background:#0c0a07;border:1px solid var(--line)}
.portrait.noimg{display:flex;align-items:center;justify-content:center;font-family:Oswald,sans-serif;
  font-size:34px;font-weight:600;color:var(--faint);letter-spacing:.04em}
.card-body{flex:1;min-width:0}
.card-top{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}
.pname{font-family:Oswald,sans-serif;font-weight:600;font-size:23px;letter-spacing:.02em;margin:0;color:var(--ink)}
.pyears{font-family:Oswald,sans-serif;font-size:13px;color:var(--fam);letter-spacing:.08em;white-space:nowrap}
.pfate{display:inline-flex;align-items:center;gap:6px;margin-top:9px;font-family:Oswald,sans-serif;
  text-transform:uppercase;letter-spacing:.07em;font-size:11px;font-weight:500;padding:3px 10px;border-radius:999px;border:1px solid}
.pfate .fi{font-size:12px;line-height:1}
.f-killed{color:#e08a82;background:rgba(181,69,59,.13);border-color:rgba(181,69,59,.4)}
.f-nat{color:var(--dim);background:rgba(255,255,255,.03);border-color:var(--line)}
.f-jail{color:#e2bf6a;background:rgba(201,162,74,.12);border-color:rgba(201,162,74,.45)}
.f-live{color:#8fc090;background:rgba(111,155,138,.13);border-color:rgba(111,155,138,.4)}
.f-other{color:#c9b48a;background:rgba(255,255,255,.03);border-color:var(--line)}
.prole{font-style:italic;color:var(--dim);font-size:14px;margin-top:10px}
.pextract{font-size:14.5px;color:#cabfac;margin:10px 0 0}
/* collapsible "Associated with" dropdown */
.assoc{margin-top:14px;border-top:1px solid var(--line);padding-top:12px}
.assoc-sum{list-style:none;cursor:pointer;display:inline-flex;align-items:center;gap:9px;
  font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:11px;color:var(--dim);user-select:none}
.assoc-sum::-webkit-details-marker{display:none}
.assoc-sum::before{content:"▸";color:var(--fam);font-size:11px;transition:transform .15s}
.assoc[open] .assoc-sum::before{transform:rotate(90deg)}
.assoc-sum:hover{color:var(--ink)}
.assoc-count{background:rgba(201,162,74,.12);color:var(--fam);border-radius:999px;padding:1px 9px;letter-spacing:.04em;font-size:11px}
.chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:12px}
.chip{font-family:Oswald,sans-serif;font-size:12.5px;letter-spacing:.02em;color:var(--ink);
  background:rgba(201,162,74,.09);border:1px solid var(--line);border-radius:999px;padding:3px 11px;transition:.15s}
.chip:hover{background:var(--fam);color:#160f04;border-color:var(--fam)}
.wlink{display:inline-block;margin-top:14px;font-family:Oswald,sans-serif;text-transform:uppercase;
  letter-spacing:.12em;font-size:11px;color:var(--gold)}
.wlink:hover{color:#f0d488}

/* reference node (person whose card lives in another family) */
.node.ref{display:flex;align-items:center;margin-bottom:14px}
.refcard{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.02);
  border:1px dashed var(--line);border-radius:999px;padding:7px 16px}
.refname{font-family:Oswald,sans-serif;font-weight:500;font-size:15px;color:var(--ink)}
.refnote{font-size:12px;color:var(--faint);font-style:italic}
.node.ref:hover .refcard{border-color:var(--fam)}

/* flash highlight when jumped-to */
.flash .card,.flash.ref .refcard{animation:flash 1.5s ease}
@keyframes flash{0%,100%{box-shadow:0 18px 40px rgba(0,0,0,.4)}20%{box-shadow:0 0 0 2px var(--fam),0 0 34px var(--fam)}}

/* closing */
.closing{padding:70px 0 40px;border-top:1px solid var(--line);margin-top:30px}
.ranklist{list-style:none;counter-reset:r;padding:0;margin:24px 0 0}
.ranklist li{counter-increment:r;display:flex;align-items:baseline;gap:14px;padding:11px 0;border-bottom:1px solid var(--line)}
.ranklist li::before{content:counter(r);font-family:Oswald,sans-serif;font-size:15px;color:var(--gold);width:24px;text-align:right}
.rankname{font-family:Oswald,sans-serif;font-size:18px;font-weight:500}
.rankn{margin-left:auto;font-size:12px;color:var(--faint);font-family:Oswald,sans-serif;letter-spacing:.08em}

/* footer */
.foot{max-width:760px;margin:0 auto;padding:40px 22px 70px;color:var(--faint);font-size:13px;border-top:1px solid var(--line)}
.foot a{color:var(--dim)} .foot .gen{margin-top:8px;font-size:12px;color:var(--faint)}
.loaderr{color:var(--dim);text-align:center;padding:60px}

/* scroll reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.scrollcue .arrow{animation:none}}

@media (max-width:560px){
  .card{flex-direction:column;gap:14px}
  .portrait{width:96px;height:118px}
  .stats{gap:30px}
}
