/* ══════════════════════════════════════════════════════════════
   styles.css — all Northcall app styling
   ══════════════════════════════════════════════════════════════ */

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{background:#F0EBE1;color:#1A1814;font-family:'DM Sans',-apple-system,BlinkMacSystemFont,sans-serif;font-size:13px;line-height:1.4}
input,textarea,select,button{font-family:inherit;font-size:inherit}
button{cursor:pointer;transition:all 0.14s}
textarea{resize:vertical}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#E5DDCC;border-radius:3px}
:root{
  --bg:#F0EBE1;--surf:#FFFFFF;--surf2:#F8F4EC;--el:#F8F4EC;
  --bd:#E5DDCC;--bdh:#D4C9B0;
  --sh:0 1px 3px rgba(60,40,10,0.05),0 4px 20px rgba(60,40,10,0.04);--sh-sm:0 1px 3px rgba(60,40,10,0.06);
  --tx:#1A1814;--sec:#5C5347;--mut:#9A9080;
  --gold:#C4923A;--gsub:rgba(196,146,58,0.10);--gbd:rgba(196,146,58,0.30);
  --grn:#047857;--gsn:rgba(4,120,87,0.09);
  --amb:#B45309;--asn:rgba(180,83,9,0.09);
  --red:#B91C1C;--rsn:rgba(185,28,28,0.09);
  --blu:#1D4ED8;--bsn:rgba(29,78,216,0.09);
  --pur:#6D28D9;
  --nc:#6B7AE0;--ncsub:rgba(107,122,224,0.10);--ncbd:rgba(107,122,224,0.30);
  --s1:#9A9080;--s2:#3B82F6;--s3:#8B5CF6;--s4:#06B6D4;--s5:#B45309;--s6:#C4923A;--s7:#047857;
}
.nav{height:50px;background:var(--surf);border-bottom:1px solid rgba(196,146,58,0.22);display:flex;align-items:center;padding:0 20px;position:sticky;top:0;z-index:100}
.logo{display:flex;align-items:center;gap:9px;background:none;border:none;padding:0}
.logo-m{width:25px;height:25px;border-radius:6px;background:var(--gsub);border:1px solid var(--gbd);display:flex;align-items:center;justify-content:center;font-family:Cormorant,Georgia,serif;font-size:14px;color:var(--gold);flex-shrink:0}
.logo-t{font-family:Cormorant,Georgia,serif;font-size:16px;letter-spacing:.14em;color:var(--tx);font-weight:400}
.crumbs{display:flex;align-items:center;gap:5px;margin-left:18px}
.crumb{background:none;border:none;padding:0;font-size:12px;color:var(--sec)}
.crumb:hover{color:var(--tx)}
.crumb.cur{color:var(--tx);font-weight:500}
.crumb-sep{color:var(--mut)}
.crumb-gold{color:var(--gold);font-size:12px}
.nav-r{margin-left:auto;display:flex;align-items:center;gap:10px}
.nav-count{font-family:'DM Mono','Courier New',monospace;font-size:10px;color:var(--mut);letter-spacing:.05em}
.nav-av{width:27px;height:27px;border-radius:50%;background:var(--el);border:1px solid var(--bdh);font-size:10px;font-weight:600;color:var(--gold);display:flex;align-items:center;justify-content:center}
.s-bar{display:flex;align-items:stretch;border-bottom:1px solid var(--bd);padding:0 20px;overflow-x:auto;flex-shrink:0}
.s-btn{background:none;border:none;border-bottom:2px solid transparent;padding:11px 13px 12px;display:flex;flex-direction:column;align-items:center;gap:4px;min-width:72px;transition:all 0.14s}
.s-btn:hover{background:#F8F4EC}
.s-btn.on{border-bottom-color:var(--sc)}
.s-count{font-family:'DM Mono','Courier New',monospace;font-size:17px;font-weight:500;line-height:1}
.s-label{font-size:9px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--mut);white-space:nowrap}
.s-sep{width:1px;background:var(--bd);margin:10px 0}
.pill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:500;white-space:nowrap;border:1px solid transparent;line-height:1.4}
.tag{font-size:9px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:2px 7px;border-radius:4px;line-height:1.4}
.btn{padding:8px 16px;border-radius:7px;font-size:12px;font-weight:500;border:none;outline:none}
.btn-gold{background:var(--gsub);border:1px solid var(--gbd);color:var(--gold)}
.btn-gold:hover{background:rgba(196,146,58,0.18)}
.btn-ghost{background:none;border:1px solid var(--bd);color:var(--sec)}
.btn-ghost:hover{border-color:var(--bdh);color:var(--tx)}
.btn-grn{background:var(--gsn);border:1px solid rgba(16,185,129,0.35);color:var(--grn)}
.btn-red{background:var(--rsn);border:1px solid rgba(239,68,68,0.3);color:var(--red)}
.btn-sm{padding:5px 10px;font-size:10px;border-radius:5px}
.btn-full{width:100%}
.fg{margin-bottom:22px}
.fl{font-size:9px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--mut);display:block;margin-bottom:8px}
.fi{width:100%;padding:9px 11px;border-radius:7px;background:var(--surf);border:1px solid var(--bd);color:var(--tx);font-size:12px;outline:none;transition:border-color 0.14s}
.fi:focus{border-color:rgba(196,146,58,0.4)}
.fs{width:100%;padding:9px 11px;border-radius:7px;background:var(--surf);border:1px solid var(--bd);color:var(--tx);font-size:12px;outline:none;appearance:none}
.ft{width:100%;padding:9px 11px;border-radius:7px;background:var(--surf);border:1px solid var(--bd);color:var(--tx);font-size:12px;outline:none;min-height:80px;line-height:1.65}
.ft:focus{border-color:rgba(196,146,58,0.4)}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.pl-hdr{padding:16px 20px 10px;display:flex;align-items:center;justify-content:space-between}
.pl-title{font-family:Cormorant,Georgia,serif;font-size:22px;font-weight:400;color:var(--tx)}
.pl-sub{font-size:10px;color:var(--mut);margin-top:3px}
.col-hdr{display:grid;grid-template-columns:1fr 115px 130px 60px 140px 1fr 44px 14px;gap:10px;padding:5px 20px}
.col-h{font-size:9px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--mut)}
.row{display:grid;grid-template-columns:1fr 115px 130px 60px 140px 1fr 44px 14px;gap:10px;padding:11px 20px;border-bottom:1px solid #E5DDCC;align-items:center;cursor:pointer}
.row:hover{background:#F8F4EC}
.co-nm{font-size:13px;font-weight:500;color:var(--tx)}
.co-meta{font-size:10px;color:var(--mut);margin-top:2px}
.fit-wrap{display:flex;align-items:center;gap:6px}
.fit-bar{width:42px;height:3px;border-radius:2px;background:#E5DDCC}
.fit-fill{height:100%;border-radius:2px}
.fit-n{font-family:'DM Mono','Courier New',monospace;font-size:10px}
.prob-n{font-family:'DM Mono','Courier New',monospace;font-size:14px;font-weight:500}
.hlth{display:flex;align-items:center;gap:6px;font-size:10px}
.dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.next-t{font-size:11px;color:var(--tx);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.due-t{font-size:9px;font-family:'DM Mono','Courier New',monospace;margin-top:2px}
.cc{display:flex;height:calc(100vh - 50px);overflow:hidden}
.cc-l{width:260px;flex-shrink:0;background:var(--surf);border-right:1px solid var(--bd);display:flex;flex-direction:column;overflow-y:auto}
.cc-m{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}
.cc-r{width:280px;flex-shrink:0;background:var(--surf);border-left:1px solid var(--bd);display:flex;flex-direction:column;overflow-y:auto}
.sec{padding:14px 18px;border-bottom:1px solid var(--bd)}
.sl{font-size:9px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--mut);display:block;margin-bottom:8px}
.ev-hdr{padding:14px 20px 12px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.ev-title{font-family:Cormorant,Georgia,serif;font-size:17px;font-weight:400;color:var(--tx)}
.ev-sub{font-size:10px;color:var(--mut);margin-top:2px}
.ev-scroll{overflow-y:auto;padding:14px 20px;flex:1}
.ev-entry{position:relative;padding-left:20px;margin-bottom:14px}
.ev-line{position:absolute;left:5px;top:25px;bottom:-14px;width:1px;background:var(--bd)}
.ev-dot{position:absolute;left:0;top:13px;width:11px;height:11px;border-radius:50%;background:var(--el);border:1.5px solid var(--bdh)}
.ev-card{background:var(--surf);border-radius:9px;border:1px solid var(--bd);padding:12px}
.ev-meta{display:flex;align-items:center;gap:7px;margin-bottom:8px;flex-wrap:wrap}
.ev-who{font-size:11px;color:var(--sec);font-weight:500}
.ev-date{margin-left:auto;font-family:'DM Mono','Courier New',monospace;font-size:10px;color:var(--mut)}
.ev-text{font-size:11px;color:var(--tx);line-height:1.65;margin-bottom:9px}
.sigs{display:flex;flex-wrap:wrap;gap:4px}
.sig{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:4px;font-size:10px}
.prob-panel{padding:18px 18px 14px;border-bottom:1px solid var(--bd);display:flex;flex-direction:column;align-items:center;gap:10px}
.prob-sum{background:var(--el);border-radius:7px;padding:10px 12px;width:100%}
.prob-row{display:flex;justify-content:space-between;font-size:11px;margin-bottom:5px;cursor:pointer;padding:3px 4px;border-radius:4px;transition:background 0.12s}
.prob-row:last-child{margin-bottom:0}
.prob-row:hover{background:#F8F4EC}
.prob-desc{font-size:10px;color:var(--mut);text-align:center;line-height:1.5}
.sh-card{padding:10px 11px;border-radius:7px;margin-bottom:7px;background:var(--el);border:1px solid var(--bd)}
.sh-name{font-size:12px;font-weight:500;color:var(--tx)}
.sh-role{font-size:10px;color:var(--mut)}
.sh-tags{display:flex;gap:4px;flex-wrap:wrap;margin-top:5px}
.sh-tag{font-size:10px;color:var(--mut);background:#F8F4EC;padding:1px 5px;border-radius:3px}
.score-page{max-width:680px;margin:0 auto;padding:24px 20px}
.sq{background:var(--surf);border-radius:9px;border:1px solid var(--bd);padding:14px;margin-bottom:10px}
.sq-text{font-size:12px;color:var(--tx);line-height:1.5;margin-bottom:10px}
.score-opts{display:flex;gap:8px;margin-bottom:8px}
.sopt{flex:1;padding:8px;border-radius:6px;border:1px solid var(--bd);background:var(--el);color:var(--mut);font-size:11px;font-weight:500;text-align:center;cursor:pointer;transition:all 0.14s}
.sopt.s1.sel{background:var(--rsn);border-color:rgba(239,68,68,0.4);color:var(--red)}
.sopt.s2.sel{background:var(--asn);border-color:rgba(245,158,11,0.4);color:var(--amb)}
.sopt.s3.sel{background:var(--gsn);border-color:rgba(16,185,129,0.45);color:var(--grn)}
.snote{width:100%;padding:7px 10px;border-radius:5px;background:#F8F4EC;border:1px solid var(--bd);color:var(--sec);font-size:11px;outline:none}
.sig-row{display:flex;align-items:center;gap:7px;margin-bottom:6px;background:var(--el);border-radius:7px;padding:8px 10px}
.sig-dir{display:flex;gap:5px}
.sdb{width:26px;height:26px;border-radius:5px;border:1px solid var(--bd);background:none;font-size:12px;display:flex;align-items:center;justify-content:center;color:var(--mut);font-weight:600}
.sdb.pos.sel{background:var(--gsn);border-color:rgba(16,185,129,0.4);color:var(--grn)}
.sdb.amb.sel{background:var(--asn);border-color:rgba(245,158,11,0.4);color:var(--amb)}
.sdb.neg.sel{background:var(--rsn);border-color:rgba(239,68,68,0.4);color:var(--red)}
.sig-in{flex:1;padding:6px 8px;border-radius:5px;background:var(--surf);border:1px solid var(--bd);color:var(--tx);font-size:11px;outline:none}
.sig-wt{padding:5px 7px;border-radius:5px;background:var(--surf);border:1px solid var(--bd);color:var(--sec);font-size:10px;outline:none;width:80px}
.sig-del{width:22px;height:22px;border-radius:4px;border:none;background:none;color:var(--mut);font-size:16px;display:flex;align-items:center;justify-content:center;padding:0;line-height:1}
.sig-del:hover{color:var(--red)}
.gate{padding:11px 13px;border-radius:8px;margin-bottom:8px;display:flex;align-items:flex-start;gap:11px;cursor:pointer;transition:all 0.14s}
.gate:hover{background:var(--el)}
.gc{width:19px;height:19px;border-radius:4px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;margin-top:1px}
.gate-text{font-size:11px;flex:1;line-height:1.4}
.gate-pts{font-family:'DM Mono','Courier New',monospace;font-size:10px;color:var(--red);flex-shrink:0;margin-top:2px}
.gate-link{font-size:9px;color:var(--gold);margin-top:3px;display:block;cursor:pointer}
.adv-wrap{display:flex;justify-content:center;padding:28px 20px;min-height:calc(100vh - 50px)}
.adv-box{width:100%;max-width:560px;background:var(--surf);border-radius:13px;border:1px solid var(--bd);overflow:hidden;align-self:flex-start}
.adv-top{padding:18px 22px;border-bottom:1px solid var(--bd);background:var(--el)}
.adv-h{font-family:Cormorant,Georgia,serif;font-size:19px;font-weight:400;color:var(--tx);margin-top:10px}
.adv-sub{font-size:10px;color:var(--mut);margin-top:4px;line-height:1.55}
.adv-footer{padding:12px 22px 18px;border-top:1px solid var(--bd);display:flex;gap:9px;justify-content:flex-end}
.sig-health{display:flex;gap:8px;margin-top:12px;padding:12px;background:var(--el);border-radius:8px}
.sih{text-align:center;flex:1}
.sih-n{font-family:'DM Mono','Courier New',monospace;font-size:18px;font-weight:500}
.sih-l{font-size:9px;color:var(--mut);text-transform:uppercase;letter-spacing:.07em;margin-top:3px}
.overlay{position:fixed;inset:0;background:rgba(26,39,54,0.45);z-index:200;display:flex;align-items:center;justify-content:center}
.overlay.hidden{display:none}
.modal{background:var(--surf);border-radius:13px;border:1px solid var(--bd);padding:24px;max-width:500px;width:92%;max-height:85vh;overflow-y:auto}
.modal-h{font-family:Cormorant,Georgia,serif;font-size:18px;font-weight:400;color:var(--tx);margin-bottom:14px}
.mfooter{display:flex;gap:9px;justify-content:flex-end;margin-top:20px;padding-top:16px;border-top:1px solid var(--bd)}
.fp{max-width:660px;margin:0 auto;padding:28px 20px}
.fp-title{font-family:Cormorant,Georgia,serif;font-size:22px;font-weight:400;color:var(--tx);margin-bottom:4px}
.fp-sub{font-size:10px;color:var(--mut);margin-bottom:24px}
.tabs{display:flex;border-bottom:1px solid var(--bd)}
.tab{padding:10px 14px;background:none;border:none;border-bottom:2px solid transparent;font-size:12px;color:var(--mut);font-weight:500}
.tab:hover{color:var(--sec)}
.tab.on{color:var(--tx);border-bottom-color:var(--gold)}
.na-item{display:flex;align-items:flex-start;gap:10px;padding:10px;border-radius:7px;margin-bottom:6px;background:var(--el);border:1px solid var(--bd)}
.na-check{width:18px;height:18px;border-radius:4px;border:1.5px solid var(--bdh);flex-shrink:0;display:flex;align-items:center;justify-content:center;cursor:pointer;margin-top:1px;transition:all 0.14s}
.na-item.done .na-check{background:var(--grn);border-color:var(--grn)}
.na-t{font-size:11px;color:var(--tx);flex:1;line-height:1.45}
.na-item.done .na-t{text-decoration:line-through;color:var(--mut)}
.na-due{font-size:10px;font-family:'DM Mono','Courier New',monospace;margin-top:3px}
.na-notes{font-size:10px;color:var(--sec);margin-top:4px;line-height:1.55;padding:6px 8px;background:#F8F4EC;border-radius:4px;border-left:2px solid #E5DDCC}
.pb-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:6px;border:1px solid var(--bd);background:var(--el);margin-bottom:6px;cursor:pointer;transition:all 0.12s}
.pb-item:hover{border-color:var(--gbd);background:var(--gsub)}
.pb-add{width:20px;height:20px;border-radius:4px;background:var(--gsub);border:1px solid var(--gbd);color:var(--gold);font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pb-text{font-size:11px;color:var(--sec);line-height:1.4}
.align-card{background:var(--el);border-radius:8px;padding:13px;margin-bottom:10px;border:1px solid var(--bd)}
.align-q{font-size:11px;color:var(--sec);font-style:italic;line-height:1.55;margin-bottom:8px}
.align-a{font-size:11px;color:var(--tx);line-height:1.6}
.empty{text-align:center;padding:50px 20px;color:var(--mut)}
.empty-icon{font-size:28px;margin-bottom:10px}
.empty-t{font-size:14px;color:var(--sec);margin-bottom:5px}
.empty-s{font-size:11px;line-height:1.6}
.ev-explainer{background:var(--gsub);border:1px solid var(--gbd);border-radius:8px;padding:12px 14px;margin-bottom:20px}
.ev-explainer p{font-size:11px;color:var(--sec);line-height:1.65}
.ev-explainer strong{color:var(--gold)}
.profile-page{max-width:640px;margin:0 auto;padding:28px 20px}
.step-indicator{display:flex;align-items:center;gap:8px;margin-bottom:28px}
.step-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;transition:all 0.2s}
.step-line{flex:1;height:1px;background:var(--bd)}
.radio-group{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:0}
.radio-opt{padding:8px 14px;border-radius:7px;border:1px solid var(--bd);background:var(--el);color:var(--sec);font-size:12px;cursor:pointer;transition:all 0.14s}
.radio-opt:hover{border-color:var(--bdh);color:var(--tx)}
.radio-opt.sel{background:var(--gsub);border-color:var(--gbd);color:var(--gold)}
.drilldown-panel{padding:16px 18px;flex:1;overflow-y:auto}
.drilldown-sig{padding:10px 12px;border-radius:7px;margin-bottom:7px;background:var(--el);border:1px solid var(--bd)}
.win-card{background:rgba(16,185,129,0.06);border-radius:9px;border:1px solid rgba(16,185,129,0.2);padding:16px;margin-bottom:12px}
.archive-banner{background:rgba(220,38,38,0.09);border:1px solid rgba(239,68,68,0.25);border-radius:10px;padding:12px;margin-bottom:12px}
.future-label{font-size:9px;color:#D97706;border:1px solid rgba(245,158,11,0.25);border-radius:4px;padding:1px 5px;margin-left:6px}
.ready-card{background:rgba(5,150,105,0.09);border:1px solid rgba(16,185,129,0.25);border-radius:8px;padding:10px;margin-bottom:10px}
.dc-line.clickable{cursor:pointer;border-radius:4px;padding:3px 4px}
.dc-line.clickable:hover{background:#F8F4EC}
.help{font-size:10px;color:var(--mut);line-height:1.5;margin-top:7px;margin-bottom:6px}
.affects{display:inline-flex;margin-top:4px;margin-bottom:10px;padding:2px 6px;border-radius:4px;background:rgba(96,165,250,0.08);border:1px solid rgba(96,165,250,0.20);color:#2563EB;font-size:9px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}

.universe-wrap{padding:18px 20px 40px;overflow:auto;height:calc(100vh - 50px)}
.hero{background:linear-gradient(135deg,rgba(196,146,58,0.09),#FFFFFF);border:1px solid var(--gbd);border-radius:14px;padding:20px 22px;margin-bottom:18px;display:flex;justify-content:space-between;gap:20px;align-items:flex-start}
.hero-k{font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.hero-h{font-family:Cormorant,Georgia,serif;font-size:24px;font-weight:400;color:var(--tx);margin-bottom:7px}
.hero-p{font-size:12px;color:var(--sec);line-height:1.65;max-width:720px}
.warn{background:rgba(217,119,6,0.09);border:1px solid rgba(245,158,11,0.26);color:var(--amb);border-radius:8px;padding:10px 12px;font-size:11px;line-height:1.5;margin-bottom:14px}
.u-grid{display:grid;grid-template-columns:1.2fr 70px 125px 1.4fr 140px 110px;gap:10px;padding:6px 10px;margin:0 0 4px;color:var(--mut)}
.u-row{display:grid;grid-template-columns:1.2fr 70px 125px 1.4fr 140px 110px;gap:10px;align-items:center;background:#FFFFFF;border:1px solid var(--bd);border-radius:10px;padding:12px 10px;margin-bottom:8px;cursor:pointer}
.u-row:hover{border-color:var(--bdh);background:#F8F4EC}
.u-small{font-size:10px;color:var(--mut);line-height:1.45;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.u-text{font-size:11px;color:var(--sec);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.summary-card{background:var(--surf);border:1px solid var(--bd);border-radius:12px;padding:16px;margin-bottom:14px}
.summary-title{font-family:Cormorant,Georgia,serif;font-size:18px;font-weight:400;color:var(--tx);margin-bottom:8px}
.summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}
.summary-item{background:var(--el);border:1px solid var(--bd);border-radius:8px;padding:10px 11px}
.summary-l{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--mut);margin-bottom:5px}
.summary-v{font-size:11px;color:var(--sec);line-height:1.55}
.q-row{display:grid;grid-template-columns:1fr 58px;gap:8px;margin-bottom:8px;align-items:start}
.q-row textarea{min-height:52px}
.dc-break{background:var(--el);border:1px solid var(--bd);border-radius:8px;padding:10px 11px;margin-top:10px;width:100%}
.dc-line{display:flex;justify-content:space-between;gap:10px;font-size:10px;margin-bottom:6px;color:var(--sec)}
.dc-line:last-child{margin-bottom:0;padding-top:6px;border-top:1px solid var(--bd);color:var(--tx);font-weight:600}
.na-list{display:flex;flex-direction:column;gap:8px;min-width:0}
.na-item{width:100%;min-width:0}
.na-main{flex:1;min-width:0}
.na-controls{display:flex;gap:5px;flex-shrink:0}
.sig-summary{display:inline-flex;align-items:center;gap:5px;padding:4px 8px;border-radius:5px;font-size:10px;font-weight:600}
.profile-section{background:#F8F4EC;border:1px solid var(--bd);border-radius:10px;padding:14px;margin-bottom:14px}
.profile-section-title{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.hero{overflow:hidden}

.hero-chip{max-width:260px;overflow:hidden;text-overflow:ellipsis}

.u-row > div,.u-grid > span{min-width:0;overflow:hidden}
.u-grid,.u-row{grid-template-columns:minmax(220px,1.4fr) 130px 150px minmax(240px,1.6fr) minmax(200px,1.3fr)}
.co-nm,.co-meta{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;display:block}
.u-text{min-width:0;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;word-break:break-word}

@media(max-width:1100px){.u-grid,.u-row{grid-template-columns:1fr 110px 130px 1fr}.summary-grid{grid-template-columns:1fr}}
.lobby-wrap{padding:28px 24px 50px;max-width:1180px;margin:0 auto}
.lobby-hero{background:linear-gradient(135deg,rgba(196,146,58,0.09),#FFFFFF);border:1px solid var(--gbd);border-radius:16px;padding:26px;margin-bottom:18px}
.lobby-title{font-family:Cormorant,Georgia,serif;font-size:30px;font-weight:400;color:var(--tx);line-height:1.2;margin-bottom:10px}
.lobby-body{font-size:13px;color:var(--sec);line-height:1.75;max-width:820px}
.lobby-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:16px}
.lobby-card{background:var(--surf);border:1px solid var(--bd);border-radius:13px;padding:18px;margin-bottom:14px}
.lobby-card h3{font-family:Cormorant,Georgia,serif;font-size:18px;font-weight:400;color:var(--tx);margin-bottom:8px}
.lobby-k{font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.focus-title{font-size:17px;font-weight:650;color:var(--tx);margin-bottom:6px}
.focus-body{font-size:12px;color:var(--sec);line-height:1.7}
.insight{padding:10px 12px;border-radius:9px;background:var(--el);border:1px solid var(--bd);font-size:11px;color:var(--sec);line-height:1.55;margin-bottom:8px}
.grounding{font-family:Cormorant,Georgia,serif;font-size:19px;color:var(--tx);line-height:1.45}
.prose-section{background:var(--surf);border:1px solid var(--bd);border-radius:12px;padding:18px;margin-bottom:14px}
.prose-section h3{font-family:Cormorant,Georgia,serif;font-size:19px;font-weight:400;color:var(--tx);margin-bottom:8px}
.prose-section p{font-size:12px;color:var(--sec);line-height:1.75}
.motion-def{font-size:10px;color:var(--mut);line-height:1.5;margin-top:6px;padding:8px 10px;background:rgba(255,255,255,.025);border:1px solid var(--bd);border-radius:7px}
.example{font-size:10px;color:#5C6B7E;line-height:1.55;margin-top:7px;padding:8px 10px;background:rgba(196,146,58,0.09);border-left:2px solid rgba(196,146,58,.45);border-radius:6px}
.nudge{font-size:10px;color:#D97706;line-height:1.5;margin-top:7px;padding:8px 10px;background:rgba(217,119,6,0.09);border:1px solid rgba(245,158,11,.24);border-radius:7px}
.step-status{display:inline-flex;align-items:center;padding:3px 8px;border-radius:16px;border:1px solid var(--bd);font-size:10px;color:var(--sec);margin-left:8px}
@media(max-width:900px){.lobby-grid{grid-template-columns:1fr}.lobby-title{font-size:24px}}




/* ── V3.8 LIGHT DESIGN LAYER ───────────────────────────────── */
*,*::before,*::after{box-sizing:border-box}
body{background:var(--bg);color:var(--tx);font-family:'DM Sans',-apple-system,BlinkMacSystemFont,sans-serif;font-size:13px;line-height:1.4}
::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bd);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--bdh)}
button{border:none;background:none}
.app{display:flex;height:100vh;overflow:hidden;background:var(--bg)}
.sidebar{width:220px;flex-shrink:0;background:var(--surf);border-right:1px solid var(--bd);display:flex;flex-direction:column;position:relative;z-index:10}
.sb-logo{display:flex;align-items:center;gap:10px;padding:18px 16px 20px;border-bottom:1px solid var(--bd);height:64px}
.sb-mark{display:flex;align-items:center;justify-content:center;font-family:Cormorant,Georgia,serif;font-size:22px;color:var(--gold);flex-shrink:0;filter:drop-shadow(0 0 10px rgba(196,146,58,0.25));line-height:1}
.sb-name{font-family:Cormorant,Georgia,serif;font-size:16px;letter-spacing:.12em;color:var(--tx);font-weight:400}
.sb-nav{flex:1;padding:12px 8px;overflow-y:auto}.sb-divider{height:1px;background:var(--bd);margin:8px 10px}.sb-section{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--mut);padding:8px 10px 4px}
.sb-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;color:var(--sec);font-size:12px;font-weight:500;margin-bottom:2px;transition:all .12s;text-align:left;width:100%;background:none;border:none;cursor:pointer}.sb-item:hover{background:var(--surf2);color:var(--tx)}.sb-item.on{background:var(--gsub);color:var(--gold)}
.sb-ico{width:16px;height:16px;display:flex;align-items:center;justify-content:center;opacity:.75;font-size:14px}.sb-badge{margin-left:auto;background:var(--bd);color:var(--mut);font-size:10px;font-family:'DM Mono','Courier New',monospace;padding:1px 6px;border-radius:10px;font-weight:600}.sb-item.on .sb-badge{background:rgba(196,146,58,.15);color:var(--gold)}
.sb-footer{padding:12px 16px;border-top:1px solid var(--bd)}.sb-user{display:flex;align-items:center;gap:10px}.sb-av{width:32px;height:32px;border-radius:50%;background:var(--gsub);border:1.5px solid var(--gbd);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--gold)}.sb-un{font-size:12px;color:var(--tx);font-weight:500}.sb-ur{font-size:10px;color:var(--mut)}
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.topbar{height:52px;background:var(--surf);border-bottom:1px solid var(--bd);display:flex;align-items:center;padding:0 24px;gap:8px;flex-shrink:0}.tb-title{font-family:Cormorant,Georgia,serif;font-size:18px;color:var(--tx);font-weight:400}.tb-sub{font-size:11px;color:var(--mut);margin-left:4px;margin-top:2px}.tb-r{margin-left:auto;display:flex;align-items:center;gap:10px}.view-content{flex:1;overflow:auto;min-width:0;background:var(--bg)}
.btn{padding:7px 14px;border-radius:8px;font-size:12px;font-weight:500;transition:all .12s;display:inline-flex;align-items:center;gap:6px;cursor:pointer;border:none;font-family:inherit}.btn-gold{background:var(--gsub);border:1px solid var(--gbd);color:var(--gold)}.btn-gold:hover{background:rgba(196,146,58,.15);border-color:rgba(196,146,58,.4)}.btn-ghost{background:transparent;border:1px solid var(--bd);color:var(--sec)}.btn-ghost:hover{border-color:var(--bdh);color:var(--tx);background:var(--surf2)}.btn-grn{background:var(--gsn);border:1px solid rgba(5,150,105,.3);color:var(--grn)}.btn-red{background:var(--rsn);border:1px solid rgba(220,38,38,.3);color:var(--red)}.btn-sm{padding:5px 10px;font-size:11px}.btn-full{width:100%;justify-content:center}
.pill{border-radius:20px;font-weight:600}.tag{font-size:9px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;border-radius:5px}.card,.lobby-card,.summary-card,.prose-section,.profile-section,.pipe-card,.adv-box{background:var(--surf);border:1px solid var(--bd);border-radius:12px;box-shadow:var(--sh-sm)}
#main,.universe-wrap,.lobby-wrap,.profile-page,.fp,.score-page{background:var(--bg)}
.lobby-wrap{padding:24px;max-width:920px;margin:0 auto}.lobby-hero{background:var(--surf);border-radius:14px;border:1px solid var(--bd);padding:32px 36px;margin-bottom:20px;box-shadow:var(--sh-sm);position:relative;overflow:hidden}.lobby-hero:before{content:'';position:absolute;top:0;right:0;width:300px;height:100%;background:linear-gradient(135deg,transparent 40%,rgba(196,146,58,.04));pointer-events:none}.lobby-title{font-family:Cormorant,Georgia,serif;font-size:28px;font-weight:400;color:var(--tx);line-height:1.3;margin-bottom:8px}.lobby-body{font-size:13px;color:var(--sec);line-height:1.6;max-width:820px}.lobby-k{font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}.lobby-grid{display:grid;grid-template-columns:3fr 2fr;gap:16px}.focus-card,.focus-card-lite{background:linear-gradient(135deg,var(--surf) 0%,rgba(196,146,58,.03) 100%);border:1.5px solid var(--gbd);border-radius:12px;padding:20px;box-shadow:var(--sh-sm)}.focus-title{font-size:14px;font-weight:600;color:var(--tx);margin-bottom:6px}.focus-body{font-size:12px;color:var(--sec);line-height:1.65}.insight{background:var(--surf2);border:1px solid var(--bd);border-radius:9px;color:var(--sec)}.grounding{font-family:Cormorant,Georgia,serif;font-size:15px;color:var(--tx);line-height:1.6}
.universe-wrap{padding:24px;overflow:auto;height:auto;min-height:100%}.hero{background:var(--surf);border:1px solid var(--bd);border-radius:14px;padding:22px 24px;margin-bottom:18px;box-shadow:var(--sh-sm)}.hero-h{font-family:Cormorant,Georgia,serif;font-size:24px;color:var(--tx)}.hero-p{font-size:12px;color:var(--sec);line-height:1.65}.u-grid,.u-row{grid-template-columns:minmax(220px,1.4fr) 130px 150px minmax(240px,1.6fr) minmax(200px,1.3fr)}.u-grid{padding:8px 12px;margin-bottom:6px;color:var(--mut)}.u-row{background:var(--surf);border:1px solid var(--bd);border-radius:12px;box-shadow:var(--sh-sm);padding:14px 12px;margin-bottom:8px}.u-row:hover{background:var(--surf2);border-color:var(--bdh)}.u-row>div,.u-grid>span{min-width:0;overflow:hidden}.co-nm,.co-meta{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;display:block}.u-text{min-width:0;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;word-break:break-word;color:var(--sec)}
.s-bar,.stage-strip{background:transparent;border-bottom:none;overflow-x:auto;flex-wrap:nowrap}.s-btn{border-radius:8px;background:var(--surf);border:1px solid var(--bd);padding:8px 12px;margin:12px 2px;min-width:84px}.s-btn.on{background:var(--gsub);border-color:var(--gbd)}.s-sep{display:none}.pl-hdr{padding:20px 24px 10px}.pl-title{font-family:Cormorant,Georgia,serif;color:var(--tx)}.col-hdr,.row{grid-template-columns:1fr 120px 130px 70px 140px 1fr 44px 14px}.col-hdr{padding:10px 20px;background:var(--surf2);border-top:1px solid var(--bd);border-bottom:1px solid var(--bd)}.row{background:var(--surf);border-bottom:1px solid var(--bd);padding:14px 20px}.row:hover{background:var(--surf2)}.fit-bar{background:var(--bd)}
.cc{height:calc(100vh - 52px);background:var(--bg)}.cc-l,.cc-r{background:var(--surf);border-color:var(--bd)}.cc-m{background:var(--bg)}.sec{border-color:var(--bd);padding:14px 20px}.ev-hdr{border-color:var(--bd);background:var(--surf);padding:16px 20px}.ev-scroll{padding:16px 20px;background:var(--bg)}.tabs{background:var(--surf)!important;border-bottom:1px solid var(--bd)!important;padding:0 20px!important}.tab{color:var(--mut)}.tab.on{color:var(--tx);border-bottom-color:var(--gold)}.ev-entry{padding-left:0;margin-bottom:10px}.ev-line,.ev-dot{display:none}.ev-card,.ev-item{background:var(--surf);border-radius:10px;border:1px solid var(--bd);padding:14px 16px;margin-bottom:10px;box-shadow:var(--sh-sm)}.prob-panel,.sig-counts,.drilldown-panel{border-color:var(--bd);background:var(--surf)}.prob-sum,.dc-break,.sh-card,.na-item,.align-card,.sq,.summary-item{background:var(--surf2);border:1px solid var(--bd);border-radius:8px}.na-item{box-shadow:none}.na-check{border-color:var(--bdh);background:var(--surf)}
.profile-page,.fp,.score-page{max-width:660px;margin:0 auto;padding:24px}.profile-page>div:first-child,.fp-title{font-family:Cormorant,Georgia,serif!important;font-size:32px!important;color:var(--tx)!important;text-align:center}.profile-section{padding:20px;margin-bottom:16px;background:var(--surf);box-shadow:var(--sh-sm)}.profile-section-title,.form-section-title{font-family:Cormorant,Georgia,serif;font-size:18px;color:var(--tx);font-weight:400;letter-spacing:normal;text-transform:none}.fg{margin-bottom:18px}.fl{color:var(--mut);font-weight:700}.fi,.fs,.ft,.snote,.sig-in,.sig-wt{background:var(--surf2);border:1px solid var(--bd);color:var(--tx);border-radius:8px;padding:10px 12px}.fi:focus,.fs:focus,.ft:focus{border-color:var(--gold);background:var(--surf)}.help{color:var(--mut);margin-top:7px;margin-bottom:6px}.affects{background:var(--bsn);border:1px solid rgba(37,99,235,.2);color:var(--blu)}.example{background:var(--surf2);border-left:2px solid var(--bd);color:var(--sec)}.radio-opt{background:var(--surf2);border:1px solid var(--bd);color:var(--sec)}.radio-opt.sel,.radio-opt.on{background:var(--gsub);border-color:var(--gbd);color:var(--gold)}
.summary-card{padding:28px;background:var(--surf)}.summary-title{font-family:Cormorant,Georgia,serif;color:var(--tx);font-size:20px}.summary-v{color:var(--sec)}.summary-item{background:var(--surf);border-top:0;border-left:0;border-right:0;border-radius:0;padding:16px 0}.summary-item:first-of-type .summary-v{font-family:Cormorant,Georgia,serif;font-size:16px;color:var(--tx);line-height:1.55}.prose-section p{color:var(--sec)}
.overlay{background:rgba(26,39,54,.45);backdrop-filter:blur(2px)}.modal{background:var(--surf);border-radius:14px;border:1px solid var(--bd);box-shadow:0 8px 40px rgba(0,0,0,.12);color:var(--tx)}.modal-h{font-family:Cormorant,Georgia,serif;color:var(--tx)}.mfooter{border-top:1px solid var(--bd)}
.warn{background:var(--asn);border-color:rgba(217,119,6,.26);color:var(--amb)}.archive-banner{background:var(--rsn);border-color:rgba(220,38,38,.25)}.ready-card{background:var(--gsn);border-color:rgba(5,150,105,.25)}.empty{color:var(--mut)}.empty-t{color:var(--sec)}
@media(max-width:1100px){.u-grid,.u-row{grid-template-columns:1fr 110px 130px 1fr}.cc{grid-template-columns:240px 1fr}.cc-r{display:none}.lobby-grid{grid-template-columns:1fr}.sidebar{width:200px}}



/* ── V3.8.1 DESIGN QA CORRECTIONS ───────────────────────────── */
.lobby-process-table{display:flex;flex-direction:column;gap:8px;width:100%;overflow:hidden}
.lobby-process-head,.lobby-process-row{display:grid;grid-template-columns:minmax(180px,1.4fr) 110px 130px 100px minmax(180px,1.3fr);gap:14px;align-items:center;min-width:0}
.lobby-process-head{padding:0 4px 6px;border-bottom:1px solid var(--bd)}
.lobby-process-head span{font-size:9px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--mut)}
.lobby-process-row{background:var(--surf);border:1px solid var(--bd);border-radius:10px;padding:12px 14px;box-shadow:var(--sh-sm);cursor:pointer;transition:background .12s,border-color .12s}
.lobby-process-row:hover{background:var(--surf2);border-color:var(--bdh)}
.lobby-process-company{min-width:0;overflow:hidden}.lobby-process-company .name{font-size:13px;font-weight:600;color:var(--tx);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lobby-process-company .meta{font-size:10px;color:var(--mut);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lobby-process-action{font-size:12px;color:var(--sec);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-width:0}
.outcome-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:12px}.outcome-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.outcome-item{background:var(--surf);border:1px solid var(--bd);border-radius:8px;padding:14px 16px;min-height:86px;box-shadow:var(--sh-sm)}.outcome-l{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--mut);margin-bottom:8px}.outcome-v{font-family:'DM Sans',-apple-system,BlinkMacSystemFont,sans-serif;font-size:12px;color:var(--sec);line-height:1.65;word-break:normal;overflow-wrap:anywhere}.outcome-v.metric{font-family:'DM Mono','Courier New',monospace;font-size:16px;font-weight:700;color:var(--tx)}
.mandate-wrap{max-width:660px;margin:0 auto;width:100%;padding:24px}.mandate-hero{text-align:center;padding:32px 20px 28px;margin-bottom:24px}.mandate-heading{font-family:Cormorant,Georgia,serif;font-size:32px;font-weight:400;color:var(--tx);margin-bottom:8px}.mandate-sub{font-size:13px;color:var(--sec);line-height:1.6;max-width:520px;margin:0 auto 12px}.mandate-time{font-size:11px;color:var(--mut)}
.step-row{display:flex;align-items:center;gap:0;margin-bottom:28px}.step-item{display:flex;align-items:center;gap:8px;min-width:0}.step-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}.step-label{font-size:11px;font-weight:500;white-space:nowrap}.step-line{flex:1;height:1px;background:var(--bd);margin:0 8px}.form-card{background:var(--surf);border-radius:12px;border:1px solid var(--bd);padding:24px;box-shadow:var(--sh-sm);margin-bottom:16px}.form-footer{display:flex;gap:10px;justify-content:flex-end}.form-section-title{font-family:Cormorant,Georgia,serif;font-size:18px;color:var(--tx);margin-bottom:4px}.form-section-sub{font-size:11px;color:var(--mut);margin-bottom:20px}
.mandate-summary-wrap{max-width:720px;margin:0 auto;padding:24px}.mandate-summary-note{font-size:12px;color:var(--sec);line-height:1.65;margin-bottom:16px}.summary-headline{font-family:Cormorant,Georgia,serif;font-size:16px;color:var(--tx);line-height:1.55;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--bd)}.summary-section{padding:16px 0;border-bottom:1px solid var(--bd)}.summary-section:last-child{border-bottom:none}.summary-sl{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--mut);display:block;margin-bottom:6px}.summary-body{font-size:12px;color:var(--sec);line-height:1.7}.summary-edit-row{text-align:right;margin-top:12px}
@media(max-width:900px){.lobby-process-head,.lobby-process-row{grid-template-columns:minmax(160px,1fr) 95px 90px 85px}.lobby-process-head span:nth-child(5),.lobby-process-row .lobby-process-action{display:none}.outcome-grid,.outcome-grid.two{grid-template-columns:1fr}.mandate-wrap,.mandate-summary-wrap{padding:18px}.step-label{display:none}}


/* ── V3.8.2 WIN CARD REDESIGN ─────────────────────────────── */
.win-card2{background:var(--surf);border-radius:12px;border:1px solid var(--bd);padding:22px 24px;margin-bottom:16px;box-shadow:var(--sh-sm)}
.win-card2.win-accepted2{border-top:3px solid var(--grn)}
.win2-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px;padding-bottom:18px;border-bottom:1px solid var(--bd)}
.win2-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--bd)}
.win2-stat{background:var(--surf2);border-radius:8px;padding:12px 14px}
.win2-sl{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--mut);margin-bottom:6px;display:block}
.win2-sv{font-family:'DM Mono','Courier New',monospace;font-size:16px;font-weight:700;color:var(--tx)}
.win2-section{margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--bd)}
.win2-section:last-of-type{border-bottom:none}
.win2-body{font-size:12px;color:var(--sec);line-height:1.65}

/* ── V3.8.3 LOBBY PROCESS TABLE ───────────────────────── */
.lp-table{display:flex;flex-direction:column;gap:0}
.lp-row{display:grid;grid-template-columns:1fr 120px 80px 90px;gap:16px;align-items:center;padding:12px 4px;border-bottom:1px solid var(--bd);cursor:pointer;transition:background .1s;border-radius:6px}
.lp-row:last-child{border-bottom:none}
.lp-row:hover{background:var(--surf2)}
.lp-name{font-size:13px;font-weight:600;color:var(--tx);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}

/* ── Northcall loading state ── */
.nc-btn-loading { opacity:0.6; pointer-events:none; }
@keyframes nc-spark-pulse { 0%,100% { opacity:0.5; transform:scale(0.85); } 50% { opacity:1; transform:scale(1.15); } }
.nc-spark { display:inline-block; animation: nc-spark-pulse 1.4s ease-in-out infinite; color: var(--nc) !important; }
.nc-spark-lg { display:inline-block; font-size:36px; line-height:1; color: var(--nc); animation: nc-spark-pulse 1.4s ease-in-out infinite; font-family:Cormorant,Georgia,serif; }
@keyframes nc-pulse-dot-global { 0%,100% { opacity:0.4; transform:scale(0.8); } 50% { opacity:1; transform:scale(1.1); } }
.nc-pulse-dot { width:14px; height:14px; border-radius:50%; background:#6B7AE0; animation: nc-pulse-dot-global 1.4s ease-in-out infinite; display:inline-block; }
@keyframes nc-dot { 0%,100%{opacity:1} 50%{opacity:0.2} }
.nc-thinking { display:inline-flex; align-items:center; gap:3px; }
.nc-thinking::after { content:'...'; animation:nc-dot 1.2s ease-in-out infinite; }

/* ── Northcall Design Pass ────────────────────────────── */

/* ✦ symbol always gold */
.nc-star { color: var(--gold); }

/* Lobby hero — subtle warm gradient */
.lobby-hero {
  background: linear-gradient(135deg, #FFFFFF 60%, rgba(196,146,58,0.04) 100%);
  border: 1px solid var(--bd);
  border-left: 3px solid var(--gold);
}

/* Lobby cards — subtle depth */
.lobby-card {
  background: var(--surf);
  border: 1px solid var(--bd);
  border-radius: 12px;
  padding: 18px 20px;
  box-shadow: 0 1px 4px rgba(0,0,0,0.04);
  transition: box-shadow 0.15s;
}
.lobby-card:hover { box-shadow: 0 2px 8px rgba(0,0,0,0.08); }

/* Northcall tab — distinctive */
.tab.on[onclick*="northcall"] {
  color: var(--gold);
  border-bottom-color: var(--gold);
}

/* Evidence entries — tighter, more readable */
.ev-entry {
  border-left: 2px solid var(--bd);
  transition: border-color 0.15s;
}
.ev-entry:hover { border-left-color: var(--gold); }

/* Active search stage indicators — colour coded */
.stage-dot { width:8px; height:8px; border-radius:50%; display:inline-block; }

/* Sidebar name styling */
.sb-un { font-weight: 600; color: var(--tx); }

/* Evidence header — clean separation */
.ev-hdr {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  border-bottom: 1px solid var(--bd);
  background: var(--surf);
}

/* Northcall thinking badge — animated dots */
@keyframes nc-dots {
  0%, 20% { opacity: 0.2; }
  40% { opacity: 1; }
  100% { opacity: 0.2; }
}
.nc-dots {
  animation: nc-dots 1.4s ease-in-out infinite;
  display: inline-block;
}

/* Score buttons — better feedback */
.score-btn {
  transition: all 0.12s;
  border: 1.5px solid var(--bd);
}
.score-btn:hover { border-color: var(--gold); }
.score-btn.active {
  border-color: var(--grn);
  background: var(--gsn);
  color: var(--grn);
}

/* Process table rows — cleaner hover */
.lp-row {
  transition: background 0.1s;
}
.lp-row:hover { background: var(--surf2); }

/* Target Universe — sticky header */
.u-head {
  position: sticky;
  top: 0;
  background: var(--bg);
  z-index: 10;
  padding-top: 4px;
}


/* Lobby warmth */
.lobby-hero { background: linear-gradient(135deg, #FFFFFF 0%, #FDFAF4 100%); border: 1px solid var(--gbd); }
.lobby-card { transition: box-shadow 0.15s ease; }
.lobby-card:hover { box-shadow: 0 4px 16px rgba(196,146,58,0.08); }
.lobby-title { background: linear-gradient(135deg, var(--tx) 60%, var(--gold)); -webkit-background-clip: text; background-clip: text; }

.nc-mark{color:var(--nc);font-weight:500}.nc-mark-bg{background:rgba(79,91,213,0.08);color:var(--nc);padding:2px 7px;border-radius:5px;font-weight:500;font-size:0.95em}

/* Mandate Summary — editorial portrait */
.portrait-wrap{max-width:680px;margin:0 auto;padding:48px 24px 32px}
.portrait-kicker{font-size:10px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:24px;text-align:center}
.portrait-title{font-family:Cormorant,Georgia,serif;font-size:38px;font-weight:300;line-height:1.15;color:var(--tx);text-align:center;margin-bottom:14px;letter-spacing:-0.01em}
.portrait-sub{font-family:Cormorant,Georgia,serif;font-style:italic;font-size:16px;color:var(--mut);text-align:center;margin-bottom:56px;font-weight:300;letter-spacing:0.01em}
.portrait-section{margin-bottom:44px}
.portrait-section-label{font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--bd);position:relative}
.portrait-section-label:after{content:'';position:absolute;bottom:-1px;left:0;width:32px;height:1px;background:var(--gold)}
.portrait-section-body{font-family:DM Sans,sans-serif;font-size:14px;line-height:1.85;color:var(--tx);font-weight:400;letter-spacing:0.005em}
.portrait-lead{font-family:Cormorant,Georgia,serif;font-size:18px;line-height:1.65;color:var(--tx);font-weight:400;letter-spacing:-0.003em}
.portrait-footer{display:flex;justify-content:space-between;align-items:center;margin-top:64px;padding-top:28px;border-top:1px solid var(--bd)}
.portrait-empty{padding:40px 32px;background:var(--surf2);border-radius:14px;border:1px solid var(--bd);text-align:center;margin-bottom:32px}
.portrait-empty-body{font-family:Cormorant,Georgia,serif;font-style:italic;font-size:15px;color:var(--sec);line-height:1.7;max-width:480px;margin:0 auto}
@media (max-width:700px){.portrait-wrap{padding:32px 18px 24px}.portrait-title{font-size:30px}.portrait-section{margin-bottom:32px}}

/* My Mandate — ritual */
.ritual-wrap{max-width:680px;margin:0 auto;padding:32px 24px 48px;min-height:calc(100vh - 48px);display:flex;flex-direction:column}
.ritual-progress{margin-bottom:48px}
.ritual-progress-bar{height:2px;background:var(--bd);border-radius:1px;overflow:hidden;margin-bottom:10px}
.ritual-progress-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-h));transition:width 0.5s cubic-bezier(0.16,1,0.3,1)}
.ritual-progress-meta{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--mut);font-weight:600;text-align:center}
.ritual-intro{padding:40px 0 32px;text-align:center;flex:1;display:flex;flex-direction:column;justify-content:center;animation:ritual-fade-in 0.5s cubic-bezier(0.16,1,0.3,1)}
.ritual-chapter-num{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:20px}
.ritual-chapter-title{font-family:Cormorant,Georgia,serif;font-size:54px;font-weight:300;color:var(--tx);line-height:1.1;margin-bottom:20px;letter-spacing:-0.015em}
.ritual-chapter-sub{font-family:Cormorant,Georgia,serif;font-style:italic;font-size:20px;color:var(--mut);margin-bottom:36px;font-weight:300;line-height:1.4}
.ritual-chapter-body{font-family:DM Sans,sans-serif;font-size:14px;color:var(--sec);line-height:1.8;max-width:520px;margin:0 auto 48px;letter-spacing:0.005em}
.ritual-intro-footer{display:flex;justify-content:space-between;align-items:center;padding-top:32px;border-top:1px solid var(--bd);max-width:520px;margin:0 auto;width:100%}
.ritual-question{padding:20px 0;flex:1;display:flex;flex-direction:column;animation:ritual-fade-in 0.5s cubic-bezier(0.16,1,0.3,1)}
.ritual-q-chapter{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:18px}
.ritual-q-text{font-family:Cormorant,Georgia,serif;font-size:30px;font-weight:400;line-height:1.25;color:var(--tx);margin-bottom:20px;letter-spacing:-0.005em}
.ritual-q-help{font-family:DM Sans,sans-serif;font-size:13px;color:var(--sec);line-height:1.75;margin-bottom:22px;letter-spacing:0.005em}
.ritual-q-example{background:var(--surf2);border-left:2px solid var(--bd);padding:14px 18px;margin-bottom:28px;font-family:Cormorant,Georgia,serif;font-style:italic;font-size:14px;color:var(--mut);line-height:1.6;border-radius:0 6px 6px 0}
.ritual-q-example-label{display:block;font-family:DM Sans,sans-serif;font-style:normal;font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--mut);font-weight:600;margin-bottom:6px}
.ritual-input-wrap{margin-bottom:36px}
.ritual-textarea, .ritual-input, .ritual-select{width:100%;background:var(--surf);border:1px solid var(--bd);color:var(--tx);border-radius:10px;padding:16px 18px;font-family:DM Sans,sans-serif;font-size:14px;line-height:1.65;letter-spacing:0.005em;transition:border-color 0.2s, background 0.2s}
.ritual-textarea{resize:vertical;min-height:120px}
.ritual-textarea:focus, .ritual-input:focus, .ritual-select:focus{outline:none;border-color:var(--gold);background:#FFFFFF}
.ritual-motion-def{margin-top:12px;padding:12px 14px;background:rgba(196,146,58,0.06);border-left:2px solid var(--gold);border-radius:0 6px 6px 0;font-size:12px;color:var(--sec);line-height:1.6}
.ritual-question-footer{margin-top:auto;display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid var(--bd)}
.ritual-next{padding:11px 20px;font-size:13px}
@keyframes ritual-fade-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@media(max-width:700px){.ritual-wrap{padding:24px 18px 36px}.ritual-chapter-title{font-size:38px}.ritual-q-text{font-size:24px}.ritual-intro-footer{flex-direction:column;gap:10px}.ritual-question-footer{flex-wrap:wrap;gap:10px}}

/* Add Company — value preview */
.add-preview{margin:36px auto 0;max-width:560px;background:var(--surf2);border:1px solid var(--bd);border-radius:14px;padding:24px 26px}
.add-preview-label{font-size:9px;font-weight:600;letter-spacing:.18em;color:var(--gold);margin-bottom:18px;text-align:center}
.add-preview-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px 24px}
.add-preview-group{}
.add-preview-cat{font-family:Cormorant,Georgia,serif;font-size:14px;color:var(--tx);margin-bottom:4px;font-weight:500}
.add-preview-fields{font-size:11px;color:var(--sec);line-height:1.65}
.add-preview-foot{font-family:Cormorant,Georgia,serif;font-style:italic;font-size:13px;color:var(--mut);text-align:center;margin-top:20px;padding-top:16px;border-top:1px solid var(--bd);line-height:1.55}
@media(max-width:560px){.add-preview-grid{grid-template-columns:1fr}}

/* Sidebar footer redesign */
.sb-footer-clickable{cursor:pointer;transition:background 0.15s;position:relative}
.sb-footer-clickable:hover{background:var(--surf2)}
.sb-footer-clickable.on{background:var(--gsub)}
.sb-ur-anchor{font-size:10px;color:var(--mut);letter-spacing:0.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px;font-weight:500}
.sb-chevron{font-size:10px;color:var(--mut);margin-left:4px;transition:transform 0.2s;flex-shrink:0}
.sb-footer-clickable[data-open="true"] .sb-chevron{transform:rotate(180deg)}
.sb-incomplete-dot{color:var(--gold);font-size:11px;margin-left:4px;opacity:0.7}
.sb-menu{position:absolute;bottom:calc(100% + 4px);left:8px;right:8px;background:var(--surf);border:1px solid var(--bd);border-radius:10px;box-shadow:0 -8px 24px rgba(0,0,0,0.08),0 -2px 6px rgba(0,0,0,0.04);padding:6px;z-index:100;animation:sb-menu-in 0.18s cubic-bezier(0.16,1,0.3,1)}
@keyframes sb-menu-in{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
.sb-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 11px;border-radius:7px;background:none;border:none;cursor:pointer;font-size:12px;color:var(--sec);font-weight:500;text-align:left;transition:all 0.12s}
.sb-menu-item:hover{background:var(--surf2);color:var(--tx)}
.sb-menu-ico{width:16px;display:flex;align-items:center;justify-content:center;opacity:0.7;font-size:13px;flex-shrink:0}
.sb-menu-count{margin-left:auto;background:var(--bd);color:var(--mut);font-size:10px;font-family:'DM Mono',monospace;padding:1px 6px;border-radius:10px;font-weight:600}
.sb-menu-tag{margin-left:auto;font-size:9px;color:var(--gold);letter-spacing:0.06em;text-transform:uppercase;font-weight:700;background:var(--gsub);padding:2px 6px;border-radius:8px}

/* My Mandate — AI assistant shortcut */
.ritual-shortcut-option{margin-top:48px;max-width:520px;margin-left:auto;margin-right:auto}
.ritual-shortcut-divider{display:flex;align-items:center;gap:14px;color:var(--mut);font-size:10px;letter-spacing:.16em;text-transform:uppercase;font-weight:600;margin-bottom:18px}
.ritual-shortcut-btn{display:flex;align-items:center;gap:14px;width:100%;padding:18px 22px;background:rgba(107,122,224,0.05);border:1px solid var(--ncbd);border-radius:12px;cursor:pointer;transition:all 0.18s;text-align:left}
.ritual-shortcut-btn:hover{background:rgba(107,122,224,0.10);border-color:var(--nc);transform:translateY(-1px);box-shadow:0 4px 16px rgba(107,122,224,0.10)}
.ritual-shortcut-page{padding:20px 0;animation:ritual-fade-in 0.5s cubic-bezier(0.16,1,0.3,1)}
.ritual-shortcut-steps{margin:48px 0 36px}
.ritual-shortcut-step{display:flex;gap:18px;margin-bottom:32px;align-items:flex-start}
.ritual-shortcut-step-num{flex-shrink:0;width:34px;height:34px;border-radius:50%;background:var(--gsub);border:1px solid var(--gbd);color:var(--gold);display:flex;align-items:center;justify-content:center;font-family:'DM Mono',monospace;font-size:14px;font-weight:600}
.ritual-shortcut-step-body{flex:1;min-width:0}
.ritual-shortcut-step-title{font-family:Cormorant,Georgia,serif;font-size:20px;color:var(--tx);margin-bottom:6px;font-weight:500}
.ritual-shortcut-step-desc{font-size:13px;color:var(--sec);line-height:1.6;margin-bottom:14px}
.ritual-shortcut-prompt-wrap{position:relative;background:var(--surf2);border:1px solid var(--bd);border-radius:10px;padding:18px 18px 14px}
.ritual-shortcut-prompt{font-family:'DM Mono',monospace;font-size:11.5px;color:var(--sec);line-height:1.65;white-space:pre-wrap;word-break:break-word;margin:0 0 12px;max-height:200px;overflow:auto}
.ritual-shortcut-copy{margin-top:4px}
@media(max-width:700px){.ritual-shortcut-step{flex-direction:column;gap:12px}.ritual-shortcut-step-num{width:28px;height:28px;font-size:12px}}

/* Mandate Summary → Fit Setup transition */
.summary-transition{max-width:680px;margin:48px auto 32px;padding:36px 32px;background:linear-gradient(135deg,var(--surf) 0%,rgba(196,146,58,0.03) 100%);border:1px solid var(--gbd);border-radius:14px;text-align:center;box-shadow:var(--sh-sm)}
.summary-transition-kicker{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:14px}
.summary-transition-title{font-family:Cormorant,Georgia,serif;font-size:26px;color:var(--tx);margin-bottom:12px;font-weight:400;letter-spacing:-0.005em;line-height:1.25}
.summary-transition-body{font-size:13px;color:var(--sec);line-height:1.7;max-width:480px;margin:0 auto 24px}
.summary-transition-btn{padding:12px 26px;font-size:13px}

/* Fit Setup as its own page */
.fit-setup-wrap{max-width:760px;margin:0 auto;padding:40px 24px 32px}
.fit-setup-intro{margin-bottom:36px}
.fit-setup-kicker{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:14px}
.fit-setup-title{font-family:Cormorant,Georgia,serif;font-size:34px;color:var(--tx);margin-bottom:14px;font-weight:400;letter-spacing:-0.01em;line-height:1.2}
.fit-setup-sub{font-family:Cormorant,Georgia,serif;font-style:italic;font-size:16px;color:var(--mut);margin-bottom:18px;line-height:1.5;font-weight:300}
.fit-setup-body{font-size:13px;color:var(--sec);line-height:1.75;max-width:620px}
.fit-setup-footer{display:flex;justify-content:space-between;align-items:center;margin-top:36px;padding-top:24px;border-top:1px solid var(--bd)}

/* Fit framework — locked questions */
.q-row-locked{display:flex;align-items:center;gap:14px;padding:12px 14px;background:var(--surf2);border:1px solid var(--bd);border-radius:8px;margin-bottom:8px;opacity:0.85}
.q-row-text{flex:1;font-size:12px;color:var(--sec);line-height:1.55}
.q-row-lock{font-size:10px;color:var(--mut);font-weight:600;letter-spacing:0.04em;flex-shrink:0;padding:4px 8px;background:var(--bd);border-radius:6px}
.info-banner{background:rgba(107,122,224,0.06);border:1px solid var(--ncbd);border-left:3px solid var(--nc);padding:12px 16px;border-radius:9px;font-size:12px;color:var(--sec);line-height:1.6}
.info-banner strong{color:var(--nc);font-weight:500}

.ritual-input-short{min-height:auto;resize:none}

/* Northcall AI action buttons — blue accent so they read as AI-driven */
.btn-nc{background:#FFFFFF;color:#6B7AE0;border:1px solid #6B7AE0;font-weight:500}
.btn-nc:hover{background:rgba(107,122,224,0.06);border-color:#5563d4;color:#5563d4}
.btn-nc:disabled{opacity:0.55;cursor:not-allowed}
.btn-nc-ghost{background:rgba(107,122,224,0.06);color:#6B7AE0;border:1px solid #6B7AE0;font-weight:500}
.btn-nc-ghost:hover{background:rgba(107,122,224,0.12);border-color:#5563d4;color:#5563d4}
/* ── Login screen (Phase 2: auth) ───────────────────────────── */
.login-wrap{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg);padding:24px}
.login-card{background:var(--surf);border:1px solid var(--bd);border-radius:18px;padding:48px 44px;max-width:420px;width:100%;text-align:center;box-shadow:0 12px 40px rgba(0,0,0,0.06),0 2px 8px rgba(0,0,0,0.03)}
.login-mark{font-family:Cormorant,Georgia,serif;font-size:40px;color:var(--gold);line-height:1;margin-bottom:14px}
.login-title{font-family:Cormorant,Georgia,serif;font-size:32px;font-weight:400;color:var(--tx);letter-spacing:-0.01em;margin-bottom:8px}
.login-sub{font-family:Cormorant,Georgia,serif;font-style:italic;font-size:15px;color:var(--mut);margin-bottom:36px;font-weight:300}
.login-input{width:100%;background:var(--surf2);border:1px solid var(--bd);color:var(--tx);border-radius:10px;padding:13px 16px;font-family:DM Sans,sans-serif;font-size:14px;text-align:center;transition:border-color 0.2s,background 0.2s;margin-bottom:12px}
.login-input:focus{outline:none;border-color:var(--gold);background:#FFFFFF}
.login-btn{width:100%;padding:13px 20px;font-size:13px}
.login-help{font-size:11px;color:var(--mut);line-height:1.6;margin-top:14px}
.login-sent-mark{font-family:Cormorant,Georgia,serif;font-size:32px;color:var(--nc);margin-bottom:14px}
.login-sent-title{font-family:Cormorant,Georgia,serif;font-size:24px;color:var(--tx);margin-bottom:10px;font-weight:400}
.login-sent-body{font-size:13px;color:var(--sec);line-height:1.7}
.login-sent-body strong{color:var(--tx);font-weight:500}
.login-foot{font-size:11px;color:var(--mut);margin-top:24px;letter-spacing:0.01em}

/* ── Sidebar menu: divider + sign out ───────────────────────── */
.sb-menu-divider{height:1px;background:var(--bd);margin:6px 4px}
.sb-menu-signout{color:var(--mut)}
.sb-menu-signout:hover{color:#DC2626;background:rgba(220,38,38,0.06)}

/* ── Google sign-in button + divider (Phase: Google OAuth) ──── */
.login-google{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;background:#FFFFFF;border:1px solid var(--bd);color:#3C4043;border-radius:10px;padding:12px 16px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:border-color 0.2s,box-shadow 0.2s,background 0.2s}
.login-google:hover{border-color:#C9BFA8;box-shadow:0 2px 8px rgba(0,0,0,0.05);background:#FDFCF9}
.login-google:active{background:#F5F1E8}
.login-google-icon{width:17px;height:17px;flex-shrink:0}
.login-or{display:flex;align-items:center;text-align:center;margin:18px 0;color:var(--mut);font-size:11px;letter-spacing:0.04em}
.login-or::before,.login-or::after{content:'';flex:1;height:1px;background:var(--bd)}
.login-or span{padding:0 14px;text-transform:uppercase}
