*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#F2F0EB;--sf:#FFFFFF;--s2:#F7F6F2;--s3:#EFEDE8;
  --bd:#E2DDD7;--bd2:#CCC6BE;--bd3:#AEA79E;
  --tx:#16130D;--t2:#524D47;--t3:#938D87;--t4:#C8C2BA;
  --gd:#B45309;--gd2:#D97706;--gdBg:#FEF3C7;--gdBd:#FDE68A;
  --gn:#065F46;--gnBg:#ECFDF5;--gnBd:#A7F3D0;
  --rd:#991B1B;--rdBg:#FEF2F2;--rdBd:#FECACA;
  --bl:#1E3A8A;--blBg:#EFF6FF;--blBd:#BFDBFE;
  --pu:#4C1D95;--puBg:#F5F3FF;--puBd:#DDD6FE;
  --sh:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --sh2:0 4px 20px rgba(0,0,0,.1);
  --sh3:0 8px 32px rgba(0,0,0,.12);
}
html,body{height:100%;overflow:hidden;font-family:'DM Sans',sans-serif;color:var(--tx);font-size:13px;line-height:1.5;background:var(--bg)}
.app{display:flex;height:100vh}

/* ── SIDEBAR ── */
.sb{width:220px;flex-shrink:0;background:var(--tx);display:flex;flex-direction:column}
.sb-logo{padding:13px 12px 10px;border-bottom:1px solid rgba(255,255,255,.07)}
.sb-row{display:flex;align-items:center;gap:8px;margin-bottom:9px}
.sb-hex{width:27px;height:27px;background:var(--gd2);border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sb-hex svg{width:14px;height:14px;fill:#fff}
.sb-brand{font-family:'DM Sans',sans-serif;font-size:14px;font-weight:800;color:#fff;letter-spacing:-.01em}
.sb-ver{font-size:9px;color:rgba(255,255,255,.28);font-family:'IBM Plex Mono',monospace;margin-top:1px;letter-spacing:.03em}

/* Tenant switcher */
.ts-wrap{position:relative}
.ts-btn{width:100%;display:flex;align-items:center;justify-content:space-between;padding:6px 9px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:5px;cursor:pointer;transition:all .1s;user-select:none}
.ts-btn:hover{background:rgba(255,255,255,.09)}
.ts-left{display:flex;flex-direction:column}
.ts-state{font-family:'DM Sans',sans-serif;font-size:11px;font-weight:700;color:#fff;line-height:1}
.ts-label{font-size:9px;color:rgba(255,255,255,.35);font-family:'IBM Plex Mono',monospace;letter-spacing:.03em;margin-top:2px}
.ts-right{display:flex;align-items:center;gap:5px}
.ts-live{display:flex;align-items:center;gap:3px;font-size:9px;color:#4ade80;font-family:'IBM Plex Mono',monospace}
.lv{width:5px;height:5px;border-radius:50%;background:#4ade80;animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.ts-chev{width:10px;height:10px;stroke:rgba(255,255,255,.35);fill:none;stroke-width:2;stroke-linecap:round;transition:transform .15s}
.ts-dd{position:absolute;top:calc(100% + 5px);left:0;right:0;background:var(--tx);border:1px solid rgba(255,255,255,.12);border-radius:6px;box-shadow:var(--sh3);z-index:99;display:none}
.ts-dd.open{display:block}
.ts-item{padding:8px 11px;cursor:pointer;transition:background .1s;font-size:11.5px;color:rgba(255,255,255,.6);display:flex;align-items:center;justify-content:space-between}
.ts-item:hover{background:rgba(255,255,255,.06)}.ts-item.on{color:#fff;font-weight:500}
.ts-item:first-child{border-radius:6px 6px 0 0}.ts-item:last-child{border-radius:0 0 6px 6px}
.ts-item .check{font-size:10px;color:var(--gd2)}

.nav{flex:1;overflow-y:auto;padding:5px;scrollbar-width:none}
.nav::-webkit-scrollbar{display:none}
.nsg{font-size:9px;color:rgba(255,255,255,.2);font-family:'IBM Plex Mono',monospace;letter-spacing:.1em;text-transform:uppercase;padding:9px 7px 3px}
.ni{display:flex;align-items:center;gap:7px;padding:6px 8px;border-radius:5px;cursor:pointer;color:rgba(255,255,255,.4);font-size:11.5px;transition:all .1s;margin-bottom:1px}
.ni:hover{background:rgba(255,255,255,.05);color:rgba(255,255,255,.75)}
.ni.on{background:rgba(180,83,9,.2);color:var(--gd2);font-weight:500}
.ni svg{width:12px;height:12px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.nbg{margin-left:auto;padding:1px 6px;border-radius:6px;font-size:9px;font-family:'IBM Plex Mono',monospace;background:rgba(255,255,255,.07);color:rgba(255,255,255,.3)}
.nbg.h{background:rgba(180,83,9,.25);color:var(--gd2)}.nbg.u{background:rgba(153,27,27,.25);color:#fca5a5}
.sb-user{padding:9px 10px;border-top:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:7px}
.av{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:#fff;flex-shrink:0}

/* ── MAIN ── */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.bar{height:48px;border-bottom:1px solid var(--bd);display:flex;align-items:center;padding:0 18px;gap:10px;flex-shrink:0;background:var(--sf);box-shadow:var(--sh)}
.bar-bc{font-size:10px;color:var(--t3);font-family:'IBM Plex Mono',monospace}
.bar-t{font-family:'DM Sans',sans-serif;font-size:14px;font-weight:700}
.bar-acts{margin-left:auto;display:flex;align-items:center;gap:7px}
.vs{display:flex;background:var(--s2);border:1px solid var(--bd);border-radius:6px;padding:3px;gap:1px}
.vsb{padding:4px 12px;border-radius:4px;font-size:11.5px;cursor:pointer;color:var(--t3);border:none;background:none;font-family:'DM Sans',sans-serif;transition:all .1s;white-space:nowrap}
.vsb.on{background:var(--sf);color:var(--tx);font-weight:500;box-shadow:var(--sh)}

/* ── BUTTONS ── */
.btn{padding:6px 13px;border-radius:5px;font-size:12px;font-weight:500;cursor:pointer;border:none;font-family:'DM Sans',sans-serif;transition:all .13s;white-space:nowrap;display:inline-flex;align-items:center;gap:5px}
.btn svg{width:11px;height:11px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.btn-p{background:var(--gd);color:#fff}.btn-p:hover{background:var(--gd2)}
.btn-g{background:var(--sf);color:var(--t2);border:1px solid var(--bd)}.btn-g:hover{color:var(--tx);border-color:var(--bd3)}
.btn-sm{padding:4px 10px;font-size:11px;border-radius:4px}
.btn-xs{padding:3px 8px;font-size:10.5px;border-radius:3px}
.btn-danger{background:var(--rdBg);color:var(--rd);border:1px solid var(--rdBd)}
.btn-warn{background:var(--gdBg);color:var(--gd);border:1px solid var(--gdBd)}
.btn-ok{background:var(--gnBg);color:var(--gn);border:1px solid var(--gnBd)}

/* ── VIEWS ── */
.ct{flex:1;overflow:hidden;display:flex;flex-direction:column}
.vw{display:none;flex:1;overflow:hidden;flex-direction:column}
.vw.on{display:flex;animation:fu .15s ease}
@keyframes fu{from{opacity:0;transform:translateY(3px)}to{opacity:1;transform:none}}

/* ── SHARED ATOMS ── */
.pill{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:3px;font-size:9.5px;font-weight:500;font-family:'IBM Plex Mono',monospace;white-space:nowrap}
.pd{width:4px;height:4px;border-radius:50%;background:currentColor;flex-shrink:0}
.p-recv{background:var(--blBg);color:var(--bl)}.p-idc{background:var(--puBg);color:var(--pu)}
.p-plan{background:var(--gdBg);color:var(--gd)}.p-rev{background:#FFF7ED;color:#C2410C}
.p-sur{background:#F0FDF4;color:#15803D}.p-gis{background:#F0FDFA;color:#0F766E}
.p-gov{background:#FDF4FF;color:#7E22CE}.p-deed{background:var(--blBg);color:var(--bl)}
.p-rofo{background:#FFF1F2;color:#BE123C}.p-cofo{background:var(--gnBg);color:var(--gn)}
.p-done{background:var(--gnBg);color:var(--gn)}.p-rej{background:var(--rdBg);color:var(--rd)}
.p-cav{background:var(--rdBg);color:var(--rd);border:1px solid var(--rdBd)}
.p-act{background:#FFF1F2;color:#BE123C;border:1px solid #FECACA}
.p-wd{background:var(--s2);color:var(--t3);border:1px solid var(--bd)}

.tag{padding:2px 7px;border-radius:3px;font-size:10px;font-family:'IBM Plex Mono',monospace}
.t-priv{background:var(--blBg);color:var(--bl)}.t-org{background:var(--puBg);color:var(--pu)}

.card{background:var(--sf);border:1px solid var(--bd);border-radius:8px;overflow:hidden;box-shadow:var(--sh)}
.ch{padding:9px 14px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;background:var(--s2)}
.ch-t{font-size:9.5px;font-family:'IBM Plex Mono',monospace;color:var(--t2);text-transform:uppercase;letter-spacing:.05em;font-weight:500}

.notice{padding:9px 11px;border-radius:6px;display:flex;gap:8px;align-items:flex-start;margin-bottom:11px;font-size:12px}
.notice svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;flex-shrink:0;margin-top:1px}
.n-info{background:var(--blBg);border:1px solid var(--blBd);color:var(--bl)}
.n-warn{background:var(--gdBg);border:1px solid var(--gdBd);color:var(--gd)}
.n-ok{background:var(--gnBg);border:1px solid var(--gnBd);color:var(--gn)}
.n-red{background:var(--rdBg);border:1px solid var(--rdBd);color:var(--rd)}

/* ── QUEUE ── */
.qb{flex:1;overflow-y:auto;padding:16px;scrollbar-width:thin;scrollbar-color:var(--bd2) transparent}
.sr{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-bottom:16px}
.sc{background:var(--sf);border:1px solid var(--bd);border-radius:8px;padding:12px 14px;cursor:pointer;box-shadow:var(--sh);transition:all .12s;position:relative;overflow:hidden}
.sc::before{content:'';position:absolute;top:0;left:0;right:0;height:2px}
.sc.ca::before{background:var(--gd)}.sc.cg::before{background:var(--gn)}.sc.cr::before{background:var(--rd)}.sc.cp::before{background:var(--pu)}.sc.cb::before{background:var(--bl)}
.sc:hover{box-shadow:var(--sh2);transform:translateY(-1px)}
.sc-l{font-size:9px;color:var(--t3);font-family:'IBM Plex Mono',monospace;text-transform:uppercase;letter-spacing:.05em;margin-bottom:5px}
.sc-v{font-family:'DM Sans',sans-serif;font-size:24px;font-weight:700;line-height:1}
.sc-s{font-size:10px;color:var(--t3);margin-top:3px}
.sc-s.up{color:var(--gn)}.sc-s.wa{color:var(--gd)}.sc-s.da{color:var(--rd)}
.pipe{display:flex;border:1px solid var(--bd);border-radius:8px;overflow:hidden;background:var(--sf);box-shadow:var(--sh);margin-bottom:14px}
.pc{flex:1;min-width:68px;padding:8px 10px;border-right:1px solid var(--bd);cursor:pointer;transition:background .1s}
.pc:last-child{border-right:none}.pc:hover{background:var(--s2)}.pc.on{background:var(--gdBg);border-bottom:2px solid var(--gd)}
.pcn{font-family:'DM Sans',sans-serif;font-size:17px;font-weight:700;color:var(--t2);line-height:1;margin-bottom:1px}
.pc.on .pcn{color:var(--gd)}.pcl{font-size:9px;color:var(--t3)}
.tw{background:var(--sf);border:1px solid var(--bd);border-radius:8px;overflow:hidden;box-shadow:var(--sh)}
.tb2{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--bd)}
.tbt{font-family:'DM Sans',sans-serif;font-size:12.5px;font-weight:600}
.srch{display:flex;align-items:center;gap:5px;padding:5px 9px;background:var(--s2);border:1px solid var(--bd);border-radius:5px;flex:1;max-width:240px}
.srch svg{width:11px;height:11px;stroke:var(--t3);fill:none;stroke-width:1.5;stroke-linecap:round;flex-shrink:0}
.srch input{background:none;border:none;outline:none;font-size:11.5px;color:var(--tx);font-family:'DM Sans',sans-serif;width:100%}
.srch input::placeholder{color:var(--t3)}
.fsl{padding:5px 9px;background:var(--s2);border:1px solid var(--bd);border-radius:5px;font-size:11px;color:var(--t2);font-family:'DM Sans',sans-serif;cursor:pointer;outline:none}
table{width:100%;border-collapse:collapse}
thead th{padding:7px 13px;text-align:left;font-size:9px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--bd);font-weight:400;white-space:nowrap;background:var(--s2)}
tbody tr{border-bottom:1px solid var(--bd);cursor:pointer;transition:background .08s}
tbody tr:hover{background:var(--s2)}
tbody tr:last-child td{border-bottom:none}
td{padding:8px 13px;color:var(--t2);white-space:nowrap;vertical-align:middle}
.tref{font-family:'IBM Plex Mono',monospace;font-size:10.5px;color:var(--gd);font-weight:500}
.tfile{font-family:'IBM Plex Mono',monospace;font-size:11px;font-weight:700;color:var(--gd)}
.tname{color:var(--t2);font-size:12px}
.ta{padding:3px 8px;background:var(--sf);border:1px solid var(--bd);border-radius:4px;font-size:11px;color:var(--t3);cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .1s}
.ta:hover{color:var(--tx);border-color:var(--bd3)}
.fl{width:6px;height:6px;border-radius:50%;display:inline-block}
.fl-h{background:var(--rd)}.fl-m{background:var(--gd)}.fl-l{background:var(--t4)}
.dw2{color:var(--gd);font-weight:500}.dk{color:var(--t3)}

/* ── APPLICATION DETAIL ── */
.det{flex:1;display:grid;grid-template-columns:1fr 300px;overflow:hidden}
.dl{overflow-y:auto;background:var(--bg);scrollbar-width:thin;scrollbar-color:var(--bd2) transparent}
.dr{border-left:1px solid var(--bd);overflow-y:auto;background:var(--sf);scrollbar-width:thin;scrollbar-color:var(--bd2) transparent}

.ah{background:var(--sf);border-bottom:1px solid var(--bd);padding:13px 17px;position:sticky;top:0;z-index:20;box-shadow:var(--sh)}
.ah-top{display:flex;align-items:flex-start;gap:10px;margin-bottom:9px}
.ah-ids{font-family:'IBM Plex Mono',monospace;font-size:9.5px;color:var(--t3);margin-bottom:4px;display:flex;align-items:center;gap:8px}
.ah-sep{color:var(--t4)}
.ah-fn{font-family:'IBM Plex Mono',monospace;font-size:13px;font-weight:700;color:var(--gd);line-height:1;margin-bottom:3px}
.ah-name{font-family:'DM Sans',sans-serif;font-size:15px;font-weight:700;color:var(--tx);margin-bottom:2px}
.ah-sub{font-size:11.5px;color:var(--t3)}
.ah-right{flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.ah-acts{display:flex;align-items:center;gap:6px}

.fbanner{display:none;margin:8px 17px 0;padding:8px 11px;background:var(--gdBg);border:1px solid var(--gdBd);border-radius:6px;align-items:flex-start;gap:8px}
.fbanner.on{display:flex;animation:fu .2s ease}
.fb-i svg{width:13px;height:13px;stroke:var(--gd);fill:none;stroke-width:1.5;stroke-linecap:round}
.fb-t{flex:1;font-size:12px;color:var(--t2)}.fb-t strong{color:var(--gd)}
.fb-r{font-size:11px;color:var(--gd);cursor:pointer;text-decoration:underline;white-space:nowrap}

.dtabs{display:flex;padding:0 17px;background:var(--sf);border-bottom:1px solid var(--bd)}
.dtt{padding:8px 12px;font-size:12px;cursor:pointer;color:var(--t3);border-bottom:2px solid transparent;transition:all .1s;white-space:nowrap}
.dtt:hover{color:var(--t2)}.dtt.on{color:var(--tx);font-weight:500;border-bottom-color:var(--gd)}
.dtb{display:none;padding:16px}.dtb.on{display:block}

.is{background:var(--sf);border:1px solid var(--bd);border-radius:7px;margin-bottom:11px;overflow:hidden;box-shadow:var(--sh)}
.ish{padding:9px 14px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;background:var(--s2)}
.ish-t{font-size:9.5px;font-family:'IBM Plex Mono',monospace;color:var(--t2);text-transform:uppercase;letter-spacing:.05em;font-weight:500}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:0;padding:12px 14px}
.fi2{padding:7px 0;border-bottom:1px solid var(--bd);display:flex;flex-direction:column;gap:1px}
.fi2:nth-child(odd){padding-right:18px;border-right:1px solid var(--bd)}
.fi2:nth-child(even){padding-left:18px}
.fi2:nth-last-child(-n+2){border-bottom:none}
.fl2{font-size:9px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.04em}
.fv{font-size:12.5px;color:var(--tx);font-weight:500}
.fv.mo{font-family:'IBM Plex Mono',monospace;font-size:11.5px}.fv.ok{color:var(--gn)}.fv.wa{color:var(--gd)}.fv.dm{color:var(--t3)}

/* Instruments pending in application */
.inst-pend{background:var(--s2);border:1px solid var(--bd);border-radius:6px;padding:10px 13px;margin-bottom:11px;display:flex;align-items:flex-start;gap:10px}
.inst-pend-ico{width:28px;height:28px;border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.inst-pend-ico svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round}

/* Documents */
.doc-row{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--bd);transition:background .1s}
.doc-row.clickable{cursor:pointer}.doc-row.clickable:hover{background:var(--s2)}
.doc-row:last-child{border-bottom:none}
.di{width:30px;height:36px;border-radius:4px;border:1px solid var(--bd);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--s2)}
.di svg{width:13px;height:13px;stroke:var(--t3);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.di.g{background:var(--gnBg)}.di.g svg{stroke:var(--gn)}.di.o{background:var(--gdBg)}.di.o svg{stroke:var(--gd)}.di.r{background:var(--rdBg)}.di.r svg{stroke:var(--rd)}
.dn{font-size:12.5px;font-weight:500;color:var(--tx)}.dm2{font-size:10.5px;color:var(--t3)}
.dbg{padding:2px 7px;border-radius:3px;font-size:9.5px;font-weight:500;font-family:'IBM Plex Mono',monospace;white-space:nowrap}
.db-ok{background:var(--gnBg);color:var(--gn);border:1px solid var(--gnBd)}
.db-nr{background:var(--gdBg);color:var(--gd);border:1px solid var(--gdBd)}
.db-miss{background:var(--rdBg);color:var(--rd);border:1px solid var(--rdBd)}
.db-pend{background:var(--s2);color:var(--t3);border:1px solid var(--bd)}

/* Bills */
.br{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--bd)}
.br:last-child{border-bottom:none}
.br-n{font-size:12.5px;font-weight:500;color:var(--tx)}.br-d{font-size:10.5px;color:var(--t3);margin-top:1px}
.br-a{font-size:12.5px;font-weight:600;font-family:'IBM Plex Mono',monospace}
.br-s{padding:2px 7px;border-radius:3px;font-size:9.5px;font-family:'IBM Plex Mono',monospace}
.bs-p{background:var(--gnBg);color:var(--gn)}.bs-n{background:var(--s2);color:var(--t3);border:1px solid var(--bd)}.bs-d{background:var(--gdBg);color:var(--gd)}

/* RIGHT: Progress */
.rph{padding:11px 14px 9px;border-bottom:1px solid var(--bd);position:sticky;top:0;background:var(--sf);z-index:10}
.rph-l{font-size:9px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px}
.rph-s{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:700}
.si{display:flex;gap:0;padding:0 12px}
.si-lc{display:flex;flex-direction:column;align-items:center;width:20px;flex-shrink:0;padding-top:10px}
.si-dot{width:11px;height:11px;border-radius:50%;border:2px solid var(--bd);background:var(--sf);flex-shrink:0;z-index:1;display:flex;align-items:center;justify-content:center}
.si-dot svg{display:none;width:6px;height:6px}
.si-dot.cur{border-color:var(--gd);background:var(--gdBg);box-shadow:0 0 0 3px rgba(217,119,6,.1)}
.si-dot.done{border-color:var(--gn);background:var(--gnBg)}.si-dot.done svg{display:block}
.si-dot.nxt{border-color:var(--bd2);background:var(--s2)}
.si-vl{width:1px;flex:1;background:var(--bd);margin-top:1px;min-height:6px}
.si-vl.done-l{background:var(--gn);opacity:.3}
.si-body{flex:1;padding:6px 9px 10px;border-radius:6px;margin-bottom:1px;transition:all .12s}
.si.cur .si-body{background:var(--gdBg);border:1px solid var(--gdBd)}
.si-n{font-size:12px;color:var(--t3);font-weight:400;line-height:1.3;margin-bottom:1px}
.si.cur .si-n{color:var(--gd);font-weight:600}.si.done .si-n{color:var(--t2)}
.si-m{font-size:10px;color:var(--t3)}
.si-needs{margin-top:6px;display:flex;flex-direction:column;gap:3px}
.si-need{display:flex;align-items:flex-start;gap:6px;font-size:11.5px;color:var(--t2)}
.nd{width:13px;height:13px;border-radius:50%;border:1.5px solid var(--bd2);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.nd svg{width:7px;height:7px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round}
.nd.pend{border-color:var(--gd);background:var(--gdBg);color:var(--gd)}
.si-actbtn{width:100%;margin-top:9px;padding:8px;border-radius:5px;background:var(--gd);color:#fff;font-weight:600;font-size:12px;cursor:pointer;border:none;font-family:'DM Sans',sans-serif;transition:all .13s}
.si-actbtn:hover{background:var(--gd2)}.si-actbtn:disabled{opacity:.5;cursor:default}
.si.done .si-body{cursor:pointer}.si.done .si-body:hover{background:var(--s2)}
.si-exp{display:none;margin-top:7px;background:var(--sf);border:1px solid var(--bd);border-radius:5px;overflow:hidden}
.si-exp.open{display:block}
.si-er{display:flex;justify-content:space-between;padding:5px 9px;border-bottom:1px solid var(--bd);font-size:11px}
.si-er:last-child{border-bottom:none}
.si-ek{color:var(--t3)}.si-ev{color:var(--tx);font-weight:500;text-align:right;max-width:160px;word-break:break-word}
.si-en{padding:7px 9px;font-size:11px;color:var(--t2);font-style:italic;border-top:1px solid var(--bd);background:var(--s2)}
.pdt{padding:8px 14px;display:flex;align-items:center;gap:7px;cursor:pointer;border-top:1px solid var(--bd);border-bottom:1px solid var(--bd);background:var(--s2);transition:background .1s;user-select:none}
.pdt:hover{background:var(--s3)}.pdt-l{flex:1;height:1px;background:var(--bd)}
.pdt-lbl{font-size:10px;font-family:'IBM Plex Mono',monospace;color:var(--t3);white-space:nowrap}
.pdt-chev{width:10px;height:10px;stroke:var(--t3);fill:none;stroke-width:2;stroke-linecap:round;transition:transform .2s}
.si-more{text-align:center;padding:7px;font-size:10.5px;color:var(--t4)}
.prog-done.collapsed{display:none}

/* MORE MENU */
.mmw{position:relative}
.mmb{padding:5px 9px;background:var(--sf);border:1px solid var(--bd);border-radius:4px;cursor:pointer;font-size:12px;color:var(--t3);line-height:1;transition:all .1s;display:flex;align-items:center;gap:4px}
.mmb svg{width:11px;height:11px;stroke:currentColor;fill:none;stroke-width:1.5}
.mmb:hover{color:var(--tx);border-color:var(--bd3)}
.mmd{position:absolute;top:calc(100% + 4px);right:0;background:var(--sf);border:1px solid var(--bd);border-radius:7px;box-shadow:var(--sh2);min-width:200px;z-index:50;display:none}
.mmd.open{display:block}
.mmi{padding:8px 13px;font-size:12.5px;cursor:pointer;color:var(--t2);transition:background .1s;display:flex;align-items:center;gap:8px}
.mmi:hover{background:var(--s2)}
.mmi:first-child{border-radius:7px 7px 0 0}.mmi:last-child{border-radius:0 0 7px 7px}
.mmi svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;color:var(--t3);flex-shrink:0}
.mmi.da{color:var(--rd)}.mmi.da:hover{background:var(--rdBg)}.mmi.wa{color:var(--gd)}.mmi.wa:hover{background:var(--gdBg)}
.mm-sep{height:1px;background:var(--bd);margin:2px 0}

/* ── FILE LIST ── */
.fv-shell{flex:1;display:grid;grid-template-columns:256px 1fr;overflow:hidden}
.fl-list{border-right:1px solid var(--bd);overflow-y:auto;background:var(--sf);scrollbar-width:thin;scrollbar-color:var(--bd2) transparent}
.fl-head{padding:10px 12px;border-bottom:1px solid var(--bd);position:sticky;top:0;background:var(--sf);z-index:5}
.fl-t{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:700;margin-bottom:6px}
.fli{padding:11px 13px;border-bottom:1px solid var(--bd);cursor:pointer;transition:background .1s;position:relative}
.fli:hover{background:var(--s2)}.fli.on{background:var(--gdBg);border-left:2px solid var(--gd)}
.fli-cav{position:absolute;top:10px;right:11px;width:7px;height:7px;border-radius:50%;background:var(--rd);border:2px solid var(--sf)}
.fli-fn{font-family:'IBM Plex Mono',monospace;font-size:11.5px;font-weight:700;color:var(--gd);line-height:1.2}
.fli-n{font-family:'DM Sans',sans-serif;font-size:12.5px;font-weight:600;color:var(--tx);margin-top:2px;margin-bottom:1px}
.fli-m{font-size:10.5px;color:var(--t3)}

/* ── FILE DETAIL ── */
.fd{overflow-y:auto;background:var(--bg);scrollbar-width:thin;scrollbar-color:var(--bd2) transparent;position:relative}
.fdh{background:var(--sf);border-bottom:1px solid var(--bd);padding:14px 17px}
.fd-cav{display:none;background:var(--rdBg);border:1px solid var(--rdBd);border-radius:5px;padding:8px 11px;margin-bottom:10px;align-items:flex-start;gap:8px;font-size:12px;color:var(--rd)}
.fd-cav.on{display:flex}.fd-cav svg{width:13px;height:13px;stroke:var(--rd);fill:none;stroke-width:1.5;flex-shrink:0;margin-top:1px}
.fdh-fn{font-family:'IBM Plex Mono',monospace;font-size:15px;font-weight:700;color:var(--gd);line-height:1.2;margin-bottom:4px}
.fdh-owner-row{display:flex;align-items:center;gap:8px;margin-bottom:2px}
.fdh-n{font-family:'DM Sans',sans-serif;font-size:15px;font-weight:700;color:var(--tx)}
.curr-badge{padding:1px 7px;background:var(--gnBg);color:var(--gn);border:1px solid var(--gnBd);border-radius:3px;font-size:9px;font-family:'IBM Plex Mono',monospace;font-weight:500}
.fdh-m{font-size:12px;color:var(--t3);margin-bottom:11px}
.fdh-acts{display:flex;gap:6px;flex-wrap:wrap}

.fd-tabs{display:flex;background:var(--sf);border-bottom:1px solid var(--bd);padding:0 17px;position:sticky;top:0;z-index:5}
.fdt{padding:8px 12px;font-size:12px;cursor:pointer;color:var(--t3);border-bottom:2px solid transparent;transition:all .1s;white-space:nowrap}
.fdt:hover{color:var(--t2)}.fdt.on{color:var(--tx);font-weight:500;border-bottom-color:var(--gd)}
.fdtb{display:none;padding:16px}.fdtb.on{display:block}

/* Instruments */
.instr{display:flex;align-items:flex-start;justify-content:space-between;padding:13px 14px;border-bottom:1px solid var(--bd);gap:10px}
.instr:last-child{border-bottom:none}
.instr-ico{width:34px;height:40px;border-radius:4px;border:1px solid var(--bd);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--s2)}
.instr-ico svg{width:16px;height:16px;stroke:var(--t3);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.instr-info{flex:1;min-width:0}
.instr-type{font-family:'DM Sans',sans-serif;font-size:12.5px;font-weight:700;color:var(--tx);margin-bottom:3px;display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.instr-no{font-family:'IBM Plex Mono',monospace;font-size:10.5px;color:var(--gd);font-weight:500;margin-bottom:2px}
.instr-d{font-size:11px;color:var(--t3)}
.instr-acts{display:flex;gap:5px;flex-wrap:wrap;margin-top:8px}
.ih-item{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--t2);padding:4px 0;border-bottom:1px solid var(--bd)}
.ih-item:last-child{border-bottom:none}.ih-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

/* Ownership chain */
.ow-item{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;border-bottom:1px solid var(--bd);cursor:pointer;transition:background .1s}
.ow-item:hover{background:var(--s2)}.ow-item:last-child{border-bottom:none}
.ow-lc{display:flex;flex-direction:column;align-items:center;width:18px;padding-top:4px}
.ow-dot{width:10px;height:10px;border-radius:50%;border:2px solid var(--bd2);background:var(--s2);flex-shrink:0}
.ow-dot.orig{border-color:var(--bl);background:var(--blBg)}
.ow-dot.curr{border-color:var(--gn);background:var(--gnBg)}
.ow-vl{width:1px;flex:1;background:var(--bd);margin-top:2px;min-height:14px}
.ow-body{flex:1}
.ow-role{font-size:9.5px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}
.ow-name{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:700;color:var(--tx);display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.ow-meta{font-size:11px;color:var(--t3);margin-top:1px}
.ow-expand{display:none;margin-top:8px;background:var(--sf);border:1px solid var(--bd);border-radius:5px;padding:9px 12px}
.ow-expand.open{display:block}
.ow-fgrid{display:grid;grid-template-columns:1fr 1fr;gap:6px 18px}
.ow-frow{display:flex;flex-direction:column;gap:1px;padding:4px 0;border-bottom:1px solid var(--bd)}
.ow-frow:nth-last-child(-n+2){border-bottom:none}
.ow-fl{font-size:9px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.03em}
.ow-fv{font-size:12px;color:var(--tx);font-weight:500}

/* Map / Plot section */
.plot-map{background:var(--s2);border:1px solid var(--bd);border-radius:7px;overflow:hidden;margin-bottom:11px}
.pm-head{padding:9px 14px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;background:var(--s2)}
.pm-t{font-size:9.5px;font-family:'IBM Plex Mono',monospace;color:var(--t2);text-transform:uppercase;letter-spacing:.05em;font-weight:500}
.pm-canvas{background:#E8F4E8;height:200px;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}
.pm-svg{width:100%;height:100%}
.beacon{fill:var(--gd);stroke:#fff;stroke-width:1.5;cursor:pointer}
.beacon-lbl{font-family:'IBM Plex Mono',monospace;font-size:9px;fill:var(--t2)}
.pm-data{display:grid;grid-template-columns:1fr 1fr 1fr;gap:0;border-top:1px solid var(--bd)}
.pm-d{padding:8px 12px;border-right:1px solid var(--bd);display:flex;flex-direction:column;gap:1px}
.pm-d:last-child{border-right:none}
.pm-dl{font-size:9px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.04em}
.pm-dv{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:700;color:var(--tx);word-break:break-all}

/* Apps on file */
.aof{display:flex;align-items:flex-start;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--bd);cursor:pointer;transition:background .1s;gap:10px}
.aof:hover{background:var(--s2)}.aof:last-child{border-bottom:none}
.aof-ref{font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--gd);margin-bottom:2px;font-weight:500}
.aof-type{font-family:'DM Sans',sans-serif;font-size:12.5px;font-weight:700;color:var(--tx);margin-bottom:1px}
.aof-m{font-size:11px;color:var(--t3)}
.note-item{padding:11px 14px;border-bottom:1px solid var(--bd)}.note-item:last-child{border-bottom:none}
.ni-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:3px}
.ni-by{font-family:'DM Sans',sans-serif;font-size:12px;font-weight:700}.ni-date{font-size:10px;font-family:'IBM Plex Mono',monospace;color:var(--t3)}
.ni-txt{font-size:12.5px;color:var(--t2);line-height:1.55}
.ni-cav{display:inline-flex;align-items:center;gap:3px;background:var(--rdBg);color:var(--rd);padding:1px 7px;border-radius:3px;font-size:10px;font-family:'IBM Plex Mono',monospace;margin-top:5px}

/* INSTRUMENT SIDE PANEL (right-side overlay within file detail) */
.ip-overlay{position:absolute;inset:0;background:rgba(0,0,0,.15);z-index:30;display:none}
.ip-overlay.open{display:block}
.ip{position:absolute;top:0;right:0;bottom:0;width:420px;background:var(--sf);box-shadow:-4px 0 24px rgba(0,0,0,.12);z-index:31;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .22s cubic-bezier(.4,0,.2,1)}
.ip.open{transform:none}
.ip-h{padding:13px 16px;border-bottom:1px solid var(--bd);display:flex;align-items:flex-start;justify-content:space-between;flex-shrink:0;background:var(--s2)}
.ip-title{font-family:'DM Sans',sans-serif;font-size:14px;font-weight:700}
.ip-sub{font-size:11px;color:var(--t3);margin-top:2px}
.ip-x{width:28px;height:28px;border-radius:5px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--t3);border:1px solid var(--bd);background:var(--sf);flex-shrink:0;transition:all .1s}
.ip-x:hover{color:var(--tx)}.ip-x svg{width:11px;height:11px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round}
.ip-tabs{display:flex;padding:0 16px;border-bottom:1px solid var(--bd)}
.ipt{padding:8px 11px;font-size:12px;cursor:pointer;color:var(--t3);border-bottom:2px solid transparent;transition:all .1s;white-space:nowrap}
.ipt:hover{color:var(--t2)}.ipt.on{color:var(--tx);font-weight:500;border-bottom-color:var(--gd)}
.iptb{display:none;padding:15px;flex:1;overflow-y:auto}.iptb.on{display:block}
.ip-acts{padding:12px 16px;border-top:1px solid var(--bd);background:var(--s2);display:flex;gap:6px;flex-wrap:wrap}

/* DRAWERS */
.do{position:fixed;inset:0;background:rgba(0,0,0,.2);z-index:99;opacity:0;pointer-events:none;transition:opacity .2s}
.do.open{opacity:1;pointer-events:all}
.dw{position:fixed;top:0;right:0;height:100%;width:70%;max-width:820px;background:var(--sf);box-shadow:-4px 0 28px rgba(0,0,0,.1);z-index:100;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .22s cubic-bezier(.4,0,.2,1)}
.dw.open{transform:none}
.dw.sm{max-width:460px}.dw.md{max-width:600px}.dw.lg{max-width:900px}
.dwh{padding:13px 18px;border-bottom:1px solid var(--bd);display:flex;align-items:flex-start;justify-content:space-between;flex-shrink:0;background:var(--s2)}
.dw-title{font-family:'DM Sans',sans-serif;font-size:14px;font-weight:700}
.dw-sub{font-size:11px;color:var(--t3);margin-top:2px}
.dw-x{width:28px;height:28px;border-radius:5px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--t3);border:1px solid var(--bd);background:var(--sf);flex-shrink:0;margin-left:12px;transition:all .1s}
.dw-x:hover{color:var(--tx)}.dw-x svg{width:11px;height:11px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round}
.dwb{flex:1;overflow-y:auto;padding:18px;scrollbar-width:thin;scrollbar-color:var(--bd2) transparent}
.dwf{padding:12px 18px;border-top:1px solid var(--bd);display:flex;justify-content:flex-end;gap:7px;flex-shrink:0;background:var(--s2)}

/* FORM */
.fr{display:grid;gap:11px;margin-bottom:13px}
.fr.c2{grid-template-columns:1fr 1fr}.fr.c3{grid-template-columns:1fr 1fr 1fr}
.fgw{display:flex;flex-direction:column;gap:4px}
.flb{font-size:10px;font-family:'IBM Plex Mono',monospace;color:var(--t2);text-transform:uppercase;letter-spacing:.04em;font-weight:500}
.flb.req::after{content:' *';color:var(--rd)}
.fii{padding:7px 10px;background:var(--sf);border:1px solid var(--bd2);border-radius:5px;font-size:12.5px;color:var(--tx);font-family:'DM Sans',sans-serif;outline:none;width:100%;transition:border-color .1s}
.fii:focus{border-color:var(--gd)}
.fsi{padding:7px 10px;background:var(--sf);border:1px solid var(--bd2);border-radius:5px;font-size:12.5px;color:var(--tx);font-family:'DM Sans',sans-serif;outline:none;cursor:pointer;width:100%}
.fsi:focus{border-color:var(--gd)}
.fta{padding:8px 10px;background:var(--sf);border:1px solid var(--bd2);border-radius:5px;font-size:12px;color:var(--tx);font-family:'DM Sans',sans-serif;outline:none;resize:vertical;min-height:70px;width:100%}
.fta:focus{border-color:var(--gd)}
.fro{padding:7px 10px;background:var(--s2);border:1px solid var(--bd);border-radius:5px;font-size:12px;color:var(--t2);font-family:'IBM Plex Mono',monospace}
.fcalc{padding:7px 10px;background:var(--gdBg);border:1px solid var(--gdBd);border-radius:5px;font-size:12.5px;font-weight:600;color:var(--gd);font-family:'IBM Plex Mono',monospace}
.fst{font-size:10px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px;padding-bottom:7px;border-bottom:1px solid var(--bd)}
.fdiv{height:1px;background:var(--bd);margin:13px 0}

/* doc review */
.dv-box{background:var(--s2);border:1px solid var(--bd);border-radius:7px;height:200px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:7px;color:var(--t3);margin-bottom:11px}
.dv-box svg{width:32px;height:32px;stroke:var(--t3);fill:none;stroke-width:1;stroke-linecap:round;stroke-linejoin:round}
.rev-dec{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:11px}
.rd2{padding:10px;border-radius:6px;border:2px solid var(--bd);cursor:pointer;text-align:center;transition:all .13s;background:var(--sf)}
.rd2:hover{background:var(--s2)}.rd2.sel-ap{background:var(--gnBg);border-color:var(--gn);color:var(--gn)}.rd2.sel-rj{background:var(--rdBg);border-color:var(--rd);color:var(--rd)}
.rd-l{font-size:12.5px;font-weight:600;margin-bottom:1px}.rd-s{font-size:10.5px;color:var(--t3)}

/* ROFO preview */
.rp{background:var(--s2);border:2px solid var(--bd2);border-radius:7px;padding:15px;margin-bottom:12px}
.rp-head{text-align:center;margin-bottom:12px;padding-bottom:12px;border-bottom:2px solid var(--bd)}
.rp-sn{font-family:'DM Sans',sans-serif;font-size:12.5px;font-weight:700;margin-bottom:1px}
.rp-min{font-size:11px;color:var(--t2)}.rp-tt{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:700;color:var(--gd);text-transform:uppercase;letter-spacing:.07em;margin-top:6px}
.rp-b p{font-size:12px;color:var(--tx);line-height:1.7;margin-bottom:7px}
.ph{background:var(--gdBg);padding:0 3px;border-radius:2px;font-family:'IBM Plex Mono',monospace;font-size:10.5px;color:var(--gd)}

/* consent list */
.cli{display:flex;align-items:center;gap:10px;padding:9px 13px;border-bottom:1px solid var(--bd);cursor:pointer;transition:background .1s}
.cli:hover{background:var(--s2)}.cli:last-child{border-bottom:none}
.cli-chk{width:15px;height:15px;border:2px solid var(--bd2);border-radius:3px;flex-shrink:0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .1s;font-size:9px;font-weight:700;color:#fff}
.cli-chk.on{background:var(--gd);border-color:var(--gd)}

/* identity doc checklist */
.idc-row{display:flex;align-items:center;gap:11px;padding:10px 14px;border-bottom:1px solid var(--bd);transition:background .1s;cursor:pointer}
.idc-row:hover{background:var(--s2)}.idc-row:last-child{border-bottom:none}
.idc-chk{width:16px;height:16px;border:2px solid var(--bd2);border-radius:4px;flex-shrink:0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .12s}
.idc-chk.ok{background:var(--gn);border-color:var(--gn);color:#fff}.idc-chk.ok::after{content:'✓';font-size:10px;font-weight:700}
.idc-chk.pend{border-color:var(--gd);background:var(--gdBg)}

/* CONFIG */
.cfg{flex:1;overflow-y:auto;padding:16px}
.cfg-g{display:grid;grid-template-columns:220px 1fr 200px;gap:10px;height:calc(100vh - 145px)}
.cfg-list{background:var(--sf);border:1px solid var(--bd);border-radius:8px;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--sh)}
.cgl-h{padding:9px 12px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;background:var(--s2)}
.cgi{display:flex;align-items:flex-start;gap:7px;padding:8px 11px;border-bottom:1px solid var(--bd);cursor:pointer;transition:background .1s;border-left:2px solid transparent}
.cgi:hover{background:var(--s2)}.cgi.on{background:var(--gdBg);border-left-color:var(--gd)}.cgi:last-child{border-bottom:none}
.cg-num{width:18px;height:18px;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:600;font-family:'IBM Plex Mono',monospace;flex-shrink:0;margin-top:1px}
.canvas{background:var(--sf);border:1px solid var(--bd);border-radius:8px;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--sh)}
.cv-h{padding:10px 14px;border-bottom:1px solid var(--bd);display:flex;align-items:center;gap:8px;background:var(--s2)}
.cv-body{flex:1;overflow-y:auto;padding:14px}
.insp{background:var(--sf);border:1px solid var(--bd);border-radius:8px;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--sh)}
.insp-h{padding:9px 12px;border-bottom:1px solid var(--bd);font-size:9px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.06em;background:var(--s2)}
.insp-b{flex:1;overflow-y:auto;padding:12px}
.ikv{display:flex;justify-content:space-between;padding:4px 0;border-bottom:1px solid var(--bd)}
.ikv:last-child{border-bottom:none}
.ik{font-size:10.5px;color:var(--t3)}.iv{font-size:10.5px;color:var(--tx);font-family:'IBM Plex Mono',monospace}
.iv.wa{color:var(--gd)}.iv.da{color:var(--rd)}
.tgw{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:3px;font-size:10px;font-family:'IBM Plex Mono',monospace;cursor:pointer;margin:2px}
.tgw.en{background:var(--gnBg);color:var(--gn);border:1px solid var(--gnBd)}
.tgw.gu{background:var(--gdBg);color:var(--gd);border:1px solid var(--gdBd)}
.tgw-add{display:inline-flex;align-items:center;gap:2px;padding:2px 7px;border-radius:3px;font-size:10px;color:var(--t3);border:1px dashed var(--bd2);cursor:pointer;font-family:'IBM Plex Mono',monospace;margin:2px}
.tgw-add:hover{color:var(--t2);border-color:var(--bd3)}

/* DEED VIEW */
.deed-body{flex:1;overflow-y:auto;padding:16px}

::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bd2);border-radius:2px}

/* ── APPLICATION SLIDE-OVER (persistent body-level overlay) ── */
.app-so{position:fixed;top:0;left:220px;right:0;bottom:0;background:var(--sf);z-index:50;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .22s cubic-bezier(.4,0,.2,1);box-shadow:-6px 0 40px rgba(0,0,0,.14)}
.app-so.open{transform:translateX(0)}
.aso-h{padding:11px 16px;border-bottom:1px solid var(--bd);display:flex;align-items:center;gap:10px;flex-shrink:0;background:var(--s2)}
.aso-back{display:flex;align-items:center;gap:5px;font-size:11.5px;color:var(--t3);cursor:pointer;border:none;background:none;font-family:'DM Sans',sans-serif;padding:3px 7px;border-radius:4px;transition:all .1s}
.aso-back:hover{background:var(--bd);color:var(--tx)}
.aso-back svg{width:11px;height:11px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round}
.aso-title{flex:1;font-size:13px;font-weight:600;color:var(--tx)}
.aso-b{flex:1;overflow:hidden;display:flex}

/* ── FILE OVERVIEW SECTIONS ── */
.ov-sec{background:var(--sf);border:1px solid var(--bd);border-radius:8px;margin-bottom:11px;overflow:hidden;box-shadow:var(--sh)}
.ov-sec-h{padding:9px 14px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;background:var(--s2)}
.ov-sec-ht{font-size:9.5px;font-family:'IBM Plex Mono',monospace;color:var(--t2);text-transform:uppercase;letter-spacing:.05em;font-weight:500}
.ov-sec-b{padding:12px 14px}
.ov-sec.cav-sec .ov-sec-h{background:var(--rdBg)}
.ov-sec.cav-sec .ov-sec-ht{color:var(--rd)}

/* ── KV (key-value) display ── */
.kv{display:flex;align-items:baseline;gap:6px;padding:5px 0;border-bottom:1px solid var(--bd)}
.kv:last-child{border-bottom:none}
.kv-k{font-size:9.5px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.04em;min-width:110px;flex-shrink:0}
.kv-v{font-size:12.5px;color:var(--tx);font-weight:500;flex:1}
.kv-v.mo{font-family:'IBM Plex Mono',monospace;font-size:11.5px}
.kv-v.gd{color:var(--gd);font-family:'IBM Plex Mono',monospace;font-size:11.5px;font-weight:700}
.kv-v.ok{color:var(--gn)}.kv-v.wa{color:var(--gd)}.kv-v.dm{color:var(--t3)}

/* ── COMPACT INSTRUMENT CARD (overview) ── */
.instr-card{background:var(--sf);border:1px solid var(--bd);border-radius:7px;overflow:hidden;box-shadow:var(--sh);margin-bottom:0}
.instr-card-top{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-bottom:1px solid var(--bd)}
.instr-card-ico{width:32px;height:38px;border-radius:4px;border:1px solid var(--bd);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--s2)}
.instr-card-ico svg{width:15px;height:15px;stroke:var(--t3);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.instr-card-info{flex:1;min-width:0}
.instr-card-type{font-weight:700;font-size:12.5px;color:var(--tx);display:flex;align-items:center;gap:7px;flex-wrap:wrap;margin-bottom:2px}
.instr-card-no{font-family:'IBM Plex Mono',monospace;font-size:10.5px;color:var(--gd);font-weight:700;margin-bottom:2px}
.instr-card-party{font-size:11px;color:var(--t3);margin-bottom:1px}
.instr-card-acts{padding:8px 14px;display:flex;gap:5px;background:var(--s3)}

/* ── ROFO UNIFIED DRAWER ── */
.rofo-ab{padding:10px 18px;border-bottom:1px solid var(--bd);display:flex;align-items:center;gap:7px;flex-wrap:wrap;flex-shrink:0;background:var(--sf)}
.rofo-ab-edit{font-size:12px;font-weight:600;color:var(--gd);font-style:italic;margin-right:4px}
.rofo-body{flex:1;overflow-y:auto;padding:18px;display:grid;grid-template-columns:1fr 270px;gap:18px;scrollbar-width:thin;scrollbar-color:var(--bd2) transparent}
.rofo-hist{margin-top:14px}
.rofo-hist-h{font-size:9.5px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:9px;padding-bottom:7px;border-bottom:1px solid var(--bd)}
.ih-row{display:flex;align-items:center;gap:8px;padding:5px 0;border-bottom:1px solid var(--bd);font-size:11px;color:var(--t2)}
.ih-row:last-child{border-bottom:none}
.ih-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

/* fread/edit-field toggle */
.fread{font-size:12.5px;color:var(--tx);font-weight:500;padding:7px 0;line-height:1.5}
.fread.mo{font-family:'IBM Plex Mono',monospace;font-size:11.5px}
.edit-field{display:none}
.rofo-edit-mode .edit-field{display:block}
.rofo-edit-mode .fread{display:none}

/* ── EDIT HISTORY (owner / allocation) ── */
.ed-hist{margin-top:10px;background:var(--sf);border:1px solid var(--bd);border-radius:6px;overflow:hidden}
.ed-hist-h{padding:7px 12px;font-size:9px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.06em;background:var(--s2);border-bottom:1px solid var(--bd)}
.edh-row{padding:7px 12px;border-bottom:1px solid var(--bd);font-size:11.5px}
.edh-row:last-child{border-bottom:none}
.edh-field{font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--t3);text-transform:uppercase;letter-spacing:.03em;margin-bottom:3px}
.edh-changes{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.edh-old{color:var(--rd);text-decoration:line-through;font-size:11.5px}
.edh-arr{color:var(--t4);font-size:11px}
.edh-new{color:var(--gn);font-weight:500;font-size:11.5px}
.edh-by{font-size:10px;color:var(--t4);margin-left:auto;white-space:nowrap}

/* ── ALLOCATION WARNING ── */
.alloc-warn{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;background:var(--gdBg);border:1px solid var(--gdBd);border-radius:6px;font-size:12px;color:var(--gd);margin-bottom:12px}
.alloc-warn svg{width:13px;height:13px;stroke:var(--gd);fill:none;stroke-width:1.5;flex-shrink:0;margin-top:1px}

/* ── DOCUMENT CONFIRM BAR ── */
.doc-confirm-bar{padding:9px 14px;background:var(--sf);border-bottom:1px solid var(--bd);display:flex;align-items:center;gap:10px;position:sticky;top:0;z-index:5}
.dcb-prog{flex:1;font-size:12px;color:var(--t2)}
.dcb-prog strong{color:var(--gd)}
.dcb-prog.all-ok strong{color:var(--gn)}
.dcb-prog.has-rej strong{color:var(--rd)}

/* ── CHECKLIST OFFICER NAME ── */
.si-need{display:flex;align-items:flex-start;gap:6px;font-size:11.5px;color:var(--t2);justify-content:space-between}
.si-need-text{flex:1}
.si-need-who{font-size:10px;color:var(--t3);font-family:'IBM Plex Mono',monospace;white-space:nowrap;margin-top:1px;flex-shrink:0}

/* ── PROPERTY CHARGE ── */
.pch-body{flex:1;overflow-y:auto;padding:16px;scrollbar-width:thin;scrollbar-color:var(--bd2) transparent}
.pch-subnav{display:flex;background:var(--sf);border-bottom:1px solid var(--bd);padding:0 18px;flex-shrink:0}
.pchn{padding:8px 14px;font-size:12px;cursor:pointer;color:var(--t3);border-bottom:2px solid transparent;transition:all .1s;white-space:nowrap}
.pchn:hover{color:var(--t2)}.pchn.on{color:var(--tx);font-weight:500;border-bottom-color:var(--gd)}
.pchv{display:none}.pchv.on{display:block}
.prop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:11px;margin-bottom:16px}
@media (max-width:1100px){.prop-grid{grid-template-columns:repeat(2,1fr)}}
.pcard{background:var(--sf);border:1px solid var(--bd);border-radius:8px;overflow:hidden;box-shadow:var(--sh);display:flex;flex-direction:column;transition:box-shadow .12s}
.pcard:hover{box-shadow:var(--sh2)}
.pcard-photo{height:120px;background:var(--s3);display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--bd);position:relative}
.pcard-photo svg{width:36px;height:36px;stroke:var(--t4);fill:none;stroke-width:1;stroke-linecap:round}
.pcard-body{padding:11px 13px;flex:1}
.pcard-codes{display:flex;gap:6px;margin-bottom:6px;flex-wrap:wrap}
.pcard-ic{font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--gd);font-weight:700}
.pcard-sc{font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--t3)}
.pcard-addr{font-size:12px;font-weight:600;color:var(--tx);margin-bottom:4px;line-height:1.4}
.pcard-meta{font-size:11px;color:var(--t3);margin-bottom:8px}
.pcard-charge{display:flex;align-items:center;justify-content:space-between;padding-top:8px;border-top:1px solid var(--bd)}
.pcard-amt{font-family:'IBM Plex Mono',monospace;font-size:12px;font-weight:700;color:var(--tx)}
.pcard-foot{padding:9px 13px;border-top:1px solid var(--bd);background:var(--s2);display:flex;align-items:center;justify-content:space-between}
.pc-stat-paid{color:var(--gn);font-size:10px;font-family:'IBM Plex Mono',monospace}
.pc-stat-due{color:var(--rd);font-size:10px;font-family:'IBM Plex Mono',monospace}

/* rate settings */
.rate-table{background:var(--sf);border:1px solid var(--bd);border-radius:8px;overflow:hidden;box-shadow:var(--sh);margin-bottom:14px}
.rt-row{display:flex;align-items:center;padding:9px 14px;border-bottom:1px solid var(--bd);gap:10px;font-size:12.5px}
.rt-row:last-child{border-bottom:none}
.rt-zone{flex:1;color:var(--tx);font-weight:500}
.rt-rate{font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--gd);font-weight:700}

/* price calculation */
.calc-result{background:var(--gdBg);border:2px solid var(--gdBd);border-radius:8px;padding:16px;text-align:center;margin-top:14px}
.calc-result-amt{font-family:'IBM Plex Mono',monospace;font-size:28px;font-weight:700;color:var(--gd);line-height:1}
.calc-result-lbl{font-size:10.5px;color:var(--t3);margin-top:4px}
.calc-formula{font-size:11px;color:var(--t2);margin-top:8px;font-family:'IBM Plex Mono',monospace}

/* metrics */
.pch-metrics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px}
.prog-bar-wrap{margin-bottom:8px}
.prog-bar-label{display:flex;justify-content:space-between;font-size:11px;color:var(--t2);margin-bottom:3px}
.prog-bar{height:6px;background:var(--s3);border-radius:3px;overflow:hidden}
.prog-bar-fill{height:100%;border-radius:3px;background:var(--gd);transition:width .3s}

/* ── fl-t fix (sidebar file list title) ── */
.fl-t{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:700;margin-bottom:6px}

/* ── SIDEBAR COLLAPSE ── */
.sb{transition:width .18s ease}
.sb.collapsed{width:52px}
.sb.collapsed .sb-brand,.sb.collapsed .sb-ver,.sb.collapsed .ts-wrap,.sb.collapsed .nsg{display:none}
.sb.collapsed .sb-row{justify-content:center;margin-bottom:4px}
.sb.collapsed .sb-logo{padding:10px 8px 8px}
.sb.collapsed .ni{justify-content:center;padding:7px;font-size:0;border-radius:5px}
.sb.collapsed .ni svg{width:14px;height:14px;flex-shrink:0}
.sb.collapsed .nbg{display:none}
.sb.collapsed .nav{padding:5px 4px}
.sb.collapsed .sb-user{padding:8px 6px;justify-content:center}
.sb.collapsed .sb-user>div:last-child{display:none}
.sb-toggle{display:flex;align-items:center;justify-content:center;padding:7px;cursor:pointer;color:rgba(255,255,255,.2);border-top:1px solid rgba(255,255,255,.06);transition:color .1s;flex-shrink:0}
.sb-toggle:hover{color:rgba(255,255,255,.45)}
.sb-toggle svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}

/* ── PROPERTY CHARGE LAYOUT ── */
#vw-propcharge.on{flex-direction:row}
#vw-propcharge>.pc-inner{display:flex;flex-direction:row;flex:1;overflow:hidden;position:relative;min-height:0}
.pcf{width:220px;flex-shrink:0;background:var(--sf);border-right:1px solid var(--bd);display:flex;flex-direction:column;overflow:hidden;transition:width .18s ease}
.pcf.collapsed{width:0;border-right:none}
.pcf-h{padding:12px 14px 10px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.pcf-title{font-size:12px;font-weight:600;color:var(--tx)}
.pcf-body{flex:1;overflow-y:auto;padding:10px 14px;scrollbar-width:thin;scrollbar-color:var(--bd2) transparent}
.pcf-sec{font-size:9px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.08em;margin:12px 0 6px;padding-bottom:5px;border-bottom:1px solid var(--bd)}
.pcf-sec:first-child{margin-top:0}
.pcf-check{display:flex;align-items:center;gap:7px;font-size:11.5px;cursor:pointer;padding:3px 0;color:var(--t2);user-select:none}
.pcf-check:hover{color:var(--tx)}
.pcf-check input[type=checkbox]{cursor:pointer;accent-color:var(--gd)}
.pcf-stats{padding:10px 14px;border-top:1px solid var(--bd);background:var(--s2);flex-shrink:0}
.pcf-stat-row{display:flex;justify-content:space-between;font-size:11px;padding:2px 0;color:var(--t3)}
.pcf-stat-row strong{color:var(--tx);font-weight:600}
.pcf-tog{width:22px;height:22px;border-radius:4px;border:none;background:transparent;cursor:pointer;color:var(--t3);display:flex;align-items:center;justify-content:center;transition:all .1s}
.pcf-tog:hover{background:var(--s3);color:var(--tx)}
.pcf-tog svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round}
.pch-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.pch-subnav{display:flex;background:var(--sf);border-bottom:1px solid var(--bd);padding:0 18px;flex-shrink:0;align-items:center;gap:0}
.pchn{padding:9px 14px;font-size:12px;cursor:pointer;color:var(--t3);border-bottom:2px solid transparent;transition:all .1s;white-space:nowrap}
.pchn:hover{color:var(--t2)}.pchn.on{color:var(--tx);font-weight:500;border-bottom-color:var(--gd)}
.pch-subnav-right{margin-left:auto;display:flex;align-items:center;gap:7px;padding:0 4px}
.pchv{display:none;flex-direction:column;overflow:hidden}.pchv.on{display:flex}
.pchv-head{padding:12px 18px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:var(--sf);flex-wrap:wrap;gap:8px}
.pchv-title{font-size:14px;font-weight:700;color:var(--tx)}
.pchv-sub{font-size:11px;color:var(--t3);margin-top:1px}
.pchv-body{flex:1;overflow-y:auto;padding:16px 18px;scrollbar-width:thin;scrollbar-color:var(--bd2) transparent}

/* View toggle (grid / table) */
.vt-toggle{display:flex;background:var(--s2);border:1px solid var(--bd);border-radius:5px;padding:2px;gap:2px}
.vtb{padding:3px 8px;border-radius:3px;cursor:pointer;font-size:11px;color:var(--t3);border:none;background:none;font-family:'DM Sans',sans-serif;transition:all .1s;display:flex;align-items:center;gap:4px}
.vtb.on{background:var(--sf);color:var(--tx);font-weight:500;box-shadow:var(--sh)}
.vtb svg{width:11px;height:11px;stroke:currentColor;fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}

/* Property table view */
.pcard-table{background:var(--sf);border:1px solid var(--bd);border-radius:8px;overflow:hidden}
.pct-head,.pct-row{display:grid;grid-template-columns:140px 1fr 120px 100px 110px 100px;gap:0;padding:8px 14px;align-items:center}
.pct-head{background:var(--s2);border-bottom:1px solid var(--bd);font-size:10px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.04em}
.pct-row{font-size:12px;border-bottom:1px solid var(--bd);cursor:pointer;transition:background .1s}
.pct-row:last-child{border-bottom:none}
.pct-row:hover{background:var(--s2)}
.pc-zone-badge{display:inline-block;padding:1px 6px;border-radius:3px;font-size:10px;font-family:'IBM Plex Mono',monospace;font-weight:600}
.pcz-a{background:var(--blBg);color:var(--bl)}.pcz-b{background:var(--puBg);color:var(--pu)}
.pcz-p{background:var(--gdBg);color:var(--gd)}.pcz-r{background:var(--gnBg);color:var(--gn)}
.pcz-g{background:var(--s3);color:var(--t3)}
.pc-stat-paid{color:var(--gn);font-family:'IBM Plex Mono',monospace;font-size:10px;font-weight:700}
.pc-stat-due{color:var(--gd);font-family:'IBM Plex Mono',monospace;font-size:10px;font-weight:700}
.pc-stat-overdue{color:var(--rd);font-family:'IBM Plex Mono',monospace;font-size:10px;font-weight:700}
.pc-stat-partial{color:var(--bl);font-family:'IBM Plex Mono',monospace;font-size:10px;font-weight:700}
.pc-stat-exempt{color:var(--t3);font-family:'IBM Plex Mono',monospace;font-size:10px}

/* Property detail panel (slide-over) */
.pc-detail{position:absolute;top:0;right:0;width:480px;height:100%;background:var(--sf);border-left:1px solid var(--bd);box-shadow:var(--sh3);transform:translateX(100%);transition:transform .2s ease;z-index:1000;display:flex;flex-direction:column}
.pc-detail.open{transform:translateX(0)}
.pcd-h{padding:12px 18px 10px;border-bottom:1px solid var(--bd);flex-shrink:0;background:var(--sf)}
.pcd-back{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--t3);cursor:pointer;border:none;background:none;padding:0;font-family:'DM Sans',sans-serif;transition:color .1s;margin-bottom:8px}
.pcd-back:hover{color:var(--tx)}
.pcd-back svg{width:11px;height:11px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round}
.pcd-ic{font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--gd);font-weight:700;margin-bottom:3px}
.pcd-name{font-size:15px;font-weight:700;color:var(--tx);margin-bottom:2px}
.pcd-addr{font-size:12px;color:var(--t3)}
.pcd-acts{display:flex;gap:7px;flex-wrap:wrap;padding:9px 18px;border-bottom:1px solid var(--bd);background:var(--s2);flex-shrink:0}
.pcd-tabs{display:flex;border-bottom:1px solid var(--bd);padding:0 18px;flex-shrink:0;background:var(--sf)}
.pdtab{padding:7px 12px;font-size:12px;cursor:pointer;color:var(--t3);border-bottom:2px solid transparent;transition:all .1s;white-space:nowrap}
.pdtab:hover{color:var(--t2)}.pdtab.on{color:var(--tx);font-weight:500;border-bottom-color:var(--gd)}
.pdtabp{display:none;flex:1;overflow-y:auto;padding:16px 18px}.pdtabp.on{display:block}

