/* ============================================================
   How Related? page skin. Layers on melrose-tokens.css + maps.css.
   Parchment ground, hunter green + gold, Playfair + Source Serif.
   No em dashes or en dashes anywhere.
   ============================================================ */

body {
  margin: 0;
  background: var(--cream);
  color: var(--ink);
  font-family: var(--ff-body);
  -webkit-font-smoothing: antialiased;
}

.hr-wrap {
  max-width: 920px;
  margin: 0 auto;
  padding: var(--space-10) var(--space-5) var(--space-16);
}

.hr-intro {
  text-align: center;
  margin-bottom: var(--space-10);
}
.hr-intro h1 {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: var(--fs-3xl);
  color: var(--green-deep);
  margin: 0 0 var(--space-3);
  line-height: var(--lh-tight);
}
.hr-intro p {
  font-size: var(--fs-lg);
  color: var(--ink-mid);
  line-height: var(--lh-body);
  max-width: 620px;
  margin: 0 auto;
}
/* one-line plain-language key for the three trust tiers, centered under the intro */
.hr-tier-key {
  display: flex; flex-wrap: wrap; justify-content: center;
  gap: var(--space-2) var(--space-5);
  margin: var(--space-5) auto 0;
  max-width: 720px;
}

/* the two pickers, side by side on desktop */
.hr-pickers {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: var(--space-5);
  align-items: start;
  margin-bottom: var(--space-8);
}
.hr-picker {
  background: var(--white);
  border: var(--border-gold);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: var(--space-6);
}
.hr-picker h2 {
  font-family: var(--ff-body);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-light);
  margin: 0 0 var(--space-3);
}
.hr-search-field { position: relative; }
.hr-search-field input {
  width: 100%;
  box-sizing: border-box;
  background: var(--cream);
  border: var(--border-green);
  border-radius: var(--radius-sm);
  color: var(--ink);
  padding: var(--space-3);
  font-size: var(--fs-base);
  font-family: var(--ff-body);
  outline: none;
}
.hr-search-field input:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 2px rgba(201, 164, 74, 0.18);
}
.hr-results {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  max-height: 280px;
  overflow-y: auto;
  background: var(--white);
  border: var(--border-gold);
  border-radius: var(--radius);
  box-shadow: var(--shadow-md);
  z-index: 50;
  display: none;
}
.hr-results.open { display: block; }
.hr-results .sr-item { color: var(--ink-mid); }

/* the chosen person chip */
.hr-chosen {
  margin-top: var(--space-4);
  min-height: 1.2em;
}
.hr-chosen.empty { color: var(--ink-light); font-style: italic; font-size: var(--fs-sm); }
.hr-chosen .name {
  font-family: var(--ff-display);
  font-size: var(--fs-xl);
  font-weight: 700;
  color: var(--green-deep);
  line-height: var(--lh-snug);
}
.hr-chosen .years { color: var(--ink-light); font-size: var(--fs-sm); margin-top: 2px; }
.hr-chosen .temp-tag {
  display: inline-block;
  margin-left: var(--space-2);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--gold);
  border: 1px solid rgba(201, 164, 74, 0.5);
  border-radius: 999px;
  padding: 1px 8px;
  vertical-align: middle;
}

.hr-between {
  align-self: center;
  font-family: var(--ff-display);
  font-style: italic;
  font-size: var(--fs-lg);
  color: var(--gold);
  padding-top: var(--space-12);
}

/* result card */
.hr-result {
  background: var(--green-deep);
  color: var(--gold-light);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: var(--space-8);
  text-align: center;
  display: none;
}
.hr-result.show { display: block; }
.hr-result .eyebrow {
  font-family: var(--ff-body);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: var(--space-3);
}
.hr-result .term {
  font-family: var(--ff-display);
  font-size: var(--fs-3xl);
  font-weight: 700;
  color: var(--white);
  line-height: var(--lh-tight);
  margin-bottom: var(--space-3);
}
.hr-result .sentence {
  font-size: var(--fs-lg);
  color: var(--gold-light);
  line-height: var(--lh-body);
  max-width: 620px;
  margin: 0 auto var(--space-6);
}
.hr-result.none .term { font-size: var(--fs-2xl); color: var(--gold-light); }

