/* ============================================================
   Lineage Registry — royal purple + brass gold on ivory
   (matches the Lekgotla La Batlokwa ba Mokgalong website)
   ============================================================ */
:root{
  --ink:#241226;          /* deep aubergine text */
  --ink-soft:#463a52;
  --bone:#fbf6ec;         /* ivory background */
  --bone-2:#f2e9d7;
  --card:#fffdf7;
  --gold:#e3a52a;         /* brass gold */
  --gold-deep:#b9831a;
  --clay:#9a4f33;         /* used sparingly */
  --sage:#4e7a4e;         /* living / verified */
  --line:#e6ddc9;
  --line-soft:#efe7d4;
  --muted:#6d6477;
  --danger:#a23b2c;
  --royal:#4a1768;        /* royal purple surfaces */
  --royal-deep:#330f48;
  --royal-lite:#6a2b95;
  --radius:10px;
  --shadow:0 1px 0 rgba(0,0,0,.04), 0 12px 30px -18px rgba(48,16,72,.45);
}

*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family:'Inter',system-ui,sans-serif;
  color:var(--ink);
  background:var(--bone);
  -webkit-font-smoothing:antialiased;
}
.hidden{display:none !important}
.muted{color:var(--muted)}
.tiny{font-size:11px}
.err{color:var(--danger);font-size:13px;margin:8px 0 0;min-height:16px}