/* Billing list */
.inv-table{background:var(--sf);border:1px solid var(--bd);border-radius:8px;overflow:hidden;margin-top:12px}
.inv-thead,.inv-row{display:grid;grid-template-columns:140px 1fr 110px 100px 95px 88px;padding:8px 14px;align-items:center;gap:0}
.inv-thead{background:var(--s2);border-bottom:1px solid var(--bd);font-size:10px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.04em}
.inv-row{font-size:12px;border-bottom:1px solid var(--bd);cursor:pointer;transition:background .1s}
.inv-row:last-child{border-bottom:none}
.inv-row:hover{background:var(--s2)}
.inv-no{font-family:'IBM Plex Mono',monospace;font-size:10.5px;color:var(--gd);font-weight:700}
.inv-stat-paid{color:var(--gn);font-size:10px;font-family:'IBM Plex Mono',monospace;font-weight:700}
.inv-stat-due{color:var(--gd);font-size:10px;font-family:'IBM Plex Mono',monospace;font-weight:700}
.inv-stat-overdue{color:var(--rd);font-size:10px;font-family:'IBM Plex Mono',monospace;font-weight:700}
.inv-stat-partial{color:var(--bl);font-size:10px;font-family:'IBM Plex Mono',monospace;font-weight:700}
.bill-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:4px}
.bill-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:14px;margin-top:14px}
.bill-stat{background:var(--sf);border:1px solid var(--bd);border-radius:7px;padding:11px 14px;box-shadow:var(--sh)}
.bill-stat-v{font-family:'IBM Plex Mono',monospace;font-size:18px;font-weight:700;color:var(--tx);line-height:1}
.bill-stat-l{font-size:10.5px;color:var(--t3);margin-top:4px}
.bill-filter-row{display:flex;align-items:center;gap:8px;margin-bottom:2px;flex-wrap:wrap}