/* named path chain */
.hr-path {
  background: rgba(247, 243, 234, 0.06);
  border: 1px solid rgba(201, 164, 74, 0.28);
  border-radius: var(--radius);
  padding: var(--space-5) var(--space-6);
  margin-top: var(--space-4);
  text-align: left;
}
.hr-path-label {
  font-family: var(--ff-body);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: var(--space-3);
}
.hr-path ol { list-style: none; margin: 0; padding: 0; }
.hr-path li {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  padding: var(--space-1) 0;
  color: var(--cream);
}
.hr-path li .pn { font-weight: 600; color: var(--white); }
.hr-path li .py { color: var(--gold-light); font-size: var(--fs-sm); }
.hr-path li .note {
  color: var(--green-subtle);
  font-size: var(--fs-xs);
  font-style: italic;
}
.hr-path li.mrca .pn { color: var(--gold); }
.hr-path li.temp .pn::after {
  content: ' temporary';
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--gold);
}
.hr-path li .step-mark {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--gold); flex-shrink: 0; align-self: center;
}

/* temporary / off-tree people section */
.hr-temp {
  margin-top: var(--space-12);
  background: var(--white);
  border: var(--border-green);
  border-radius: var(--radius-lg);
  padding: var(--space-6) var(--space-8);
}
.hr-temp h2 {
  font-family: var(--ff-display);
  font-size: var(--fs-xl);
  font-weight: 700;
  color: var(--green-deep);
  margin: 0 0 var(--space-2);
}
.hr-temp .lead {
  color: var(--ink-mid);
  font-size: var(--fs-base);
  line-height: var(--lh-body);
  margin: 0 0 var(--space-5);
}
.hr-temp-form {
  display: grid;
  grid-template-columns: 1.4fr 0.7fr 1.6fr auto;
  gap: var(--space-3);
  align-items: end;
}
.hr-field label {
  display: block;
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-light);
  margin-bottom: var(--space-1);
}
.hr-field input {
  width: 100%;
  box-sizing: border-box;
  background: var(--cream);
  border: var(--border-green);
  border-radius: var(--radius-sm);
  color: var(--ink);
  padding: var(--space-2) var(--space-3);
  font-size: var(--fs-base);
  font-family: var(--ff-body);
  outline: none;
}
.hr-field input:focus { border-color: var(--gold); box-shadow: 0 0 0 2px rgba(201, 164, 74, 0.18); }
.hr-field { position: relative; }

.hr-temp-list { margin-top: var(--space-5); }
.hr-temp-list:empty { display: none; }
.hr-temp-chip {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  background: var(--gold-pale);
  border: 1px solid rgba(201, 164, 74, 0.5);
  border-radius: var(--radius);
  padding: var(--space-2) var(--space-4);
  margin-bottom: var(--space-2);
  font-size: var(--fs-sm);
  color: var(--ink-mid);
}
.hr-temp-chip strong { color: var(--green-deep); }
.hr-temp-chip button {
  background: transparent;
  border: none;
  color: var(--ink-light);
  cursor: pointer;
  font-size: var(--fs-md);
  line-height: 1;
  padding: 2px 6px;
}
.hr-temp-chip button:hover { color: #a44; }

.hr-temp-actions { margin-top: var(--space-4); display: flex; gap: var(--space-3); flex-wrap: wrap; }

.hr-note {
  margin-top: var(--space-3);
  font-size: var(--fs-xs);
  color: var(--ink-light);
  line-height: var(--lh-body);
}

@media (max-width: 760px) {
  .hr-pickers { grid-template-columns: 1fr; }
  .hr-between { padding-top: 0; text-align: center; }
  .hr-temp-form { grid-template-columns: 1fr; }
  .hr-result .term { font-size: var(--fs-2xl); }
}
