/* ============================================================
   PEOPLE OF THE LANTERN — survivor record
   Aesthetic: bright, airy, editorial minimal.
   White space, hairline rules, light geometric type, monochrome
   charcoal with a single restrained red for danger.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Jost:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&display=swap');

:root{
  --bg:      #ffffff;
  --bg-soft: #f7f6f3;
  --ink:     #26262a;
  --ink-soft:#5f5f64;
  --muted:   #9b9aa0;
  --faint:   #c3c2bd;
  --hair:    #ebe9e4;
  --hair-2:  #d9d7d1;
  --danger:  #b23b32;

  --r: 12px;
  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
}

*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
body{
  background:var(--bg);
  color:var(--ink);
  font-family:"Jost", system-ui, sans-serif;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  letter-spacing:.2px;
  min-height:100vh;
}
.lantern{ display:none; } /* atmosphere removed for clarity */

/* ============================================================ LAYOUT */
.app{ display:grid; grid-template-columns:268px 1fr; min-height:100vh; }

/* ---------- ROSTER ---------- */
.roster{
  position:sticky; top:0; align-self:start; height:100vh;
  display:flex; flex-direction:column;
  background:var(--bg-soft); border-right:1px solid var(--hair);
}
.roster__brand{ padding:34px 26px 22px; }
.roster__brand .kicker{
  font-size:9.5px; font-weight:500; letter-spacing:.34em; text-transform:uppercase;
  color:var(--muted); margin:0 0 12px;
}
.roster__brand h1{
  font-weight:300; font-size:25px; line-height:1.12; margin:0; color:var(--ink); letter-spacing:.01em;
}
.roster__brand p{ margin:10px 0 0; font-size:13px; color:var(--muted); font-weight:300; }

.roster__list{ flex:1; overflow-y:auto; padding:8px 14px; display:flex; flex-direction:column; gap:2px; }
.roster__list::-webkit-scrollbar{ width:8px; }
.roster__list::-webkit-scrollbar-thumb{ background:var(--hair-2); border-radius:8px; }