/* Invoice print modal */
.inv-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;display:none;align-items:center;justify-content:center}
.inv-modal-overlay.open{display:flex}
.inv-modal{width:660px;max-height:90vh;background:var(--sf);border-radius:10px;box-shadow:var(--sh3);display:flex;flex-direction:column;overflow:hidden}
.inv-modal-h{padding:13px 18px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.inv-modal-acts{display:flex;align-items:center;gap:7px}
.inv-modal-b{flex:1;overflow-y:auto;padding:28px 32px}
.inv-doc{font-size:12.5px;line-height:1.7;color:var(--tx)}
.inv-doc-head{text-align:center;padding-bottom:16px;border-bottom:2px solid var(--gd);margin-bottom:18px}
.inv-doc-sn{font-family:'DM Sans',sans-serif;font-size:15px;font-weight:800;color:var(--tx);letter-spacing:-.02em}
.inv-doc-min{font-size:10.5px;color:var(--t3);margin-top:2px;font-family:'IBM Plex Mono',monospace}
.inv-doc-title{font-size:17px;font-weight:700;color:var(--gd);margin-top:10px;font-family:'DM Sans',sans-serif}
.inv-doc-no{font-family:'IBM Plex Mono',monospace;font-size:11.5px;color:var(--gd);font-weight:700;margin-top:3px}
.inv-doc-2col{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px}
.inv-doc-box{border:1px solid var(--bd);border-radius:6px;padding:11px 13px}
.inv-doc-box-h{font-size:9px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;padding-bottom:5px;border-bottom:1px solid var(--bd)}
.inv-doc-box p{font-size:12px;color:var(--t2);margin-bottom:3px;line-height:1.5}
.inv-doc-box strong{color:var(--tx);font-weight:600}
.inv-charge-table{width:100%;border-collapse:collapse;margin:14px 0}
.inv-charge-table th{text-align:left;font-size:9.5px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.04em;padding:6px 0;border-bottom:1px solid var(--bd)}
.inv-charge-table td{padding:8px 0;border-bottom:1px solid var(--bd);font-size:12.5px;color:var(--t2)}
.inv-charge-table tbody tr:last-child td{border-bottom:none;font-weight:600;color:var(--tx);font-size:13px}
.inv-total-row{background:var(--gdBg);border:1px solid var(--gdBd);border-radius:6px;padding:11px 14px;display:flex;align-items:center;justify-content:space-between;margin:4px 0 14px}
.inv-total-amt{font-family:'IBM Plex Mono',monospace;font-size:20px;font-weight:700;color:var(--gd)}
.inv-pay-box{background:var(--gnBg);border:1px solid var(--gnBd);border-radius:6px;padding:11px 13px;font-size:12px;color:var(--gn);margin-top:10px}
.inv-pay-box strong{font-weight:700;display:block;margin-bottom:4px}
.inv-paid-stamp{display:inline-block;border:2px solid var(--gn);color:var(--gn);font-family:'IBM Plex Mono',monospace;font-size:13px;font-weight:700;padding:4px 12px;border-radius:4px;letter-spacing:.1em;opacity:.85;transform:rotate(-3deg);margin-top:6px}

/* pchv-wrap scroll fix */
.pchv.on{display:flex;flex-direction:column}
.pchv-body{flex:1;overflow-y:auto;padding:16px 18px;scrollbar-width:thin;scrollbar-color:var(--bd2) transparent}
.metrics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:20px}

