/* Lifted near-verbatim from _preexisting/trade-reports_6.html, with small
   additions for the multi-page shell (role switcher, audit form, owner views). */

:root{
  --ink:#11161c; --ink-2:#2b3640; --line:#dde3ea; --line-2:#eef2f6;
  --paper:#f6f8fa; --card:#ffffff; --muted:#6b7783;
  --accent:#0f5a52; --accent-soft:#e6f2f0;
  --ok:#1a7f4b; --ok-soft:#e7f5ec;
  --warn:#9a6700; --warn-soft:#fdf3da;
  --block:#a3261f; --block-soft:#fbe9e7;
  --fam:#0b4a8f; --fam-soft:#e8f0fb;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'IBM Plex Sans',sans-serif;background:var(--paper);color:var(--ink);
  line-height:1.45;-webkit-font-smoothing:antialiased}
.mono{font-family:'IBM Plex Mono',monospace;font-variant-numeric:tabular-nums}
.wrap{max-width:1160px;margin:0 auto;padding:0 24px}
.muted{color:var(--muted)}
.hidden{display:none}

/* Auth-page top bar — matches the app's solid teal .topnav (see base.html). */
header.top{border-bottom:none;background:var(--accent);min-height:50px;display:flex;
  align-items:center;padding:0;position:sticky;top:0;z-index:30}