.survivor-chip{
  text-align:left; cursor:pointer; width:100%;
  padding:13px 12px; border-radius:8px; border:none; background:transparent; color:var(--ink-soft);
  font-family:inherit; font-size:15px; font-weight:400;
  display:flex; flex-direction:column; gap:5px;
  transition:background .3s var(--ease), color .25s;
}
.survivor-chip:hover{ background:#efedea; color:var(--ink); }
.survivor-chip.active{ background:var(--ink); color:#fff; }
.survivor-chip .name.unnamed{ font-style:italic; color:var(--muted); font-weight:300; }
.survivor-chip.dead .name{ text-decoration:line-through; opacity:.6; }
.survivor-chip.active .name.unnamed{ color:#bdbdbd; }
.survivor-chip .tags{ display:flex; gap:6px; flex-wrap:wrap; }
.chip-tag{
  font-size:8.5px; letter-spacing:.18em; text-transform:uppercase; font-weight:500;
  padding:2px 8px; border-radius:20px; border:1px solid var(--hair-2); color:var(--muted);
}
.survivor-chip.active .chip-tag{ border-color:rgba(255,255,255,.3); color:rgba(255,255,255,.75); }
.chip-tag.danger{ color:var(--danger); border-color:rgba(178,59,50,.35); }
.survivor-chip.active .chip-tag.danger{ color:#ffb3ab; border-color:rgba(255,179,171,.4); }

.roster__foot{ padding:16px; border-top:1px solid var(--hair); display:flex; flex-direction:column; gap:8px; }

/* ---------- buttons ---------- */
.btn{
  font-family:inherit; font-size:11px; letter-spacing:.16em; text-transform:uppercase; font-weight:500;
  padding:12px 14px; border-radius:8px; cursor:pointer;
  border:1px solid var(--hair-2); background:#fff; color:var(--ink-soft);
  transition:all .25s var(--ease);
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
}
.btn:hover{ color:#fff; background:var(--ink); border-color:var(--ink); }
.btn--ghost:hover{ color:var(--ink); background:#efedea; border-color:var(--hair-2); }
.btn--block{ width:100%; }
.btn-row{ display:flex; gap:8px; }
.btn-row .btn{ flex:1; }

/* ============================================================ MAIN */
.main{ max-width:1100px; }
.scroll{ padding:52px 64px 120px; }
@media(max-width:1100px){ .scroll{ padding:40px 36px 100px; } }

.reveal{ opacity:0; transform:translateY(10px); animation:rise .55s var(--ease-out) forwards; }
@keyframes rise{ to{ opacity:1; transform:none; } }

/* ---------- hero ---------- */
.hero{ margin-bottom:54px; }
.hero__row{ display:flex; align-items:flex-end; gap:24px; flex-wrap:wrap; }
.name-field{ flex:1; min-width:260px; }
.name-field .label{ font-size:9.5px; letter-spacing:.34em; text-transform:uppercase;
  color:var(--muted); margin-bottom:10px; font-weight:500; }
.name-input{
  width:100%; background:transparent; border:none; outline:none; color:var(--ink);
  font-family:inherit; font-weight:300; font-size:clamp(30px,4.4vw,50px); line-height:1.05;
  padding:0 0 10px; border-bottom:1px solid var(--hair); transition:border-color .35s var(--ease);
}
.name-input::placeholder{ color:var(--faint); }
.name-input:focus{ border-color:var(--ink); }
.hero__tagline{ margin:18px 0 0; color:var(--muted); font-size:14.5px; font-weight:300; }
.hero__tagline b{ color:var(--ink-soft); font-weight:500; }

.hero__meta{ display:flex; gap:10px; align-items:center; }
.seg{ display:inline-flex; border:1px solid var(--hair-2); border-radius:30px; overflow:hidden; }
.seg button{ font-family:inherit; font-size:13px; letter-spacing:.06em; padding:9px 16px; cursor:pointer;
  background:#fff; border:none; color:var(--muted); transition:all .25s var(--ease); }
.seg button.on{ background:var(--ink); color:#fff; }
.seg button:hover:not(.on){ color:var(--ink); }

/* ---------- sections & cards ---------- */
.section{ margin:46px 0 0; }
.section > h2{
  font-size:11px; letter-spacing:.26em; text-transform:uppercase; color:var(--muted); font-weight:500;
  margin:0 0 22px; padding-bottom:12px; border-bottom:1px solid var(--hair);
}
.grid{ display:grid; gap:22px; }
.cols-2{ grid-template-columns:1fr 1fr; }
.cols-3{ grid-template-columns:repeat(3,1fr); }
@media (max-width:980px){ .cols-2,.cols-3{ grid-template-columns:1fr; } }

.card{
  background:#fff; border:1px solid var(--hair); border-radius:var(--r); padding:26px;
  transition:border-color .3s var(--ease);
}
.card:hover{ border-color:var(--hair-2); }
.card__title{
  font-size:10.5px; letter-spacing:.24em; text-transform:uppercase; color:var(--muted); font-weight:500;
  margin:0 0 20px; display:flex; align-items:baseline; gap:10px;
}
.card__note{ font-size:11px; color:var(--faint); text-transform:none; letter-spacing:.02em; font-weight:300;
  font-style:italic; }

/* the stats row sits on open space, no heavy frame */
.card--stats{ border:1px solid var(--hair); }
.statline{ display:grid; grid-template-columns:auto 1px auto 1px 1fr; gap:30px; align-items:center; }
@media(max-width:880px){ .statline{ grid-template-columns:1fr; gap:26px; }
  .statline .vrule{ display:none; } }

.bigstat{ display:flex; flex-direction:column; align-items:center; gap:14px; }
.bigstat .cap{ font-size:10px; letter-spacing:.26em; text-transform:uppercase; color:var(--muted); font-weight:500; }
.dial{ display:flex; align-items:center; gap:16px; }
.dial button{
  width:30px; height:30px; border-radius:50%; cursor:pointer; flex:none;
  border:1px solid var(--hair-2); background:#fff; color:var(--ink-soft);
  font-size:17px; line-height:1; display:grid; place-items:center; transition:all .2s var(--ease);
}
.dial button:hover{ background:var(--ink); color:#fff; border-color:var(--ink); }
.dial .val{ font-weight:300; font-size:52px; line-height:1; min-width:60px; text-align:center; color:var(--ink); }
.dial .val.pulse{ animation:pop .3s var(--ease-out); }
@keyframes pop{ 0%{ transform:scale(1);} 45%{ transform:scale(1.1);} 100%{ transform:scale(1);} }
.vrule{ width:1px; align-self:stretch; background:var(--hair); }

.insane-flag{ font-size:9.5px; letter-spacing:.24em; text-transform:uppercase; color:var(--danger);
  font-weight:500; opacity:0; transition:opacity .35s; height:12px; }
.insane-flag.show{ opacity:1; }

/* ---------- tracks (pips) ---------- */
.track{ display:flex; flex-direction:column; gap:11px; }
.track__pips{ display:flex; flex-wrap:wrap; gap:6px; align-items:center; }
.pip{
  width:20px; height:20px; border-radius:5px; cursor:pointer; flex:none; position:relative;
  border:1.5px solid var(--hair-2); background:#fff; padding:0;
  transition:background .2s var(--ease), border-color .2s var(--ease), transform .15s var(--ease);
}
.pip:hover{ border-color:var(--ink); transform:translateY(-1px); }
.pip.on{ background:var(--ink); border-color:var(--ink); }
.pip.milestone{ border-radius:50%; }
.pip.retire{ border-color:rgba(178,59,50,.5); }
.pip.retire.on{ background:var(--danger); border-color:var(--danger); }
.pip__star{ position:absolute; inset:0; display:grid; place-items:center; font-size:9px;
  color:var(--muted); pointer-events:none; }
.pip.on .pip__star{ color:#fff; }
.track__legend{ display:flex; gap:18px; flex-wrap:wrap; font-size:11px; color:var(--muted); font-weight:300; }
.track__legend b{ color:var(--ink-soft); font-weight:500; letter-spacing:.06em; }

/* ---------- attributes ---------- */
.attr-grid{ display:grid; grid-template-columns:repeat(6,1fr); gap:0; border-top:1px solid var(--hair); }
@media(max-width:900px){ .attr-grid{ grid-template-columns:repeat(3,1fr); } }
@media(max-width:520px){ .attr-grid{ grid-template-columns:repeat(2,1fr); } }
.attr{ padding:22px 14px; text-align:center; border-bottom:1px solid var(--hair);
  border-right:1px solid var(--hair); transition:background .25s var(--ease); }
.attr:hover{ background:var(--bg-soft); }
.attr__name{ font-weight:500; font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink); }
.attr__sub{ font-size:10.5px; color:var(--muted); margin-bottom:14px; font-weight:300; }
.attr__total{ font-weight:300; font-size:42px; line-height:1; color:var(--ink); margin-bottom:14px; transition:transform .2s; }
.attr__total.pulse{ animation:pop .3s var(--ease-out); }
.attr__bg{ display:flex; gap:8px; justify-content:center; }
.minifield{ display:flex; flex-direction:column; gap:4px; flex:1; max-width:54px; }
.minifield label{ font-size:8px; letter-spacing:.18em; text-transform:uppercase; color:var(--faint); font-weight:500; }
.minifield input{
  width:100%; text-align:center; background:#fff; border:1px solid var(--hair-2); border-radius:7px;
  color:var(--ink-soft); font-family:inherit; font-weight:400; font-size:15px; padding:6px 0; outline:none;
  transition:border-color .2s, color .2s;
}
.minifield input:focus{ border-color:var(--ink); color:var(--ink); }

/* ---------- hit locations ---------- */
.loc-grid{ display:grid; grid-template-columns:repeat(6,1fr); gap:12px; }
@media(max-width:1000px){ .loc-grid{ grid-template-columns:repeat(3,1fr); } }
@media(max-width:560px){ .loc-grid{ grid-template-columns:repeat(2,1fr); } }
.loc{ border:1px solid var(--hair); border-radius:10px; padding:18px 14px; text-align:center;
  transition:border-color .25s var(--ease); }
.loc:hover{ border-color:var(--hair-2); }
.loc__name{ font-weight:500; font-size:12px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink); margin-bottom:14px; }
.loc__armor{ display:flex; align-items:baseline; justify-content:center; gap:7px; margin-bottom:16px; }
.loc__armor input{ width:58px; text-align:center; background:#fff; border:1px solid var(--hair-2);
  border-radius:8px; color:var(--ink); font-family:inherit; font-weight:300; font-size:26px; padding:6px 0;
  outline:none; transition:border-color .2s; }
.loc__armor input:focus{ border-color:var(--ink); }
.loc__armor .ap{ font-size:9px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); font-weight:500; }
.loc__inj{ display:flex; gap:14px; justify-content:center; }
.injtog{ display:flex; align-items:center; gap:6px; cursor:pointer; user-select:none;
  font-size:11px; letter-spacing:.08em; color:var(--muted); font-weight:500; transition:color .2s; }
.injtog:hover{ color:var(--ink); }
.injtog .box{ width:15px; height:15px; border-radius:4px; border:1.5px solid var(--hair-2); transition:all .2s var(--ease); }
.injtog.on{ color:var(--danger); }
.injtog.on .box{ background:var(--danger); border-color:var(--danger); }

/* ---------- pills ---------- */
.pills{ display:flex; flex-wrap:wrap; gap:8px; }
.pill{
  font-family:inherit; font-size:12px; letter-spacing:.04em; cursor:pointer; user-select:none; font-weight:400;
  padding:8px 15px; border-radius:30px; border:1px solid var(--hair-2); color:var(--ink-soft); background:#fff;
  transition:all .22s var(--ease); display:inline-flex; align-items:center; gap:8px;
}
.pill:hover{ color:var(--ink); border-color:var(--ink); }
.pill.on{ color:#fff; background:var(--ink); border-color:var(--ink); }
.pill.danger.on{ background:var(--danger); border-color:var(--danger); }

/* ---------- text fields / lists ---------- */
.field{ margin-bottom:16px; }
.field:last-child{ margin-bottom:0; }
.field > label{ display:block; font-size:9px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--muted); margin-bottom:7px; font-weight:500; }
.field input.line, .field textarea{
  width:100%; background:#fff; border:none; border-bottom:1px solid var(--hair); border-radius:0;
  color:var(--ink); font-family:inherit; font-size:15px; padding:8px 2px; outline:none;
  transition:border-color .25s; resize:vertical; font-weight:300;
}
.field textarea{ border:1px solid var(--hair); border-radius:10px; padding:12px 14px; min-height:96px; line-height:1.6; }
.field input.line:focus{ border-color:var(--ink); }
.field textarea:focus{ border-color:var(--hair-2); }

.ability-row{ display:flex; gap:12px; align-items:flex-start; margin-bottom:12px; }
.ability-row:last-child{ margin-bottom:0; }
.ability-row .pill{ flex:none; margin-top:2px; padding:6px 11px !important; }
.ability-row .txt b{ color:var(--ink); font-weight:500; font-size:12px; letter-spacing:.04em;
  display:block; margin-bottom:2px; }
.ability-row .txt span{ font-size:13px; color:var(--muted); font-weight:300; line-height:1.45; }

/* ---------- severe injuries ---------- */
.sev-region{ border:1px solid var(--hair); border-radius:10px; padding:16px 18px; margin-bottom:14px; }
.sev-region:last-child{ margin-bottom:0; }
.sev-region__head{ margin-bottom:12px; padding-bottom:10px; border-bottom:1px solid var(--hair); }
.sev-region__head .nm{ font-weight:500; font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-soft); }
.sev-injury{ display:flex; align-items:center; gap:12px; padding:7px 0; }
.sev-injury .label{ flex:1; font-size:14px; color:var(--ink); font-weight:300; }
.sev-injury .label .retire{ font-size:8px; letter-spacing:.12em; color:var(--danger);
  border:1px solid rgba(178,59,50,.35); border-radius:20px; padding:1px 7px; margin-left:9px;
  text-transform:uppercase; font-weight:500; }
.sev-injury.filled .label{ color:var(--danger); }

/* ---------- family ---------- */
.family{ display:flex; flex-direction:column; align-items:center; gap:14px; }
.family__row{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.fambox{ width:150px; }
.fambox input{ width:100%; text-align:center; background:#fff; border:1px solid var(--hair); border-radius:9px;
  color:var(--ink); font-family:inherit; font-size:14px; padding:10px; outline:none; font-weight:300;
  transition:border-color .2s; }
.fambox input:focus{ border-color:var(--ink); }
.fambox.center input{ border-color:var(--hair-2); font-weight:500; }
.fam-connect{ width:1px; height:18px; background:var(--hair-2); }
.fam-lbl{ font-size:9px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); font-weight:500; }
.fam-lbl em{ font-style:normal; color:var(--faint); text-transform:none; letter-spacing:.02em; font-weight:300; }
.fam-self{ border:1px solid var(--hair-2); border-radius:9px; padding:13px 22px; font-weight:500;
  color:var(--ink); min-width:200px; text-align:center; background:#fff; }
.fam-select{
  appearance:none; -webkit-appearance:none; background:#fff; border:1px solid var(--hair); border-radius:9px;
  padding:11px 34px 11px 14px; font-family:inherit; font-size:14px; font-weight:300; color:var(--ink);
  cursor:pointer; min-width:170px; transition:border-color .2s;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%239b9aa0' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 14px center;
}
.fam-select:hover{ border-color:var(--hair-2); }
.fam-select:focus{ outline:none; border-color:var(--ink); }
.fam-children{ display:flex; flex-wrap:wrap; gap:8px; justify-content:center; width:100%; }
.fam-childchip{ font-family:inherit; font-size:14px; font-weight:300; color:var(--ink); cursor:pointer;
  background:#fff; border:1px solid var(--hair-2); border-radius:20px; padding:8px 16px; transition:all .2s var(--ease); }
.fam-childchip:hover{ border-color:var(--ink); }
.fam-empty{ font-size:13px; color:var(--muted); font-style:italic; }

/* ---------- three-line lists ---------- */
.lines3{ display:flex; flex-direction:column; gap:14px; }
.lines3 input.line{
  width:100%; background:#fff; border:none; border-bottom:1px solid var(--hair);
  color:var(--ink); font-family:inherit; font-size:15px; font-weight:300; padding:8px 2px; outline:none;
  transition:border-color .25s;
}
.lines3 input.line:focus{ border-color:var(--ink); }

/* ---------- chronicles timeline ---------- */
.timeline{ display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:20px; }
@media(max-width:560px){ .timeline{ grid-template-columns:1fr; gap:16px; } .tl-node--end{ align-items:flex-start !important; text-align:left !important; } }
.tl-node{ display:flex; flex-direction:column; gap:9px; }
.tl-node--end{ align-items:flex-end; text-align:right; }
.tl-cap{ font-size:9px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); font-weight:500; }
.tl-year{ width:96px; background:#fff; border:1px solid var(--hair-2); border-radius:9px; text-align:center;
  font-family:inherit; font-weight:300; font-size:25px; color:var(--ink); padding:7px 0; outline:none;
  transition:border-color .2s; }
.tl-year:focus{ border-color:var(--ink); }
.tl-mid{ display:flex; align-items:center; gap:9px; }
.tl-dot{ width:9px; height:9px; border-radius:50%; background:var(--ink); flex:none; }
.tl-dot--end{ background:#fff; border:1.5px solid var(--ink); }
.tl-rail{ width:30px; height:1px; background:var(--hair-2); }
.tl-span{ font-size:11px; letter-spacing:.05em; color:var(--ink-soft); white-space:nowrap; font-weight:400;
  padding:5px 12px; border:1px solid var(--hair); border-radius:20px; }

/* ---------- records / great deeds ---------- */
.notes{ display:flex; flex-direction:column; gap:8px; margin-bottom:14px; }
.note{ display:flex; align-items:center; gap:12px; padding-left:14px;
  border-left:2px solid transparent; transition:border-color .25s var(--ease); }
.note.deed{ border-left-color:var(--ink); }
.note__deed{ flex:none; width:30px; height:30px; border-radius:50%; cursor:pointer;
  border:1px solid var(--hair-2); background:#fff; color:var(--muted); font-size:15px; line-height:1;
  display:grid; place-items:center; transition:all .2s var(--ease); }
.note__deed:hover{ border-color:var(--ink); color:var(--ink); }
.note.deed .note__deed{ background:var(--ink); border-color:var(--ink); color:#fff; }
.note__text{ flex:1; background:#fff; border:none; border-bottom:1px solid var(--hair);
  font-family:inherit; font-size:15px; font-weight:300; color:var(--ink); padding:9px 2px; outline:none;
  transition:border-color .2s; }
.note__text:focus{ border-color:var(--ink); }
.note.deed .note__text{ font-weight:400; }
.note__del{ flex:none; width:26px; height:26px; border-radius:50%; cursor:pointer; border:none;
  background:transparent; color:var(--faint); font-size:19px; line-height:1; transition:all .2s; }
.note__del:hover{ color:var(--danger); background:#f7eceb; }
.note-add{ font-family:inherit; font-size:12px; letter-spacing:.08em; color:var(--ink-soft); cursor:pointer;
  background:#fff; border:1px dashed var(--hair-2); border-radius:9px; padding:12px; width:100%; font-weight:400;
  transition:all .2s var(--ease); }
.note-add:hover{ border-color:var(--ink); color:var(--ink); background:var(--bg-soft); }

/* ---------- toast ---------- */
.toast{ position:fixed; bottom:26px; left:50%; transform:translateX(-50%) translateY(16px);
  background:var(--ink); color:#fff; font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; font-weight:500;
  padding:11px 22px; border-radius:30px; box-shadow:0 8px 30px -10px rgba(0,0,0,.4);
  opacity:0; pointer-events:none; transition:opacity .25s, transform .35s var(--ease-out); z-index:200; }
.toast.show{ opacity:1; transform:translateX(-50%) translateY(0); }
.toast--off{ background:var(--danger); }

#importFile{ display:none; }

/* ============================================================ SIDEBAR NAV */
.roster__camp{ padding:4px 18px 16px; border-bottom:1px solid var(--hair); }
.roster__lbl{ font-size:9px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); font-weight:500;
  display:block; margin-bottom:8px; }
.roster__nav{ flex:1; display:flex; flex-direction:column; min-height:0; padding:12px 14px 4px; }
.nav-item{ font-family:inherit; font-size:14px; text-align:left; padding:12px; border-radius:8px; border:none;
  background:transparent; color:var(--ink-soft); cursor:pointer; transition:all .25s var(--ease); }
.nav-item:hover{ background:#efedea; color:var(--ink); }
.nav-item.active{ background:var(--ink); color:#fff; }
.roster__subhead{ font-size:9px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); font-weight:500;
  margin:18px 4px 6px; display:flex; gap:6px; }
.roster__nav .roster__list{ padding:0; }

/* ============================================================ SETTLEMENT */
.campaign-tag{ font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted);
  border:1px solid var(--hair-2); border-radius:20px; padding:9px 16px; font-weight:500; }
.settle .val{ font-size:36px; font-weight:300; }
.settle .dial button{ width:28px; height:28px; font-size:15px; }
.statline--6, .statline--4{ display:flex; justify-content:space-between; align-items:center; gap:14px; flex-wrap:wrap; }
.statline--6 .bigstat, .statline--4 .bigstat{ flex:1; min-width:110px; }

.sub-lbl{ font-size:9px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); font-weight:500; margin:0 0 10px; }

/* checkbox square used across settlement */
.ms-box{ width:18px; height:18px; border:1.5px solid var(--hair-2); border-radius:5px; cursor:pointer; flex:none;
  display:inline-block; transition:all .2s var(--ease); }
.ms-box:hover{ border-color:var(--ink); }
.ms-box.on{ background:var(--ink); border-color:var(--ink); }

/* timeline */
.card--timeline{ padding:24px 22px; }
.tl-head,.tl-row{ display:grid; grid-template-columns:24px 36px 1fr 1.5fr; gap:18px; align-items:center; }
.tl-head{ font-size:9px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); font-weight:500;
  padding:0 6px 12px; border-bottom:1px solid var(--hair); margin-bottom:6px; }
.tl-row{ padding:2px 6px; border-radius:9px; transition:background .18s var(--ease); }
.tl-row:hover{ background:var(--bg-soft); }
.tl-year-n{ font-weight:400; font-size:15px; color:var(--ink-soft); text-align:center; font-variant-numeric:tabular-nums; }
.tl-row.done .tl-year-n{ color:var(--faint); }
.tl-row.done .tl-input{ color:var(--muted); }
.tl-input{ width:100%; background:transparent; border:none; border-bottom:1px solid var(--hair);
  color:var(--ink); font-family:inherit; font-size:14px; font-weight:300; padding:9px 3px; outline:none;
  transition:border-color .2s; }
.tl-input::placeholder{ color:var(--faint); }
.tl-input:focus{ border-bottom-color:var(--ink); }

/* milestones */
.ms-row{ display:grid; grid-template-columns:20px 1fr auto; gap:12px; align-items:center; padding:9px 0; border-bottom:1px solid var(--hair); }
.ms-row:last-child{ border-bottom:none; }
.ms-cond{ font-size:13.5px; color:var(--ink); font-weight:300; }
.ms-reward{ font-size:11px; color:var(--muted); font-weight:500; letter-spacing:.04em; }

/* principles */
.pr-row{ display:grid; grid-template-columns:84px 1fr 1fr; gap:9px; align-items:center; padding:9px 0; border-bottom:1px solid var(--hair); }
.pr-row:last-child{ border-bottom:none; }
.pr-name{ font-size:10.5px; font-weight:500; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft); }
.pr-opt{ font-size:13px; padding:9px 10px; border:1px solid var(--hair-2); border-radius:8px; cursor:pointer;
  text-align:center; transition:all .2s var(--ease); color:var(--ink-soft); }
.pr-opt:hover{ border-color:var(--ink); color:var(--ink); }
.pr-opt.on{ background:var(--ink); color:#fff; border-color:var(--ink); }

/* inline stat (innovate) */
.inline-stat{ display:flex; align-items:center; gap:14px; }
.inline-stat .cap{ font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); font-weight:500; }
.inline-stat .val{ font-size:26px; }
.inline-stat .dial button{ width:26px; height:26px; }
.inline-hint{ font-size:12px; color:var(--muted); font-style:italic; }

/* nemesis */
.nem-row{ display:grid; grid-template-columns:1fr auto; gap:12px; align-items:center; padding:7px 0; border-bottom:1px solid var(--hair); }
.nem-row:last-child{ border-bottom:none; }
.nem-name{ font-size:14px; font-weight:300; }

/* checkbox grids (locations / masteries) */
.chk-grid{ display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.chk-grid .pill{ justify-content:flex-start; }

/* generic list rows (innovations, resources) */
.li-row{ display:flex; align-items:center; gap:10px; padding:5px 0; }
.li-text{ flex:1; background:#fff; border:none; border-bottom:1px solid var(--hair); font-family:inherit;
  font-size:14px; font-weight:300; color:var(--ink); padding:8px 2px; outline:none; transition:border-color .2s; }
.li-text:focus{ border-color:var(--ink); }
.qty{ display:flex; align-items:center; gap:8px; flex:none; }
.qty button{ width:26px; height:26px; border-radius:50%; border:1px solid var(--hair-2); background:#fff;
  color:var(--ink-soft); cursor:pointer; font-size:15px; line-height:1; transition:all .2s var(--ease); }
.qty button:hover{ background:var(--ink); color:#fff; border-color:var(--ink); }
.qty b{ min-width:22px; text-align:center; font-weight:500; font-size:15px; }

/* records */
.rec-head,.rec-row{ display:grid; grid-template-columns:1fr 22px 22px 22px 26px; gap:12px; align-items:center; }
.rec-head{ font-size:9px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); font-weight:500;
  padding-bottom:8px; border-bottom:1px solid var(--hair); margin-bottom:4px; }
.rec-row{ padding:5px 0; border-bottom:1px solid var(--hair); }
.rec-row:last-child{ border-bottom:none; }

/* resource storage (multi-type) */
.store-item{ padding:13px 0; border-bottom:1px solid var(--hair); }
.store-item:last-of-type{ border-bottom:none; }
.store-top{ display:flex; align-items:center; gap:12px; }
.store-top .li-text{ flex:1; }
.cat-group{ display:flex; gap:5px; flex:none; }
.cat-box{ width:23px; height:23px; border:1.5px solid var(--hair-2); border-radius:5px; display:grid; place-items:center;
  font-size:11px; font-weight:600; color:var(--muted); cursor:pointer; transition:all .2s var(--ease); }
.cat-box:hover{ border-color:var(--ink); color:var(--ink); }
.cat-box.on{ background:var(--ink); border-color:var(--ink); color:#fff; }
.kw-group{ display:flex; flex-wrap:wrap; gap:6px; margin-top:11px; }
.kw-chip{ font-size:11px; letter-spacing:.02em; padding:5px 11px; border:1px solid var(--hair-2); border-radius:20px;
  color:var(--ink-soft); cursor:pointer; transition:all .2s var(--ease); }
.kw-chip:hover{ border-color:var(--ink); color:var(--ink); }
.kw-chip.on{ background:var(--ink); border-color:var(--ink); color:#fff; }

/* population */
.pop-row{ display:flex; align-items:center; gap:12px; padding:9px 0; border-bottom:1px solid var(--hair); }
.pop-row:last-child{ border-bottom:none; }
.pop-row.dead{ opacity:.5; }
.pop-open{ flex:1; text-align:left; background:none; border:none; cursor:pointer; font-family:inherit;
  font-size:15px; font-weight:300; color:var(--ink); transition:color .2s; }
.pop-open:hover{ text-decoration:underline; }
.pop-open i{ color:var(--muted); }
.seg--sm button{ padding:6px 11px; font-size:13px; }

/* ============================================================ FAMILY TREE MODAL */
#ftModal{ position:fixed; inset:0; z-index:300; background:#fcfbf9; display:none; flex-direction:column; }
#ftModal.open{ display:flex; animation:rise .25s var(--ease-out); }
.ft-bar{ display:flex; align-items:center; justify-content:space-between; gap:18px;
  padding:18px 28px; border-bottom:1px solid var(--hair); background:#fff; }
.ft-bar h2{ font-family:inherit; font-size:13px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-soft);
  font-weight:500; margin:0; }
.ft-bar h2 span{ color:var(--muted); }
.ft-actions{ display:flex; align-items:center; gap:10px; }
.ft-hint{ font-size:12px; color:var(--muted); font-style:italic; margin-right:6px; }
.ft-zoom{ width:40px; padding:10px 0; font-size:16px; }
.ft-canvas{ flex:1; overflow:auto; padding:48px; cursor:grab; }
.ft-canvas.grabbing{ cursor:grabbing; }
.ft-canvas svg{ display:block; margin:0 auto; }
.ft-empty{ color:var(--muted); font-style:italic; text-align:center; margin-top:60px; }

.ft-line{ fill:none; stroke:var(--hair-2); stroke-width:1.6; }
.ft-partner{ stroke:var(--ink); stroke-width:1.6; }
.ft-box{ fill:#fff; stroke:var(--hair-2); stroke-width:1.6; transition:stroke .2s, fill .2s; }
.ft-name{ font-family:"Jost", sans-serif; font-size:15px; font-weight:300; fill:var(--ink); text-anchor:middle; }
.ft-node{ cursor:pointer; }
.ft-node:hover .ft-box{ stroke:var(--ink); fill:var(--bg-soft); }
.ft-cur .ft-box{ stroke:var(--ink); stroke-width:2.2; }
.ft-dead .ft-box{ fill:#f6f4f1; stroke-dasharray:5 4; }
.ft-dead .ft-name{ fill:var(--muted); }
/* highlight a survivor's immediate kin on hover */
.ft-line.ft-hl, .ft-partner.ft-hl{ stroke:var(--danger); stroke-width:2.6; }
.ft-node.ft-kin .ft-box{ stroke:var(--danger); stroke-width:2.4; fill:#fdf3f1; }
.ft-node.ft-kin .ft-name{ fill:var(--ink); }

/* ============================================================ PRINT */
@page{ size:A4; margin:14mm; }
@media print{
  .roster,.toast{ display:none !important; }
  .app{ display:block; }
  .main{ max-width:none; }
  .scroll{ padding:0; }
  .card,.loc,.sev-region{ break-inside:avoid; page-break-inside:avoid; }
  .reveal{ opacity:1 !important; transform:none !important; animation:none !important; }
}