/* ══════════════════════════════════════════════
   PROPERTY CHARGE — NEW FEATURE STYLES
   ══════════════════════════════════════════════ */

/* ── Filter sidebar enhancements ── */
.pcf-ql{display:flex;flex-direction:column;gap:2px;padding:6px 0 10px;border-bottom:1px solid var(--bd);margin-bottom:4px}
.pcf-ql-item{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--gd);font-weight:600;text-decoration:none;background:none;border:none;cursor:pointer;padding:4px 2px;border-radius:4px;transition:background .15s;text-align:left}
.pcf-ql-item:hover{background:var(--gdBg)}
.pcf-ql-item svg{width:11px;height:11px;stroke:currentColor;fill:none;stroke-width:1.5;flex-shrink:0}
.pcf-pills{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px}
.pcf-pill{border-radius:20px;padding:2px 9px;font-size:10.5px;background:var(--s3);border:1px solid var(--bd);cursor:pointer;color:var(--t2);font-weight:500;transition:all .15s}
.pcf-pill:hover{background:var(--sf);border-color:var(--bd2)}
.pcf-pill.on{background:var(--gdBg);border-color:var(--gdBd);color:var(--gd);font-weight:600}
.pcf-sec-toggle{cursor:pointer;user-select:none;display:flex;align-items:center;justify-content:space-between}
.pcf-sec-arrow{font-size:10px;color:var(--t3);transition:transform .2s}
.pcf-sec-body{overflow:hidden;max-height:300px;transition:max-height .25s}
.pcf-sec-body.collapsed{max-height:0}
.pcf-count{font-size:9px;font-family:'IBM Plex Mono',monospace;color:var(--t3);margin-left:4px}