/* ---------- buttons ---------- */
.btn{
  font-family:inherit;font-size:14px;font-weight:600;
  border:1px solid transparent;border-radius:8px;
  padding:10px 16px;cursor:pointer;transition:.15s;
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
}
.btn.sm{padding:6px 12px;font-size:13px}
.btn.full{width:100%}
.btn-gold{background:var(--gold);color:#3a2208;border-color:var(--gold-deep)}
.btn-gold:hover{background:var(--gold-deep);color:#fff}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{background:var(--bone-2)}
.btn-danger{background:transparent;color:var(--danger);border-color:#e0c4bd}
.btn-danger:hover{background:#f6e9e6}

/* ---------- login ---------- */
.login-screen{
  position:fixed;inset:0;display:grid;place-items:center;
  background:radial-gradient(120% 120% at 50% 0%, #6a2b95 0%, #330f48 60%);
}
.login-card{
  background:var(--card);width:min(360px,90vw);padding:38px 34px;
  border-radius:14px;box-shadow:var(--shadow);text-align:center;
  border:1px solid var(--line);
}
.crest{font-size:34px;color:var(--gold);line-height:1}
.crest.sm{font-size:22px}
.login-card h1{font-family:'Fraunces',serif;font-weight:600;font-size:26px;margin:10px 0 4px}
.login-card .sub{color:var(--muted);font-size:14px;margin:0 0 20px}
.login-card input{
  width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:8px;
  font-size:15px;margin-bottom:14px;background:#fff;
}
.login-card input:focus{outline:2px solid var(--gold);border-color:var(--gold)}

/* ---------- app shell ---------- */
.app{display:grid;grid-template-columns:288px 1fr;min-height:100vh}
.rail{
  background:var(--royal);color:#efe7d4;padding:22px 18px;
  display:flex;flex-direction:column;gap:18px;position:sticky;top:0;height:100vh;
}
.brand{display:flex;align-items:center;gap:11px}
.brand-name{font-family:'Fraunces',serif;font-weight:600;font-size:18px;color:#fff}
.brand-sub{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#b7a6d6}
.rail-field label{display:block;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#b7a6d6;margin-bottom:6px}
.rail-field input,.rail-field select{
  width:100%;padding:9px 11px;border-radius:7px;border:1px solid #553a73;
  background:#3a1556;color:#f3ecdf;font-size:14px;font-family:inherit;
}
.rail-field input:focus,.rail-field select:focus{outline:2px solid var(--gold);border-color:var(--gold)}
.results{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:4px;margin:-6px -4px}
.result-item{
  padding:8px 10px;border-radius:7px;cursor:pointer;font-size:14px;
  display:flex;align-items:center;gap:9px;color:#efe7d4;
}
.result-item:hover{background:#3d2155}
.result-item .ravatar{
  width:26px;height:26px;border-radius:50%;background:#553a73;flex:0 0 26px;
  background-size:cover;background-position:center;font-size:11px;color:#b7a6d6;
  display:grid;place-items:center;
}
.rail-foot{display:flex;flex-direction:column;gap:8px;border-top:1px solid #4a2b66;padding-top:14px}
.rail-foot .btn-ghost{color:#efe7d4;border-color:#553a73}
.rail-foot .btn-ghost:hover{background:#3d2155}

/* ---------- canvas ---------- */
.canvas{padding:26px 30px;overflow-x:auto}
.canvas-head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:22px;flex-wrap:wrap}
#canvasTitle{font-family:'Fraunces',serif;font-weight:500;font-size:24px;margin:0;color:var(--ink)}
.legend{display:flex;gap:6px;flex-wrap:wrap}
.chip{font-size:11px;padding:3px 9px;border-radius:20px;border:1px solid var(--line);background:var(--card);font-weight:600}
.chip-verified{color:var(--sage);border-color:#bcd0c2}
.chip-pending{color:var(--gold-deep);border-color:#e3d2a6}
.chip-male{color:#3a5a8c;border-color:#bdcbe0}
.chip-female{color:#8c3a6e;border-color:#e0bdd2}

.tree{min-width:max-content;padding-bottom:60px}
.empty{color:var(--muted);font-size:15px;padding:40px 0;font-style:italic}

/* ---------- person card ---------- */
.node{margin:0}
.pcard{
  display:inline-flex;align-items:center;gap:12px;background:var(--card);
  border:1px solid var(--line);border-radius:var(--radius);padding:10px 14px;
  box-shadow:var(--shadow);cursor:pointer;min-width:220px;transition:.15s;
}
.pcard:hover{border-color:var(--gold);transform:translateY(-1px)}
.pcard.male{border-left:4px solid #3a5a8c}
.pcard.female{border-left:4px solid #8c3a6e}
.pavatar{
  width:46px;height:46px;border-radius:8px;flex:0 0 46px;background:var(--bone-2);
  background-size:cover;background-position:center;display:grid;place-items:center;
  font-family:'Fraunces',serif;font-size:18px;color:var(--muted);
}
.pmeta{display:flex;flex-direction:column;gap:2px}
.pname{font-family:'Fraunces',serif;font-weight:600;font-size:16px;line-height:1.1}
.pdates{font-size:12px;color:var(--muted)}
.pkyc{font-size:10px;letter-spacing:.06em;text-transform:uppercase;padding:2px 7px;border-radius:20px;width:max-content;font-weight:700;margin-top:2px}
.kyc-verified{background:#e4eee7;color:var(--sage)}
.kyc-pending{background:#f3e9cf;color:var(--gold-deep)}
.kyc-rejected{background:#f3ddd7;color:var(--danger)}

/* ---------- household band (the signature element) ---------- */
.households{margin-left:26px;border-left:2px solid var(--line);padding-left:22px;margin-top:10px}
.household{margin:14px 0}
.hband{display:flex;align-items:center;gap:12px;position:relative}
.hband::before{
  content:"";position:absolute;left:-22px;top:50%;width:20px;height:2px;background:var(--line);
}
.worder{
  font-family:'Fraunces',serif;font-size:12px;font-weight:600;color:#fff;background:var(--gold);
  border-radius:20px;padding:3px 11px;white-space:nowrap;letter-spacing:.02em;
}
.worder.loose{background:var(--muted)}
.union-bar{font-size:18px;color:var(--gold);margin:0 2px}
.children{margin-left:26px;border-left:2px solid var(--line-soft);padding-left:22px;margin-top:8px}
.children .node{position:relative;margin:10px 0}
.children .node::before{
  content:"";position:absolute;left:-22px;top:28px;width:20px;height:2px;background:var(--line-soft);
}
.no-children{font-size:12px;color:var(--muted);font-style:italic;margin:6px 0 0 26px}

/* ---------- drawer ---------- */
.scrim{position:fixed;inset:0;background:rgba(20,30,25,.4);opacity:0;pointer-events:none;transition:.2s;z-index:40}
.scrim.show{opacity:1;pointer-events:auto}
.drawer{
  position:fixed;top:0;right:0;height:100vh;width:min(440px,94vw);background:var(--card);
  box-shadow:-18px 0 40px -24px rgba(20,30,25,.6);z-index:50;
  transform:translateX(100%);transition:transform .22s ease;display:flex;flex-direction:column;
  border-left:1px solid var(--line);
}
.drawer.show{transform:translateX(0)}
.drawer-head{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-bottom:1px solid var(--line)}
.drawer-head h3{font-family:'Fraunces',serif;font-weight:600;margin:0;font-size:20px}
.x{background:none;border:none;font-size:26px;cursor:pointer;color:var(--muted);line-height:1}
.drawer-body{flex:1;overflow-y:auto;padding:20px 22px;display:flex;flex-direction:column;gap:13px}
.drawer-foot{display:flex;justify-content:space-between;gap:10px;padding:16px 22px;border-top:1px solid var(--line)}
.fld{display:flex;flex-direction:column;gap:5px;font-size:12px;font-weight:600;color:var(--ink-soft);letter-spacing:.02em}
.fld input,.fld select,.fld textarea{
  font-family:inherit;font-size:14px;font-weight:400;padding:9px 11px;border:1px solid var(--line);
  border-radius:7px;background:#fff;color:var(--ink);
}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:2px solid var(--gold);border-color:var(--gold)}
.two{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.photo-row{display:flex;gap:14px;align-items:center}
.photo-prev{
  width:74px;height:74px;border-radius:10px;background:var(--bone-2);background-size:cover;background-position:center;
  display:grid;place-items:center;font-size:11px;color:var(--muted);flex:0 0 74px;border:1px solid var(--line);
}
.photo-actions{display:flex;flex-direction:column;gap:7px}

/* ---------- marriage panel ---------- */
.marriage-panel{border-top:1px solid var(--line);padding-top:14px;margin-top:4px}
.marriage-panel h4{font-family:'Fraunces',serif;margin:0 0 10px;font-size:16px}
.marriage-list{display:flex;flex-direction:column;gap:7px;margin-bottom:10px}
.mrow{display:flex;justify-content:space-between;align-items:center;background:var(--bone-2);border-radius:7px;padding:7px 11px;font-size:13px}
.mrow .wname{font-weight:600}
.mrow .wdel{background:none;border:none;color:var(--danger);cursor:pointer;font-size:16px}
.add-wife{display:flex;gap:8px}
.add-wife select{flex:1;padding:8px 10px;border:1px solid var(--line);border-radius:7px;font-family:inherit;font-size:13px;background:#fff}

/* ---------- responsive ---------- */
@media(max-width:820px){
  .app{grid-template-columns:1fr}
  .rail{position:static;height:auto}
  .results{max-height:200px}
}

/* ---------- print ---------- */
@media print{
  .rail,.drawer,.scrim,.canvas-head .legend,.rail-foot{display:none !important}
  .app{grid-template-columns:1fr}
  .canvas{padding:0;overflow:visible}
  .pcard{box-shadow:none;break-inside:avoid}
  body{background:#fff}
}

/* ===== auth extras ===== */
.login-card .switch{font-size:13px;color:var(--muted);margin:14px 0 0}
.login-card .switch a{color:var(--gold-deep);cursor:pointer;font-weight:600}
.ok-msg{color:var(--sage);font-size:13px;margin:8px 0 0;min-height:16px}
#setupBox input,#registerBox input{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:8px;font-size:15px;margin-bottom:11px;background:#fff;font-family:inherit}
#setupBox input:focus,#registerBox input:focus{outline:2px solid var(--gold);border-color:var(--gold)}

/* ===== rail who ===== */
.who{font-size:13px;color:#d8cbe8;font-weight:600;padding-bottom:6px}

/* ===== ancestry strip ===== */
.ancestry{margin-bottom:20px;padding:14px 16px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius)}
.anc-label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.anc-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.anc-card{display:flex;align-items:center;gap:8px;background:var(--bone-2);border-radius:20px;padding:5px 12px 5px 5px;font-size:13px;font-weight:600}
.anc-card.you{background:var(--royal);color:#fff}
.anc-av{width:28px;height:28px;border-radius:50%;background:var(--line);background-size:cover;background-position:center;display:grid;place-items:center;font-size:11px;color:var(--muted)}
.anc-arrow{color:var(--gold);font-weight:700}

/* ===== viewer: hide sensitive fields ===== */
body.viewer .staff-only{display:none !important}

/* ===== admin panel ===== */
.drawer.wide{width:min(640px,96vw)}
.tabs{display:flex;gap:6px;margin-bottom:16px;border-bottom:1px solid var(--line)}
.tab{background:none;border:none;padding:8px 14px;font-family:inherit;font-size:14px;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent}
.tab.active{color:var(--ink);border-bottom-color:var(--gold)}
.users-list{display:flex;flex-direction:column;gap:14px}
.ucard{border:1px solid var(--line);border-radius:var(--radius);padding:14px;background:var(--card)}
.ucard.pending{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold) inset}
.uhead{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.ustatus{font-size:10px;text-transform:uppercase;letter-spacing:.06em;font-weight:700;padding:3px 9px;border-radius:20px}
.s-active{background:#e4eee7;color:var(--sage)}
.s-pending{background:#f3e9cf;color:var(--gold-deep)}
.s-suspended{background:#f3ddd7;color:var(--danger)}
.ugrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:12px 0}
.ugrid label{display:flex;flex-direction:column;gap:4px;font-size:11px;font-weight:600;color:var(--ink-soft)}
.ugrid select{padding:7px 9px;border:1px solid var(--line);border-radius:6px;font-family:inherit;font-size:13px;background:#fff}
.ugrid .chkline{flex-direction:row;align-items:center;gap:7px;font-size:13px}
.uactions{display:flex;gap:8px;flex-wrap:wrap}

/* ===== audit ===== */
.audit-list{display:flex;flex-direction:column;gap:2px}
.arow{display:grid;grid-template-columns:120px 110px 1fr;gap:8px;align-items:baseline;padding:7px 8px;border-bottom:1px solid var(--line-soft);font-size:13px}
.arow .aact{font-weight:600}
.arow .adet{color:var(--ink-soft)}
.arow .muted.tiny{grid-column:1/-1;margin-top:-2px}

@media(max-width:560px){ .ugrid{grid-template-columns:1fr} .arow{grid-template-columns:1fr} }

/* ===== highlight the logged-in member's own card ===== */
.pcard.me{border-color:var(--gold);box-shadow:0 0 0 2px var(--gold) inset, var(--shadow)}
.you-tag{display:inline-block;margin-left:8px;font-family:'Inter',sans-serif;font-size:10px;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;color:#fff;background:var(--gold);border-radius:20px;padding:2px 8px;vertical-align:middle}

/* ===== lineage-building action buttons in marriage rows ===== */
.mrow-actions{display:flex;align-items:center;gap:6px}
.mrow-actions .btn.sm{padding:3px 9px;font-size:12px}
.addchild{white-space:nowrap}
#newWifePersonBtn{white-space:nowrap}
.add-wife{flex-wrap:wrap}