.brandrow{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.brand{display:flex;align-items:baseline;gap:10px}
.brand h1{font-size:16px;font-weight:700;letter-spacing:-.01em}
.brand .tag{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;
  color:var(--accent);background:var(--accent-soft);padding:3px 8px;border-radius:4px}
.brand p{font-size:12.5px;color:var(--muted);margin-top:3px}
/* White brand on the teal auth bar */
header.top .brand h1{color:#fff}
header.top .brand .tag{color:#fff;background:rgba(255,255,255,.18)}
header.top .brand .muted,header.top .muted{color:rgba(255,255,255,.82)}
.roleswitch{display:flex;align-items:center;gap:10px;font-size:12.5px}
.roleswitch span{font-size:12.5px}
.roleswitch form{margin:0}
.roleswitch select{font-family:'IBM Plex Sans';font-size:12.5px;border:1px solid var(--line);border-radius:6px;
  padding:5px 8px;background:var(--card);color:var(--ink)}
.roleswitch select:focus{outline:none;border-color:var(--accent)}

.datebox{font-size:12px;color:var(--muted);margin-top:14px}
.datebox b{color:var(--ink);font-weight:600}
.dateinput{font-family:'IBM Plex Mono',monospace;font-size:12.5px;border:1px solid var(--line);
  border-radius:6px;padding:5px 8px;color:var(--ink);background:var(--card);margin-left:4px}
.dateinput:focus{outline:none;border-color:var(--accent)}
.datePrompt{background:var(--warn-soft);border:1px solid #ecd79a;color:var(--warn);font-weight:600;
  font-size:13px;border-radius:9px;padding:16px 18px;margin:22px 0}

.uploadzone{margin:26px 0 6px;border:1.5px dashed var(--line);border-radius:10px;background:var(--card);
  padding:30px;text-align:center;transition:.15s;cursor:pointer}
.uploadzone:hover{border-color:var(--accent);background:#fbfdfd}
.uploadzone.drag{border-color:var(--accent);background:var(--accent-soft)}
.uploadzone h2{font-size:15px;font-weight:600;margin-bottom:5px}
.uploadzone p{font-size:12.5px;color:var(--muted)}
.uploadzone .pill{display:inline-block;margin-top:12px;font-size:12px;font-weight:600;color:#fff;
  background:var(--ink);padding:8px 16px;border-radius:6px}
#fileInput{display:none}

/* status gate */
.gate{margin:22px 0;border-radius:10px;border:1px solid var(--line);overflow:hidden;background:var(--card)}
.gate.ok{border-color:#bfe3cd}
.gate.warn{border-color:#ecd79a}
.gatehead{display:flex;align-items:center;gap:12px;padding:14px 18px;font-size:13.5px;font-weight:600}
.gate.ok .gatehead{background:var(--ok-soft);color:var(--ok)}
.gate.warn .gatehead{background:var(--warn-soft);color:var(--warn)}
.dot{width:9px;height:9px;border-radius:50%;flex:none}
.gate.ok .dot{background:var(--ok)} .gate.warn .dot{background:var(--warn)}
.gatebody{padding:4px 18px 16px}
.stats{display:flex;gap:26px;flex-wrap:wrap;padding:12px 0 4px}
.stat .n{font-size:20px;font-weight:600}
.stat .l{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted)}
.exc{border-top:1px dashed var(--line);margin-top:8px;padding-top:12px}
.exc-item{display:flex;align-items:center;gap:12px;background:var(--block-soft);border:1px solid #f0cfca;
  border-radius:7px;padding:10px 13px;margin-bottom:8px;font-size:13px}
.exc-item .x{color:var(--block);font-weight:700;flex:none}
.exc-item .grow{flex:1}
.btn{font-family:inherit;font-size:12.5px;font-weight:600;border:1px solid var(--line);background:var(--card);
  color:var(--ink);padding:7px 13px;border-radius:6px;cursor:pointer;transition:.12s;text-decoration:none;display:inline-block}
.btn:hover{border-color:var(--ink-2)}
.btn.sm{padding:5px 10px;font-size:11.5px}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn.primary:hover{background:#0c4a43}
.btn:disabled{opacity:.45;cursor:not-allowed}
.sendbar{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:6px;
  padding:14px 18px;border-radius:9px;background:var(--ink);color:#fff}
.sendbar .msg{font-size:13px}
.sendbar .msg b{font-weight:600}

/* reports */
.report{background:var(--card);border:1px solid var(--line);border-radius:11px;margin:18px 0;overflow:hidden}
.rhead{display:flex;align-items:center;gap:14px;padding:15px 18px;border-bottom:1px solid var(--line-2);flex-wrap:wrap}
.rhead .subj{font-size:14.5px;font-weight:700;letter-spacing:-.005em}
.rhead .seg{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;
  padding:3px 7px;border-radius:4px;background:var(--accent-soft);color:var(--accent)}
.rhead .seg.fam{background:var(--fam-soft);color:var(--fam)}
.rhead .to{font-size:12px;color:var(--muted)}
.rhead .to b{color:var(--ink-2);font-weight:500}
.rhead .spacer{flex:1}
.approve-tag{display:none;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--ok)}
.report.approved .approve-tag{display:inline-flex}
.report.approved .btn.approve{display:none}
.report.approved{border-color:#bfe3cd}
.btn.copy{display:inline-flex;align-items:center;gap:6px}
.report.approved .btn.copy{background:var(--accent);border-color:var(--accent);color:#fff}
.report.approved .btn.copy:hover{background:#0c4a43}
.btn.whatsapp{background:#25d366;border-color:#25d366;color:#fff}
.btn.whatsapp:hover{background:#1faa50}
.report.approved .btn.whatsapp{background:#25d366;border-color:#25d366}

.note{font-size:12px;color:var(--warn);background:var(--warn-soft);padding:9px 18px;border-bottom:1px solid #f0e2b8}
.tablescroll{overflow-x:auto}
table{border-collapse:collapse;width:100%;font-size:12.5px}
th{font-family:'IBM Plex Sans';font-weight:600;font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;
  color:var(--muted);text-align:left;padding:9px 12px;border-bottom:1px solid var(--line);white-space:nowrap;background:#fafbfc}
td{padding:8px 12px;border-bottom:1px solid var(--line-2);white-space:nowrap}
td.num,th.num{text-align:right;font-family:'IBM Plex Mono',monospace;font-variant-numeric:tabular-nums}
tr.grp td{background:#fafbfc;font-weight:600}
tr.sub td{font-weight:600;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
tr.total td{font-weight:700;background:#f1f4f7;border-top:2px solid var(--ink-2)}
.neg{color:var(--block)}
/* tableview.js: sortable headers + filter box */
th.th-sort{cursor:pointer;user-select:none;position:relative;padding-right:18px}
th.th-sort:hover{color:var(--ink-2);background:#f2f5f8}
th.th-sort::after{content:'⇅';position:absolute;right:6px;opacity:.32;font-size:10px}
th.th-sort.th-asc::after{content:'▲';opacity:.85}
th.th-sort.th-desc::after{content:'▼';opacity:.85}
input.tv-filter{max-width:260px;margin:0 0 8px}
.tv-pager{display:flex;align-items:center;gap:8px;margin:8px 0;flex-wrap:wrap}
.tv-pager .tv-pginfo{font-size:12px}
.tv-pager select.tv-pgsize{padding:3px 6px;font-size:12px}
.tv-pager button[disabled]{opacity:.45;cursor:default}
tbody tr:hover td{background:#f8fafb}
tr.grp:hover td,tr.sub:hover td,tr.total:hover td{background:inherit}
.empty{padding:30px 18px;text-align:center;color:var(--muted);font-size:13px}

/* both-buy-and-sell punching-error flag */
tr.both-sides td{background:#fff7e6 !important}
tr.both-sides:hover td{background:#fff2d6 !important}
tr.warn-row td{padding:0;background:#fff;border-bottom:1px solid var(--line)}
.warn-banner{margin:0;padding:12px 16px;background:var(--warn-soft);border-left:4px solid var(--warn);
  display:flex;flex-direction:column;gap:8px}
.warn-banner .warn-head{font-size:12.5px;color:var(--warn);font-weight:500;line-height:1.5}
.warn-banner .warn-head b{font-weight:700;color:var(--ink)}
.warn-banner .warn-row-input{display:flex;gap:10px;align-items:flex-start;flex-wrap:wrap}
.warn-banner textarea.expl-input{flex:1;min-width:280px;min-height:46px;font-family:inherit;font-size:13px;
  border:1px solid var(--line);border-radius:6px;padding:7px 10px;background:#fff;color:var(--ink);resize:vertical}
.warn-banner textarea.expl-input:focus{outline:none;border-color:var(--accent)}
.warn-banner textarea.expl-input.locked{background:#f4f5f7;color:var(--muted);cursor:not-allowed}
.warn-banner .expl-status{font-size:11.5px;color:var(--muted);min-width:80px;font-weight:600;padding-top:8px}
.warn-banner .flagbox-body{display:flex;flex-direction:column;gap:8px}
.warn-banner .expl-instr{font-size:12px;color:var(--muted)}
.warn-banner .remove-flag{align-self:flex-start;white-space:nowrap}
.flag-pending{font-size:12.5px;color:var(--ink);font-weight:600}
.flag-declined{font-size:12.5px;color:var(--block);font-weight:600}

/* inline approver-authorisation modal */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:100;
  display:flex;align-items:center;justify-content:center;padding:16px}
.modal{background:var(--card);border:1px solid var(--line);border-radius:12px;
  padding:18px 20px;width:100%;max-width:380px;box-shadow:0 20px 50px rgba(0,0,0,.25);
  display:flex;flex-direction:column;gap:6px}
.modal h3{margin:0 0 2px;font-size:15px;font-weight:700}
.modal label{font-weight:500}
.modal select,.modal input,.modal textarea{width:100%;font-family:inherit;font-size:13px;
  border:1px solid var(--line);border-radius:6px;padding:7px 10px;background:#fff;color:var(--ink)}
.modal .m-err{color:var(--block);font-size:12px;min-height:15px;font-weight:600}
.modal .m-actions{display:flex;gap:8px;margin-top:6px}

/* reusable collapsible accordion */
details.acc{border:1px solid var(--line);border-radius:9px;margin-bottom:10px;background:var(--card);overflow:hidden}
details.acc>summary{cursor:pointer;padding:12px 16px;list-style:none;display:flex;gap:12px;
  align-items:center;flex-wrap:wrap;font-size:14px}
details.acc>summary::-webkit-details-marker{display:none}
details.acc>summary::before{content:'▸';color:var(--muted);font-size:11px}
details.acc[open]>summary::before{content:'▾'}
details.acc>summary:hover{background:var(--accent-soft)}
details.acc>summary .sub{color:var(--muted);font-size:12px;font-weight:400}
.acc-body{padding:2px 16px 16px}

/* dashboard */
.active-window{background:var(--accent)!important;color:#fff!important;border-color:var(--accent)!important}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin:12px 0}
.stat-card{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:16px 18px}
.stat-num{font-family:'IBM Plex Mono',monospace;font-size:26px;font-weight:600;color:var(--ink);letter-spacing:-.01em}
.stat-label{font-size:12px;color:var(--muted);margin-top:3px}
.top3-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}
.top3-card{border:1px solid var(--line);border-radius:10px;padding:14px 16px;position:relative;background:var(--accent-soft)}
.top3-rank{position:absolute;top:10px;right:12px;font-weight:700;color:var(--accent);font-size:13px}
.top3-name{font-size:13px;font-weight:600;color:var(--ink);padding-right:24px}
.top3-turn{font-family:'IBM Plex Mono',monospace;font-size:20px;font-weight:600;color:var(--accent);margin-top:6px}
.bar-chart{display:flex;align-items:flex-end;gap:3px;height:170px;padding:6px 0;border-bottom:1px solid var(--line)}
.bar-col{flex:1;height:100%;display:flex;align-items:flex-end;min-width:4px}
.bar{width:100%;background:var(--accent);border-radius:3px 3px 0 0;min-height:2px;opacity:.85}
.bar-col:hover .bar{opacity:1;background:var(--ink)}
.bar-axis{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);margin-top:4px}
.line-chart{position:relative;height:180px;margin-top:8px;border-bottom:1px solid var(--line)}
.line-chart svg{position:absolute;inset:0;width:100%;height:100%;display:block}
.line-area{fill:var(--accent-soft)}
.line-path{fill:none;stroke:var(--accent);stroke-width:2;stroke-linejoin:round;stroke-linecap:round}
.line-hover{position:absolute;inset:0}
.line-dot{position:absolute;width:8px;height:8px;border-radius:50%;background:var(--accent);
  border:2px solid var(--card);transform:translate(-50%,50%);cursor:default}
.line-dot:hover{transform:translate(-50%,50%) scale(1.45)}
.heatmap{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px}
.heat-tile{border:1px solid var(--line);border-radius:8px;padding:10px 12px;color:var(--ink);overflow:hidden}
.heat-tile.hot{color:#fff;border-color:transparent}
.heat-scrip{font-size:12.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.heat-side{font-size:10px;font-weight:600;opacity:.8;margin-left:2px}
.heat-turn{font-family:'IBM Plex Mono',monospace;font-size:15px;font-weight:600;margin-top:2px}
.heat-bs{font-size:10.5px;opacity:.85;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.heat-key{display:inline-block;width:11px;height:11px;border-radius:3px;vertical-align:-1px}
.heat-key.buy{background:rgba(26,127,75,.85)}
.heat-key.sell{background:rgba(163,38,31,.85)}

/* two-up dashboard panels + horizontal bar lists */
.dash-two{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:12px}
.hbars{display:flex;flex-direction:column;gap:7px;margin-top:4px}
.hbar-row{display:flex;align-items:center;gap:10px;font-size:12.5px}
.hbar-label{flex:0 0 130px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--ink-2)}
.hbar-track{flex:1;height:14px;background:var(--line-2);border-radius:7px;overflow:hidden}
.hbar-fill{display:block;height:100%;background:var(--accent);border-radius:7px;min-width:2px}
.hbar-fill.alt{background:var(--fam)}
.hbar-val{flex:0 0 44px;text-align:right;font-family:'IBM Plex Mono',monospace;font-weight:600;color:var(--ink)}

/* role-aware collapsible left sidebar */
.app-shell{display:flex;align-items:flex-start;min-height:100vh}
.sidebar{width:208px;flex-shrink:0;background:var(--card);border-right:1px solid var(--line);
  position:sticky;top:0;height:100vh;display:flex;flex-direction:column;
  transition:width .14s ease;z-index:30}
.sidebar.collapsed{width:56px}
.sidebar-brand{display:flex;align-items:center;gap:10px;padding:12px 12px;min-height:53px;
  border-bottom:1px solid var(--line)}
.sidebar-brand .logo{font-weight:700;font-size:15px;letter-spacing:-.01em;white-space:nowrap;overflow:hidden}
.collapse-btn{flex-shrink:0;width:34px;height:34px;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);border-radius:7px;background:var(--card);color:var(--ink-2);cursor:pointer}
.collapse-btn:hover{background:var(--accent-soft);color:var(--accent)}
.collapse-btn svg{width:18px;height:18px}
.sidebar-nav{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:8px 0;display:flex;flex-direction:column;gap:1px}
.sidebar-foot{flex-shrink:0}
.navlink{display:flex;align-items:center;gap:11px;padding:9px 16px;color:var(--ink-2);
  text-decoration:none;font-size:13px;border-left:3px solid transparent;white-space:nowrap}
.navlink:hover{background:var(--accent-soft);color:var(--ink)}
.navlink.active{color:var(--accent);background:var(--accent-soft);border-left-color:var(--accent);font-weight:600}
.navicon{width:18px;height:18px;flex-shrink:0}
.sidebar.collapsed .sidebar-brand .logo,
.sidebar.collapsed .navlabel{display:none}
.sidebar.collapsed .navlink{justify-content:center;padding:9px 0;gap:0}
.sidebar-foot{border-top:1px solid var(--line);padding:10px 16px;font-size:11px;color:var(--muted)}
.sidebar-foot .ver-short{display:none}
.sidebar.collapsed .sidebar-foot{padding:10px 0;text-align:center}
.sidebar.collapsed .sidebar-foot .ver-full{display:none}
.sidebar.collapsed .sidebar-foot .ver-short{display:inline}
.main-area{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;gap:10px;padding:10px 24px;background:var(--card);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}
.topbar .brand-tag{font-size:13px;font-weight:600;color:var(--ink-2);display:flex;align-items:center;gap:8px}
.topbar-spacer{flex:1}
.main-area > main.wrap{padding-top:6px;padding-bottom:60px;width:100%}

/* segment tag — UNIVERSAL colour rule for EQ / FO / DEBT (and FAMILY bucket).
   Used everywhere a segment is shown (search, scriptwise, clientwise, audit,
   drill-downs). EQ is the base/accent; add a lowercase class for the rest. */
.seg-tag{display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:.06em;padding:2px 6px;border-radius:3px;background:var(--accent-soft);color:var(--accent)}
.seg-tag.eq  {background:var(--accent-soft);color:var(--accent)}
.seg-tag.fo  {background:#fbe9e7;color:#a3261f}
.seg-tag.debt{background:#fdf3da;color:#9a6700}
.seg-tag.fam {background:var(--fam-soft);color:var(--fam)}

/* drill-down flag tags + per-row explanation banner (auditor + owner) */
.flag-tag{display:inline-block;font-size:11px;font-weight:700;padding:1px 5px;border-radius:3px;
  background:var(--warn-soft);color:var(--warn);margin-right:3px}
.drill-expl-row td{padding:0;background:#fff;border-bottom:1px solid var(--line)}
.drill-expl{padding:8px 14px;font-size:12.5px;line-height:1.5;border-left:4px solid var(--warn);background:var(--warn-soft);color:var(--ink-2)}
.drill-expl.ok{border-left-color:var(--ok);background:var(--ok-soft)}
.drill-expl b{color:var(--ink);font-weight:600}

/* flag badge on the audit + clientwise main rows */
.row-flag{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;
  background:var(--warn-soft);color:var(--warn);padding:2px 7px;border-radius:4px;margin-left:6px}
.row-flag.ok{background:var(--ok-soft);color:var(--ok)}

/* double-upload banner */
.double-upload-banner{margin:16px 0 0;padding:14px 18px;border-radius:10px;border:1px solid #ecd79a;
  background:var(--warn-soft);color:var(--warn);font-size:13px}
.double-upload-banner b{color:var(--ink);font-weight:600}

.footnotes{margin:30px 0 0;font-size:12px;color:var(--muted);border-top:1px solid var(--line);padding-top:14px}
.footnotes p{margin-bottom:6px} .footnotes b{color:var(--ink-2)}

/* pick role landing */
.pickrole{margin:60px auto;text-align:center;max-width:560px}
.pickrole h2{font-size:22px;font-weight:700;margin-bottom:6px}
.pickrole p{font-size:13px;margin-bottom:24px}
.pickrole-form{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.pickrole-form .btn{padding:11px 18px}

/* audit + owner forms */
.card{background:var(--card);border:1px solid var(--line);border-radius:11px;padding:22px;margin:22px 0}
.card h2{font-size:15px;font-weight:600;margin-bottom:14px}
.card label{display:block;font-size:12px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.07em;margin-bottom:5px;margin-top:14px}
.card input[type=text],.card input[type=number],.card input[type=date],
.card input[type=email],.card input[type=password],.card input[type=tel],
.card input[type=url],.card input:not([type]),.card textarea,.card select{
  font-family:inherit;font-size:13.5px;border:1px solid var(--line);border-radius:7px;
  padding:10px 12px;background:var(--card);color:var(--ink);width:100%;max-width:520px}
.card input:focus,.card textarea:focus,.card select:focus{
  outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.card textarea{min-height:80px;font-family:inherit;resize:vertical}
.card .row{display:flex;gap:18px;flex-wrap:wrap}
.card .row > div{flex:1;min-width:200px}
.card .actions{margin-top:18px;display:flex;gap:10px}
.checkrow{display:flex;align-items:center;gap:8px;margin-top:8px}
.checkrow input{width:auto;margin:0}

.statusgrid{width:100%;margin-top:8px}
.statusgrid td .ok-dot{color:var(--ok);font-weight:700}
.statusgrid td .miss-dot{color:var(--block);font-weight:700}
.kind-plus{color:var(--ok);font-weight:700}
.kind-minus{color:var(--block);font-weight:700}