/* ── Migration tab nav item ── */
.pchn-mig{border-left:1px solid var(--bd);margin-left:4px;padding-left:10px;display:flex;align-items:center;color:var(--bl)}
.pchn-mig svg{stroke:currentColor}

/* ── Map view ── */
#prop-map-wrap{position:relative;border-radius:8px;overflow:hidden;border:1px solid var(--bd);box-shadow:var(--sh)}
#prop-map{height:calc(100vh - 272px);min-height:440px}
.leaflet-container{font-family:'DM Sans',sans-serif;font-size:12px}
.pc-map-marker{width:13px;height:13px;border-radius:50%;border:2.5px solid #fff;box-shadow:0 1px 5px rgba(0,0,0,.4)}
/* Status legend — Leaflet control, bottom-right */
.pc-map-legend{background:var(--sf);border:1px solid var(--bd);border-radius:7px;padding:9px 12px;z-index:500;box-shadow:var(--sh2)}
.pc-map-legend-row{display:flex;align-items:center;gap:7px;font-size:10.5px;color:var(--t2);margin-bottom:4px}
.pc-map-legend-row:last-child{margin-bottom:0}
.pc-map-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
/* Stats chip — bottom-left */
.pc-map-stats{position:absolute;bottom:28px;left:12px;z-index:1000;background:var(--sf);border:1px solid var(--bd);border-radius:6px;padding:5px 10px;box-shadow:var(--sh);font-size:11px;color:var(--t2);font-family:'DM Sans',sans-serif;pointer-events:none;white-space:nowrap}

/* ── Metrics redesign ── */
.metrics-kpi-ribbon{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px}
.mkpi{background:var(--sf);border:1px solid var(--bd);border-radius:8px;padding:14px 16px;box-shadow:var(--sh)}
.mkpi-val{font-family:'IBM Plex Mono',monospace;font-size:19px;font-weight:700;line-height:1.1}
.mkpi-lbl{font-size:10px;color:var(--t3);text-transform:uppercase;letter-spacing:.05em;margin-top:3px}
.mkpi-trend{font-size:10px;margin-top:4px;font-weight:600}
.mkpi-trend.up{color:var(--gn)}
.mkpi-trend.dn{color:var(--rd)}
.met-section{background:var(--sf);border:1px solid var(--bd);border-radius:8px;padding:14px 16px;margin-bottom:14px}
.met-section-title{font-size:10px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--bd)}
.met-bar-row{display:flex;align-items:center;gap:10px;margin-bottom:7px}
.met-bar-label{width:170px;font-size:11.5px;color:var(--t2);flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.met-bar-track{flex:1;height:6px;background:var(--s3);border-radius:4px;overflow:hidden}
.met-bar-fill{height:100%;border-radius:4px;transition:width .5s cubic-bezier(.4,0,.2,1)}
.met-bar-val{width:110px;font-size:10.5px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-align:right;flex-shrink:0}
.met-risk-head{display:grid;grid-template-columns:1fr 110px 90px 80px;gap:8px;font-size:9.5px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.04em;padding:0 10px 6px;border-bottom:1px solid var(--bd);margin-bottom:4px}
.met-risk-row{display:grid;grid-template-columns:1fr 110px 90px 80px;gap:8px;padding:7px 10px;border-radius:5px;align-items:center;font-size:11.5px;cursor:pointer;transition:background .15s}
.met-risk-row:hover{background:var(--s3)}
.met-2col{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.met-3col{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.met-lga-head{display:grid;grid-template-columns:1fr 70px 90px 90px 60px;gap:8px;font-size:9.5px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.04em;padding:0 10px 6px;border-bottom:1px solid var(--bd);margin-bottom:4px}
.met-lga-row{display:grid;grid-template-columns:1fr 70px 90px 90px 60px;gap:8px;padding:7px 10px;border-radius:5px;align-items:center;font-size:11.5px}
.met-lga-row:nth-child(even){background:var(--s2)}
.met-forecast-wrap{display:flex;align-items:center;gap:12px;padding:8px 0}
.met-forecast-bar{flex:1;height:18px;background:var(--s3);border-radius:4px;overflow:hidden;position:relative}
.met-forecast-actual{height:100%;background:var(--gn);border-radius:4px 0 0 4px}
.met-forecast-proj{position:absolute;inset:0;border:2px dashed var(--bd2);border-radius:4px;pointer-events:none}

/* ── Migration view ── */
.mig-banner{background:var(--blBg);border:1px solid var(--blBd);border-radius:7px;padding:12px 16px;margin-bottom:16px;display:flex;align-items:flex-start;gap:10px}
.mig-banner svg{width:16px;height:16px;stroke:var(--bl);fill:none;stroke-width:1.5;flex-shrink:0;margin-top:1px}
.mig-banner-text{font-size:12px;color:var(--bl)}
.mig-banner-text strong{display:block;font-size:12.5px;margin-bottom:2px}
.mig-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.mig-year-check{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--t2);cursor:pointer}
.mig-head{display:grid;grid-template-columns:28px 120px 1fr 90px 80px 90px;gap:8px;align-items:center;padding:6px 10px;font-size:9.5px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--bd)}
.mig-row{display:grid;grid-template-columns:28px 120px 1fr 90px 80px 90px;gap:8px;align-items:center;padding:8px 10px;border-bottom:1px solid var(--bd);font-size:11.5px;transition:background .15s}
.mig-row:hover{background:var(--s3)}
.mig-row.imported{opacity:.45;pointer-events:none}
.mig-imported-badge{font-size:9.5px;font-family:'IBM Plex Mono',monospace;color:var(--gn);font-weight:700}
.mig-preview{background:var(--gnBg);border:1px solid var(--gnBd);border-radius:7px;padding:12px 16px;margin-top:14px}
.mig-preview-title{font-size:10px;font-family:'IBM Plex Mono',monospace;color:var(--gn);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}
.mig-import-btn{display:flex;align-items:center;gap:7px;margin-top:16px}

/* ── Land use taxonomy in rate settings ── */
.lu-cat-row{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;background:var(--s2);border-radius:5px;cursor:pointer;margin-bottom:2px;transition:background .15s}
.lu-cat-row:hover{background:var(--s3)}
.lu-cat-name{font-size:12.5px;font-weight:600;color:var(--tx)}
.lu-cat-mult{font-family:'IBM Plex Mono',monospace;font-size:11.5px;color:var(--gd)}
.lu-cat-arrow{font-size:9px;color:var(--t3);transition:transform .2s;margin-left:6px}
.lu-subtypes{border-left:2px solid var(--bd);margin:0 0 6px 12px;overflow:hidden;max-height:0;transition:max-height .3s}
.lu-subtypes.open{max-height:600px}
.lu-sub-row{display:grid;grid-template-columns:1fr 90px 80px 70px;gap:8px;align-items:center;padding:6px 10px;font-size:11.5px;border-bottom:1px solid var(--bd)}
.lu-sub-row:last-child{border-bottom:none}
.lu-sub-name{color:var(--t2)}
.lu-inherit-badge{font-size:9px;font-family:'IBM Plex Mono',monospace;color:var(--t4);padding:1px 5px;background:var(--s3);border-radius:3px}

/* ── Mixed use indicator ── */
.mixed-use-pill{background:var(--puBg);border:1px solid var(--puBd);color:var(--pu);border-radius:20px;font-size:9.5px;padding:1px 7px;font-weight:600;white-space:nowrap}
.mixed-use-bar{display:flex;height:5px;border-radius:3px;overflow:hidden;margin-top:4px}

/* ── Property photos ── */
.prop-photos{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.prop-photo{width:82px;height:62px;object-fit:cover;border-radius:5px;border:1px solid var(--bd);cursor:pointer;transition:opacity .15s}
.prop-photo:hover{opacity:.8}
.photo-lightbox{position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:9999;display:none;align-items:center;justify-content:center;cursor:pointer}
.photo-lightbox.open{display:flex}
.photo-lightbox img{max-width:90vw;max-height:90vh;border-radius:8px;object-fit:contain;box-shadow:0 8px 32px rgba(0,0,0,.5)}

/* ── Field data badge in overview ── */
.field-badge{display:inline-flex;align-items:center;gap:4px;font-size:9.5px;font-family:'IBM Plex Mono',monospace;color:var(--gn);background:var(--gnBg);border:1px solid var(--gnBd);padding:2px 7px;border-radius:12px}
.field-badge svg{width:9px;height:9px;stroke:currentColor;fill:none;stroke-width:1.5}
.prop-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px 10px}
.utility-pills{display:flex;gap:4px;flex-wrap:wrap;margin-top:3px}
.utility-pill{font-size:9.5px;padding:2px 7px;border-radius:12px;font-weight:500}
.utility-pill.yes{background:var(--gnBg);color:var(--gn);border:1px solid var(--gnBd)}
.utility-pill.no{background:var(--s3);color:var(--t3);border:1px solid var(--bd)}

/* ── Bill custom rate indicator ── */
.bill-custom-badge{font-size:9px;font-family:'IBM Plex Mono',monospace;color:var(--pu);background:var(--puBg);border:1px solid var(--puBd);padding:1px 5px;border-radius:3px;margin-left:4px}
.bill-edit-btn{font-size:10px;padding:1px 7px;background:none;border:1px solid var(--bd);border-radius:3px;cursor:pointer;color:var(--t3);font-family:'DM Sans',sans-serif}
.bill-edit-btn:hover{background:var(--s3);color:var(--tx)}

/* ── Citizen portal nav link ── */
.portal-nav-link{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--gd);font-weight:600;text-decoration:none;padding:4px 10px;border:1px solid var(--gdBd);border-radius:20px;background:var(--gdBg);transition:all .15s}
.portal-nav-link:hover{background:var(--gd);color:#fff}

/* ═══════════════════════════════════════════════════════
   NEW UI — ACTIVITY & ACTIONS PANEL (Phase 1)
═══════════════════════════════════════════════════════ */
.act-next{margin:10px 12px;padding:11px 13px;background:var(--s2);border:1.5px dashed var(--bd2);border-radius:7px}
.act-next-label{font-size:9px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px}
.act-next-name{font-size:13px;font-weight:700;color:var(--tx);margin-bottom:4px}
.act-next-needs{margin-top:4px}
.act-next-need{font-size:11px;color:var(--t2);margin-bottom:2px}

/* Timeline items */
.tl-item{display:flex;gap:0;padding:0 12px 0 10px;position:relative}
.tl-lc{display:flex;flex-direction:column;align-items:center;width:22px;flex-shrink:0}
.tl-dot{width:16px;height:16px;border-radius:50%;border:2px solid var(--bd2);background:var(--sf);flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:4px}
.tl-dot svg{width:8px;height:8px}
.tl-dot.done{background:var(--sf)}
.tl-dot.warn{border-color:var(--gd);background:var(--gdBg)}
.tl-dot.pay{border-color:var(--gn);background:var(--gnBg)}
.tl-dot.note{border-color:var(--bd2);background:var(--s3)}
.tl-dot.notif{border-color:var(--bl);background:var(--blBg)}
.tl-vl{width:1px;background:var(--bd);flex:1;min-height:8px;margin:2px 0}
.tl-body{flex:1;padding:3px 0 10px 9px;cursor:pointer}
.tl-body:hover{background:none}
.tl-n{font-size:12px;color:var(--t2);font-weight:500;line-height:1.4}
.tl-m{font-size:10px;color:var(--t3);margin-bottom:2px}
.tl-exp{display:none;margin-top:5px}
.tl-exp.open{display:block}
.tl-kv{display:flex;gap:6px;font-size:10.5px;padding:2px 0}
.tl-k{color:var(--t3);flex-shrink:0;min-width:80px}
.tl-v{color:var(--t2);font-family:'IBM Plex Mono',monospace;font-size:10px}
.tl-note{background:var(--gdBg);border:1px solid var(--gdBd);border-radius:4px;padding:5px 9px;font-size:11px;color:var(--t2);font-style:italic;margin-top:4px}
.tl-note-text{font-size:11px;color:var(--t2);padding:3px 0;font-style:italic}
.tl-pay{background:var(--gnBg);border:1px solid var(--gnBd);border-radius:4px;padding:4px 8px;font-size:10.5px;color:var(--gn);margin-top:2px}
.tl-return{background:var(--rdBg);border:1px solid var(--rdBd);border-radius:4px;padding:4px 8px;font-size:10.5px;color:var(--rd);margin-top:4px}

/* ═══════════════════════════════════════════════════════
   REVIEW TAB (Phase 2)
═══════════════════════════════════════════════════════ */
.rev-card{background:var(--sf);border:1px solid var(--bd);border-radius:7px;margin-bottom:9px;overflow:hidden}
.rev-card-hd{padding:9px 14px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between}
.rev-card-stage{font-size:12px;font-weight:600;color:var(--tx)}
.rev-dec-badge{padding:2px 8px;border-radius:3px;font-size:9.5px;font-family:'IBM Plex Mono',monospace;font-weight:600}
.rev-dec-ok{background:var(--gnBg);color:var(--gn);border:1px solid var(--gnBd)}
.rev-dec-ret{background:var(--gdBg);color:var(--gd);border:1px solid var(--gdBd)}
.rev-dec-dec{background:var(--rdBg);color:var(--rd);border:1px solid var(--rdBd)}
.rv-who{font-size:10.5px;color:var(--t3);padding:8px 14px 4px}
.rv-note{font-size:11px;color:var(--t2);font-style:italic;padding:0 14px 10px}

/* App status pills in ASO header */
.aso-status-pill{font-size:9px;font-family:'IBM Plex Mono',monospace;font-weight:600;padding:2px 7px;border-radius:3px;margin-left:5px}
.sp-ret{background:var(--gdBg);color:var(--gd);border:1px solid var(--gdBd)}
.sp-hold{background:var(--s3);color:var(--t2);border:1px solid var(--bd2)}
.sp-dec{background:var(--rdBg);color:var(--rd);border:1px solid var(--rdBd)}
.sp-done{background:var(--gnBg);color:var(--gn);border:1px solid var(--gnBd)}

/* ═══════════════════════════════════════════════════════
   APP TYPE DRAWER (Phase 3)
═══════════════════════════════════════════════════════ */
.app-type-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}
.app-type-card{padding:11px 13px;border:1.5px solid var(--bd);border-radius:7px;cursor:pointer;transition:all .12s;background:var(--sf)}
.app-type-card:hover{border-color:var(--gd);background:var(--gdBg)}
.app-type-card.sel{border-color:var(--gd);background:var(--gdBg)}
.app-type-card-name{font-size:12px;font-weight:600;color:var(--tx);margin-bottom:2px}
.app-type-card-desc{font-size:10px;color:var(--t3);line-height:1.4}

/* Multi-step indicators */
.dw-steps{display:flex;padding:10px 17px 12px;border-bottom:1px solid var(--bd);gap:4px}
.dw-step{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;position:relative}
.dw-step:not(:last-child)::after{content:'';position:absolute;top:9px;left:60%;right:-40%;height:1px;background:var(--bd)}
.dw-step-dot{width:20px;height:20px;border-radius:50%;border:2px solid var(--bd);background:var(--sf);display:flex;align-items:center;justify-content:center;font-size:9px;color:var(--t3);font-weight:700;font-family:'IBM Plex Mono',monospace}
.dw-step-dot.act{border-color:var(--gd);background:var(--gdBg);color:var(--gd)}
.dw-step-dot.done{border-color:var(--gn);background:var(--gnBg);color:var(--gn)}
.dw-step-label{font-size:9px;color:var(--t3);text-align:center;font-family:'IBM Plex Mono',monospace;text-transform:uppercase;letter-spacing:.04em}

/* File search in new app drawer */
.file-search-wrap{position:relative}
.file-search-results{border:1px solid var(--bd);border-radius:5px;margin-top:4px;overflow:hidden;display:none}
.file-search-results.open{display:block}
.fsr-item{padding:8px 12px;cursor:pointer;border-bottom:1px solid var(--bd);transition:background .1s}
.fsr-item:last-child{border-bottom:none}
.fsr-item:hover{background:var(--s2)}
.fsr-fn{font-size:10px;font-family:'IBM Plex Mono',monospace;color:var(--gd);margin-bottom:1px}
.fsr-name{font-size:12px;font-weight:600;color:var(--tx)}
.fsr-meta{font-size:10px;color:var(--t3)}
.fsr-sel{border:1.5px solid var(--gn);background:var(--gnBg);border-radius:5px;padding:7px 11px;display:flex;align-items:center;justify-content:space-between;font-size:12px;margin-top:4px}
.fsr-sel-name{font-weight:600;color:var(--gn)}
.fsr-sel-clear{font-size:10px;color:var(--t3);cursor:pointer;text-decoration:underline}

/* Provisional file banner */
.prov-banner{background:var(--puBg);border:1px solid var(--puBd);border-radius:5px;padding:8px 11px;margin:8px 0;font-size:12px;color:var(--pu);line-height:1.5}

/* Notification checkbox row */
.notif-row{padding:9px 17px;border-top:1px solid var(--bd);background:var(--s2);display:flex;align-items:center;gap:7px}
.notif-label{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--t2);cursor:pointer;user-select:none}
.notif-label input{width:13px;height:13px;accent-color:var(--gd)}

/* ═══════════════════════════════════════════════════════
   CONSENT FULL FLOW (Phase 4)
═══════════════════════════════════════════════════════ */
.alloc-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--bd);border-radius:7px;overflow:hidden}
.alloc-grid-col{padding:12px 14px}
.alloc-grid-col:first-child{border-right:1px solid var(--bd)}
.alloc-grid-col-hd{font-size:9px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;padding-bottom:5px;border-bottom:1px solid var(--bd)}

/* Consent status dots */
.cs-step{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--bd)}
.cs-step:last-child{border-bottom:none}
.cs-dot{width:8px;height:8px;border-radius:50%;background:var(--bd2);flex-shrink:0}
.cs-dot.done{background:var(--gn)}
.cs-dot.cur{background:var(--gd)}
.cs-label{font-size:11.5px;color:var(--t2);flex:1}
.cs-label.done{color:var(--gn)}
.cs-label.cur{color:var(--gd);font-weight:600}
.cs-who{font-size:10px;color:var(--t3)}

/* Consent entry rows in drawer */
.ce-row{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--bd)}
.ce-row:last-child{border-bottom:none}
.ce-ref{font-size:10px;font-family:'IBM Plex Mono',monospace;color:var(--gd)}
.ce-name{font-size:12px;font-weight:600;color:var(--tx)}
.ce-loc{font-size:10.5px;color:var(--t3)}

/* Consent history timeline */
.csh-item{display:flex;gap:9px;padding:6px 0;border-bottom:1px solid var(--bd)}
.csh-item:last-child{border-bottom:none}
.csh-dot{width:6px;height:6px;border-radius:50%;background:var(--gn);margin-top:5px;flex-shrink:0}
.csh-body{flex:1}
.csh-action{font-size:12px;font-weight:600;color:var(--tx)}
.csh-meta{font-size:10.5px;color:var(--t3)}

/* ═══════════════════════════════════════════════════════
   INSTRUMENTS SECTIONS (Phase 5)
═══════════════════════════════════════════════════════ */
.instr-section{margin-bottom:18px}
.instr-section-hd{font-size:9px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.08em;padding-bottom:7px;border-bottom:1px solid var(--bd);margin-bottom:11px;display:flex;align-items:center;justify-content:space-between}
.instr-section-hd span:last-child{font-size:9px;letter-spacing:0}

/* ROFO status-aware badges */
.instr-status-prepared{background:var(--s3);color:var(--t2)}
.instr-status-generated{background:var(--gdBg);color:var(--gd)}
.instr-status-signed_uploaded{background:var(--blBg);color:var(--bl)}
.instr-status-registered,.instr-status-active{background:var(--gnBg);color:var(--gn)}

/* ═══════════════════════════════════════════════════════
   PLOT HISTORY MAP (Phase 6)
═══════════════════════════════════════════════════════ */
.plot-map-wrap{position:relative;border-radius:7px;overflow:hidden;margin-bottom:11px}
.plot-hist-panel{position:absolute;right:0;top:0;bottom:0;width:270px;background:var(--sf);border-left:1px solid var(--bd);z-index:10;transform:translateX(100%);transition:transform .2s ease;display:flex;flex-direction:column}
.plot-hist-panel.open{transform:translateX(0)}
.php-h{display:flex;align-items:center;justify-content:space-between;padding:10px 13px;border-bottom:1px solid var(--bd);background:var(--s2)}
.php-title{font-size:12px;font-weight:600;color:var(--tx)}
.php-b{flex:1;overflow-y:auto;padding:12px 13px}
.php-close{background:none;border:none;cursor:pointer;color:var(--t3);font-size:16px;line-height:1;padding:2px 5px}
.php-close:hover{color:var(--tx)}

/* Plot spatial history list */
.ph-item{display:flex;gap:9px;padding:7px 0;border-bottom:1px solid var(--bd);cursor:pointer}
.ph-item:last-child{border-bottom:none}
.ph-item:hover{background:var(--s2)}
.ph-dot{width:10px;height:10px;border-radius:50%;border:2px solid var(--gd);background:var(--gdBg);flex-shrink:0;margin-top:3px}
.ph-dot.current{background:var(--gd);border-color:var(--gd)}
.ph-body{flex:1}
.ph-label{font-size:12px;font-weight:600;color:var(--tx)}
.ph-meta{font-size:10.5px;color:var(--t3)}

/* ═══════════════════════════════════════════════════════
   NOTES FULL FLOW (Phase 9)
═══════════════════════════════════════════════════════ */
.note-item{padding:10px 14px;border-bottom:1px solid var(--bd);position:relative}
.note-item:last-child{border-bottom:none}
.note-type-general{border-left:3px solid var(--bd2)}
.note-type-flag{border-left:3px solid var(--gd)}
.note-type-alert{border-left:3px solid var(--rd)}
.note-type-caveat{border-left:3px solid var(--pu)}
.note-resolved{opacity:.45}
.note-resolved .ni-txt{text-decoration:line-through}
.ni-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:3px}
.ni-by{font-size:11px;font-weight:600;color:var(--t2)}
.ni-date{font-size:10px;color:var(--t3)}
.ni-txt{font-size:12px;color:var(--tx);line-height:1.5}
.ni-resolve{font-size:10px;color:var(--t3);cursor:pointer;text-decoration:underline;margin-top:4px;display:inline-block}
.ni-resolve:hover{color:var(--tx)}
.ni-type-badge{font-size:8.5px;font-family:'IBM Plex Mono',monospace;text-transform:uppercase;letter-spacing:.05em;padding:1px 5px;border-radius:2px;margin-right:5px}
.ni-type-flag{background:var(--gdBg);color:var(--gd)}
.ni-type-alert{background:var(--rdBg);color:var(--rd)}
.ni-type-caveat{background:var(--puBg);color:var(--pu)}
.ni-cav{font-size:9px;font-family:'IBM Plex Mono',monospace;color:var(--rd);background:var(--rdBg);border:1px solid var(--rdBd);padding:1px 5px;border-radius:2px;margin-top:3px;display:inline-block}

/* ═══════════════════════════════════════════════════════
   CAVEAT FULL FLOW (Phase 8)
═══════════════════════════════════════════════════════ */
.fd-cav{display:none;background:var(--rdBg);border-bottom:2px solid var(--rdBd);padding:8px 14px;font-size:12px;color:var(--rd);align-items:center;gap:8px}
.fd-cav.on{display:flex}
.fd-cav svg{width:14px;height:14px;stroke:var(--rd);fill:none;stroke-width:1.8;stroke-linecap:round;flex-shrink:0}
.fd-cav-actions{display:flex;gap:6px;margin-left:auto}

/* Caveat timeline rows */
.cav-tl-item{display:flex;gap:8px;padding:6px 0;border-bottom:1px solid var(--bd)}
.cav-tl-item:last-child{border-bottom:none}
.cav-tl-dot{width:8px;height:8px;border-radius:50%;background:var(--rd);margin-top:5px;flex-shrink:0}
.cav-tl-action{font-size:12px;font-weight:600;color:var(--tx)}
.cav-tl-meta{font-size:10.5px;color:var(--t3)}

/* Alloc-warn (existing, ensure it's included) */
.alloc-warn{background:var(--gdBg);border:1px solid var(--gdBd);border-radius:6px;padding:9px 12px;font-size:12px;color:var(--gd);display:flex;gap:8px;align-items:flex-start;margin-bottom:11px}
.alloc-warn svg{width:14px;height:14px;stroke:var(--gd);fill:none;stroke-width:1.8;stroke-linecap:round;flex-shrink:0;margin-top:1px}

/* ═══════════════════════════════════════════════════════
   DEED FLOW (Phase 10)
═══════════════════════════════════════════════════════ */
.deed-party-block{background:var(--s2);border:1px solid var(--bd);border-radius:6px;padding:11px 13px;margin-bottom:10px}
.deed-party-hd{font-size:10px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;border-bottom:1px solid var(--bd);padding-bottom:5px}

/* Deed registry table row actions */
.deed-row-acts{display:flex;gap:5px}

/* ═══════════════════════════════════════════════════════
   MISC IMPROVEMENTS
═══════════════════════════════════════════════════════ */
/* App-so open with new panel layout */
.app-so .det{grid-template-columns:1fr 300px}

/* Return reason type */
.return-type-sel{margin-bottom:10px}

/* Document preview for COFO */
.cofo-preview-wrap{background:var(--s2);border:1px solid var(--bd);border-radius:6px;padding:14px;margin-top:10px}
.cofo-preview-wrap h4{font-size:11px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}

/* Consent list status in consent view table */
.cl-status-draft{background:var(--s3);color:var(--t2)}
.cl-status-awaiting{background:var(--gdBg);color:var(--gd)}
.cl-status-signed{background:var(--blBg);color:var(--bl)}
.cl-status-recorded{background:var(--gnBg);color:var(--gn)}

/* ═══════════════════════════════════════════════════════
   REVIEW TAB SIDEBAR (Redesign)
═══════════════════════════════════════════════════════ */
.rev-layout{display:flex;height:100%;min-height:320px}
.rev-sidebar{width:172px;flex-shrink:0;border-right:1px solid var(--bd);overflow-y:auto;padding:8px 0}
.rev-detail{flex:1;overflow-y:auto}
.rev-si{display:flex;align-items:flex-start;gap:8px;padding:8px 12px;cursor:pointer;transition:background .12s;position:relative}
.rev-si:hover{background:var(--s2)}
.rev-si.on{background:var(--gdBg)}
.rev-si.on .rev-si-name{color:var(--gd);font-weight:600}
.rev-si-dot{width:16px;height:16px;border-radius:50%;border:2px solid var(--bd2);background:var(--sf);flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:1px}
.rev-si-dot.done{border-color:var(--gn);background:var(--gnBg)}
.rev-si-dot.done svg{width:9px;height:9px}
.rev-si-dot.cur{border-color:var(--gd);background:var(--gdBg)}
.rev-si-dot.fut{border-color:var(--bd);background:var(--s3)}
.rev-si-pulse{width:6px;height:6px;border-radius:50%;background:var(--gd);animation:pulse-dot 1.4s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.8)}}
.rev-si-name{font-size:11px;color:var(--t2);line-height:1.4;flex:1}
.rev-si-fut{color:var(--t4)}
.rev-si-cur-badge{font-size:8px;font-family:'IBM Plex Mono',monospace;color:var(--gd);background:var(--gdBg);border:1px solid var(--gdBd);border-radius:2px;padding:1px 4px;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;margin-top:2px}
/* Review detail panel */
.rev-dt{height:100%}
.rev-dt-hd{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:12px 14px;border-bottom:1px solid var(--bd)}
.rev-dt-stage{font-size:12.5px;font-weight:700;color:var(--tx);margin-bottom:2px}
.rev-dt-who{font-size:10.5px;color:var(--t3)}
.rev-dt-data{padding:10px 14px;border-bottom:1px solid var(--bd)}
.rev-dt-act{padding:10px 14px}
.rev-dt-cur-state{padding:18px 16px}
.rev-dt-cur-badge{font-size:9px;font-family:'IBM Plex Mono',monospace;text-transform:uppercase;letter-spacing:.06em;color:var(--gd);background:var(--gdBg);border:1px solid var(--gdBd);border-radius:3px;padding:2px 8px;display:inline-block;margin-bottom:8px}
.rev-dt-needs{margin:10px 0;padding:8px 10px;background:var(--s2);border-radius:5px;border:1px solid var(--bd)}
.rev-dt-need{font-size:11px;color:var(--t2);padding:2px 0}
.rev-dt-future{padding:18px 16px;opacity:.6}

/* ═══════════════════════════════════════════════════════
   CONSENT LIST CARDS (View Redesign)
═══════════════════════════════════════════════════════ */
.cl-card{border:1px solid var(--bd);border-radius:8px;margin-bottom:12px;overflow:hidden;cursor:pointer;transition:border-color .15s,box-shadow .15s;background:var(--sf)}
.cl-card:hover{border-color:var(--gd);box-shadow:0 2px 8px rgba(0,0,0,.06)}
.cl-card-hd{display:flex;align-items:flex-start;justify-content:space-between;padding:12px 14px 10px;border-bottom:1px solid var(--bd)}
.cl-card-id{font-size:13px;font-weight:700;font-family:'IBM Plex Mono',monospace;color:var(--tx);margin-bottom:2px}
.cl-card-meta{font-size:10.5px;color:var(--t3)}
/* Progress steps in consent card */
.cl-prog-steps{display:flex;align-items:center;padding:8px 14px;gap:0;border-bottom:1px solid var(--bd);background:var(--s2)}
.cl-prog-step{display:flex;align-items:center;gap:4px;flex:1}
.cl-prog-step:not(:last-child)::after{content:'';flex:1;height:1px;background:var(--bd);margin:0 4px}
.cl-prog-dot{width:8px;height:8px;border-radius:50%;border:2px solid var(--bd2);background:var(--sf);flex-shrink:0}
.cl-prog-dot.done{background:var(--gn);border-color:var(--gn)}
.cl-prog-dot.next{border-color:var(--gd)}
.cl-prog-label{font-size:9px;font-family:'IBM Plex Mono',monospace;color:var(--t4);white-space:nowrap}
/* Entry preview in consent card */
.cl-card-entries{padding:8px 14px;min-height:36px}
.cl-card-entry{display:flex;align-items:center;gap:7px;padding:3px 0;border-bottom:1px solid var(--bd)}
.cl-card-entry:last-child{border-bottom:none}
.cl-card-eref{font-size:10px;font-family:'IBM Plex Mono',monospace;color:var(--gd);flex-shrink:0}
.cl-card-ename{font-size:11.5px;font-weight:600;color:var(--tx);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cl-card-eloc{font-size:10px;color:var(--t3);flex-shrink:0;white-space:nowrap}
.cl-card-more{font-size:10.5px;color:var(--t3);font-style:italic;padding-top:4px}
.cl-card-ft{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;background:var(--s2)}
.cl-card-sig{font-size:10.5px;color:var(--t3)}
/* Richer consent entry rows in drawer */
.ce-row{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--bd)}
.ce-row:last-child{border-bottom:none}
.ce-num{width:20px;height:20px;border-radius:50%;background:var(--s3);color:var(--t3);font-size:10px;font-family:'IBM Plex Mono',monospace;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.ce-body{flex:1;min-width:0}
.ce-row-top{display:flex;align-items:center;gap:6px;margin-bottom:2px;flex-wrap:wrap}
.ce-ref{font-size:10px;font-family:'IBM Plex Mono',monospace;color:var(--gd)}
.ce-fn{font-size:10px;font-family:'IBM Plex Mono',monospace;color:var(--t3)}
.ce-name{font-size:12.5px;font-weight:600;color:var(--tx);margin-bottom:1px}
.ce-plot{font-size:11px;color:var(--t2);margin-bottom:1px}
.ce-added{font-size:10px;color:var(--t4)}

/* ═══════════════════════════════════════════════════════
   ALLOCATION HISTORY (Plot-to-file linkage)
═══════════════════════════════════════════════════════ */
.alloc-hist-list{padding:4px 0}
.alloc-hist-item{display:flex;gap:10px;padding:8px 14px;border-bottom:1px solid var(--bd)}
.alloc-hist-item:last-child{border-bottom:none}
.ah-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:4px}
.ah-dot-linked{background:var(--gn);border:2px solid var(--gnBd)}
.ah-dot-unlinked{background:var(--rd);border:2px solid var(--rdBd)}
.ah-body{flex:1}
.ah-event{font-size:12px;font-weight:600;color:var(--tx);margin-bottom:1px}
.ah-plot{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--gd)}
.ah-meta{font-size:10.5px;color:var(--t3);margin-bottom:2px}
.ah-note{font-size:11px;color:var(--t2);font-style:italic}

/* ── Improved map popup ── */
.pc-popup-clean .leaflet-popup-content-wrapper{border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,.18);padding:0;border:1px solid rgba(0,0,0,.08)}
.pc-popup-clean .leaflet-popup-content{margin:0;min-width:200px}
.pc-map-popup{padding:10px 12px}
.pop-code{font-family:'IBM Plex Mono',monospace;font-size:11px;font-weight:700;color:var(--gd);letter-spacing:.04em;margin-bottom:3px}
.pop-addr{font-size:12px;font-weight:600;color:var(--tx);margin-bottom:5px;line-height:1.3}
.pop-meta{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:6px}
.pop-meta span{font-size:10px;color:var(--t3);background:var(--s2);border:1px solid var(--bd);border-radius:4px;padding:1px 6px}
.pop-bottom{display:flex;align-items:center;justify-content:space-between;margin-bottom:7px}
.pop-charge{font-family:'IBM Plex Mono',monospace;font-size:13px;font-weight:700;color:var(--tx)}
.pop-stat{font-size:10.5px;font-weight:700}
.pop-btn{width:100%;padding:5px 10px;font-size:11.5px;font-weight:600;background:var(--s2);border:1px solid var(--bd);border-radius:5px;cursor:pointer;color:var(--tx);font-family:'DM Sans',sans-serif;transition:background .1s}
.pop-btn:hover{background:var(--gdBg);border-color:var(--gdBd);color:var(--gd)}

/* ── Layer control — floating panel top-right ── */
.pc-layer-ctrl{position:absolute;top:12px;right:12px;z-index:1000;background:var(--sf);border:1px solid var(--bd);border-radius:9px;box-shadow:0 4px 16px rgba(0,0,0,.12);min-width:180px;overflow:hidden}
.lc-header{padding:8px 12px 7px;font-size:9px;font-family:'IBM Plex Mono',monospace;color:var(--t3);text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--bd);background:var(--s2)}
.lc-item{display:flex;align-items:center;gap:8px;width:100%;padding:6px 12px;background:none;border:none;border-bottom:1px solid var(--bd);cursor:pointer;font-size:11.5px;color:var(--t2);font-family:'DM Sans',sans-serif;text-align:left;transition:background .1s}
.lc-item:last-of-type{border-bottom:none}
.lc-item:hover{background:var(--s2);color:var(--tx)}
.lc-item.on{color:var(--tx)}
.lc-check{width:14px;height:14px;border:1.5px solid var(--bd3);border-radius:3px;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .15s;background:transparent}
.lc-check svg{display:none}
.lc-item.on .lc-check{background:var(--gd);border-color:var(--gd)}
.lc-item.on .lc-check svg{display:block}
.lc-dot{width:10px;height:10px;border-radius:2px;flex-shrink:0}
.lc-label{flex:1}
.lc-legend-wrap{padding:8px 12px;border-top:1px solid var(--bd)}
.lc-legend-bar{display:flex;gap:1px;height:8px;border-radius:2px;overflow:hidden;margin-bottom:4px}
.lc-legend-labels{display:flex;justify-content:space-between;font-size:9.5px;color:var(--t3);font-family:'IBM Plex Mono',monospace}
.pc-grid-tip{font-family:'DM Sans',sans-serif;font-size:12px}
.lc-style-row{display:flex;gap:6px;padding:7px 12px}
.lc-style-btn{flex:1;padding:4px 0;font-size:11px;border:1px solid var(--bd);border-radius:5px;background:none;color:var(--t2);cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .15s}
.lc-style-btn:hover{background:var(--s2)}
.lc-style-btn.on{background:var(--gd);color:#fff;border-color:var(--gd)}

/* ── Detailed use filter tree ── */
.du-cat{font-size:11.5px;font-weight:600;color:var(--t2);padding:3px 0;cursor:pointer;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--bd);margin-bottom:2px;user-select:none}
.du-arrow{font-size:10px;color:var(--t3);transition:transform .15s}
.du-subs{padding-left:8px;overflow:hidden;max-height:500px;transition:max-height .2s}
.du-subs.collapsed{max-height:0}

/* ── Land Use Filter Tree ── */
.luf-cat-wrap { margin-bottom:2px; }
.luf-cat { display:flex; align-items:center; padding:4px 0; }
.luf-cat-label { display:flex; align-items:center; gap:6px; flex:1; cursor:pointer; font-size:12px; color:var(--tx); }
.luf-cat-name { font-weight:600; flex:1; }
.luf-cnt { font-size:10px; color:var(--t3); background:var(--b2); padding:0px 5px; border-radius:20px; min-width:20px; text-align:center; }
.luf-expand { background:none; border:none; color:var(--t3); font-size:10px; cursor:pointer; padding:2px 6px; border-radius:4px; transition:background .15s; }
.luf-expand:hover { background:var(--b2); }
.luf-subs { overflow:hidden; max-height:600px; transition:max-height .25s ease; padding-left:8px; border-left:2px solid var(--bd); margin-left:8px; }
.luf-subs.collapsed { max-height:0; }
.luf-sub-label { display:flex; align-items:center; gap:6px; padding:3px 0; cursor:pointer; font-size:11px; color:var(--t2); }
.luf-sub-name { flex:1; }

/* (lc-* classes defined in layer control block above) */

/* ── Edit Property Inline Form ── */
.dep-section { margin-bottom:10px; }
.dep-label { font-size:10px; text-transform:uppercase; letter-spacing:.05em; color:var(--t3); margin-bottom:4px; font-weight:600; }
.dep-row { display:flex; gap:10px; }
.dep-row .dep-section { flex:1; }
