/* ============================================================
   Finance Management System — APP-ONLY components.
   Extends eComma.css. ALL colors via eComma CSS variables (no new palette).
   Operator pref (from eComma reference build): status chips/pills/tags use the
   site's rounded-corner language (6px), NOT 100% capsule.
   Sole intentional exception: #fff text on the saturated --a1..--a9 monogram
   chips (.mono-ico / .dico) — readable in BOTH themes; var(--on-accent) would be
   near-black in dark. Layout / components only.
   ============================================================ */

/* inline monospace numerics (money, codes) */
.mono{font-family:"JetBrains Mono",monospace; font-variant-numeric:tabular-nums}
.hint{font-family:"JetBrains Mono",monospace; font-size:11px; font-weight:400; color:var(--ink-faint)}
.muted{color:var(--ink-faint); font-style:italic}
.pill,.tag,.chip,.estatus,.seg,.preview-badge,.sample-tag,.srcbadge,.frpill{border-radius:6px}

/* ---------- top nav (eComma portal chrome) ---------- */
.topnav{position:sticky; top:0; z-index:60; display:flex; align-items:center; gap:20px;
  padding:0 26px; height:56px; background:var(--card); border-bottom:1px solid var(--line)}
.topnav .brand{font-family:"Space Grotesk",sans-serif; font-weight:700; font-size:17px; letter-spacing:-.01em; color:var(--ink); white-space:nowrap}
.topnav .brand .dot{color:var(--accent)}
.topnav .navlinks{display:flex; gap:4px; flex-wrap:wrap}
.topnav .nl{font-size:13.5px; font-weight:500; color:var(--ink-faint); padding:7px 11px; border-radius:8px; cursor:pointer; white-space:nowrap; text-decoration:none}
.topnav .nl:hover{color:var(--ink); background:var(--line-soft)}
.topnav .nl.active{color:var(--accent); background:color-mix(in srgb,var(--accent) 11%,var(--mix))}
.topnav .spacer{flex:1}
.topnav .who{font-family:"JetBrains Mono",monospace; font-size:11.5px; color:var(--ink-faint); white-space:nowrap}
.topnav .role{font-family:"JetBrains Mono",monospace; font-size:10px; font-weight:600; letter-spacing:.06em; text-transform:uppercase;
  color:var(--accent); background:color-mix(in srgb,var(--accent) 12%,var(--mix)); border:1px solid color-mix(in srgb,var(--accent) 26%,var(--line)); padding:3px 8px; border-radius:6px; white-space:nowrap}
.preview-badge{font-family:"JetBrains Mono",monospace; font-size:10px; font-weight:500; letter-spacing:.08em; text-transform:uppercase;
  color:var(--a4); background:color-mix(in srgb,var(--a4) 13%,var(--mix)); border:1px solid color-mix(in srgb,var(--a4) 28%,var(--line)); padding:4px 9px}
.topnav .theme-toggle{position:static; top:auto; right:auto; width:34px; height:34px; font-size:14px; box-shadow:none; flex:0 0 auto}

/* ---------- page container (full-width finance workspace) ---------- */
.page{max-width:1320px; margin:0 auto; padding:26px 30px 80px}
.page > header{margin-bottom:6px}
.page h1{font-size:30px}

/* ---------- honest design-preview banner ---------- */
.banner{display:flex; gap:12px; align-items:flex-start; margin:16px 0 22px;
  background:color-mix(in srgb,var(--a4) 7%,var(--card)); border:1px solid color-mix(in srgb,var(--a4) 24%,var(--line));
  border-left:3px solid var(--a4); border-radius:var(--radius); padding:13px 16px; font-size:13px; color:var(--ink-soft)}
.banner .bi{color:var(--a4); font-size:15px; flex:0 0 auto}
.banner b{color:var(--ink)}

/* ---------- slicer rail (brand x cost-center) ---------- */
.slicer{display:flex; flex-wrap:wrap; gap:18px; align-items:flex-end; margin:6px 0 8px}
.slicer .grp{display:flex; flex-direction:column; gap:6px}
.slicer .glbl{font-family:"JetBrains Mono",monospace; font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-faint)}
.segs{display:inline-flex; flex-wrap:wrap; gap:6px}
.seg{display:inline-flex; align-items:center; gap:7px; padding:7px 12px;
  background:var(--card); border:1px solid var(--line); color:var(--ink-soft); font-weight:500; font-size:12.5px; cursor:pointer}
.seg:hover{color:var(--ink)}
.seg.on{background:var(--accent); border-color:var(--accent); color:var(--on-accent)}
.seg .c{font-family:"JetBrains Mono",monospace; font-size:10.5px; opacity:.78}
.seg .fdot{width:8px; height:8px; border-radius:50%}

/* ---------- KPI sub-line + sample tag + scope note ---------- */
.kpi .s{font-size:12px; color:var(--ink-faint); margin-top:2px; display:flex; align-items:center; gap:6px}
.kpi .v small{font-size:14px; color:var(--ink-faint); font-weight:600}
.sample-tag{font-family:"JetBrains Mono",monospace; font-size:9px; font-weight:500; letter-spacing:.05em; text-transform:uppercase;
  color:var(--a4); background:color-mix(in srgb,var(--a4) 14%,var(--mix)); padding:1px 6px; border-radius:999px; vertical-align:1px}
.live-tag{font-family:"JetBrains Mono",monospace; font-size:9px; font-weight:500; letter-spacing:.05em; text-transform:uppercase;
  color:var(--pos); background:color-mix(in srgb,var(--pos) 14%,var(--mix)); padding:1px 6px; border-radius:999px; vertical-align:1px}

/* ---------- money cell (currency + USD; never naked) ---------- */
.money{font-family:"JetBrains Mono",monospace; font-variant-numeric:tabular-nums; text-align:right; white-space:nowrap}
.money .usd{color:var(--ink); font-weight:600}
.money .orig{color:var(--ink-faint); font-size:11px}
.money.neg .usd{color:var(--neg)}
.ccy{font-family:"JetBrains Mono",monospace; font-size:10px; color:var(--ink-faint); letter-spacing:.04em}

/* ---------- source provenance badge ---------- */
.srcbadge{font-family:"JetBrains Mono",monospace; font-size:10px; font-weight:500; padding:2px 7px; border:1px solid var(--line); color:var(--ink-soft); background:var(--line-soft); white-space:nowrap}
.srcbadge.xero{color:var(--a1); border-color:color-mix(in srgb,var(--a1) 32%,var(--line)); background:color-mix(in srgb,var(--a1) 10%,var(--mix))}
.srcbadge.shopify{color:var(--a2); border-color:color-mix(in srgb,var(--a2) 32%,var(--line)); background:color-mix(in srgb,var(--a2) 10%,var(--mix))}
.srcbadge.meta{color:var(--a3); border-color:color-mix(in srgb,var(--a3) 32%,var(--line)); background:color-mix(in srgb,var(--a3) 10%,var(--mix))}
.srcbadge.bank{color:var(--a8); border-color:color-mix(in srgb,var(--a8) 32%,var(--line)); background:color-mix(in srgb,var(--a8) 10%,var(--mix))}
.srcbadge.manual{color:var(--ink-faint)}

/* ---------- freshness dots ---------- */
.fresh{display:inline-flex; align-items:center; gap:6px; font-family:"JetBrains Mono",monospace; font-size:11px; color:var(--ink-soft)}
.fdot-s{width:9px; height:9px; border-radius:50%; flex:0 0 auto}
.fdot-s.fresh-ok{background:var(--pos)}
.fdot-s.fresh-stale{background:var(--a4)}
.fdot-s.fresh-dead{background:var(--neg)}

/* ---------- controls row ---------- */
.controls{display:flex; flex-wrap:wrap; gap:9px; align-items:center; margin:8px 0 14px}
.search{position:relative; flex:1; min-width:220px}
.search svg{position:absolute; left:12px; top:50%; transform:translateY(-50%); color:var(--ink-faint)}
.search input{width:100%; padding:10px 13px 10px 35px; border:1px solid var(--line); border-radius:var(--radius);
  background:var(--card); color:var(--ink); font-family:inherit; font-size:13.5px}
.search input:focus{outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--ring)}
select.sel{padding:9px 12px; border:1px solid var(--line); border-radius:var(--radius); background:var(--card);
  color:var(--ink-soft); font-family:inherit; font-size:13px; cursor:pointer}
select.sel:focus{outline:none; border-color:var(--accent)}
.tog{display:inline-flex; align-items:center; gap:8px; padding:8px 11px; border:1px solid var(--line);
  border-radius:var(--radius); background:var(--card); font-size:12.5px; color:var(--ink-soft); cursor:pointer; user-select:none}
.tog input{position:absolute; opacity:0; pointer-events:none}
.swt{width:30px; height:17px; border-radius:999px; background:var(--line); position:relative; transition:background .15s; flex:0 0 auto}
.swt::after{content:""; position:absolute; top:2px; left:2px; width:13px; height:13px; border-radius:50%; background:var(--card); transition:transform .15s; box-shadow:0 1px 2px rgba(2,6,23,.35)}
.tog input:checked + .swt{background:var(--accent)}
.tog input:checked + .swt::after{transform:translateX(13px)}

/* ---------- table (finance) ---------- */
.tablewrap{overflow-x:auto; border:1px solid var(--line); border-radius:var(--radius); background:var(--card)}
.tablewrap table{border:0; border-radius:0}
.tablewrap thead th{position:sticky; top:0; background:var(--card); white-space:nowrap; z-index:1}
.tablewrap thead th.sortable{cursor:pointer}
.tablewrap thead th .ar{opacity:.45; margin-left:3px}
.tablewrap thead th.r,.tablewrap tbody td.r{text-align:right}
.tablewrap tbody td{white-space:nowrap}
.tablewrap tbody tr.clickable{cursor:pointer}
.tablewrap tbody tr.total td{font-weight:700; background:var(--line-soft); border-top:2px solid var(--line)}
.tablewrap tbody tr.subtotal td{font-weight:600; background:color-mix(in srgb,var(--accent) 5%,var(--card))}
.rowhead{display:flex; align-items:center; gap:9px}
.mono-ico{width:24px; height:24px; border-radius:6px; display:grid; place-items:center; flex:0 0 auto;
  font-family:"Space Grotesk",sans-serif; font-weight:700; font-size:10px; color:#fff}
.acctname{font-weight:500; color:var(--ink)}
.acctcode{font-family:"JetBrains Mono",monospace; font-size:10.5px; color:var(--ink-faint)}

/* ---------- EBITDA waterfall / bridge ---------- */
.waterfall{display:flex; align-items:flex-end; gap:10px; height:260px; padding:14px 6px 0; border-bottom:1px solid var(--line); overflow-x:auto}
.wf-col{flex:1; min-width:62px; display:flex; flex-direction:column; align-items:center; justify-content:flex-end; height:100%; gap:8px}
.wf-bar-area{flex:1; width:100%; display:flex; flex-direction:column; justify-content:flex-end; align-items:center; position:relative}
.wf-bar{width:74%; max-width:54px; border-radius:5px 5px 0 0; min-height:3px}
.wf-bar.base{background:var(--accent)}
.wf-bar.add{background:var(--pos)}
.wf-bar.sub{background:var(--neg)}
.wf-bar.result{background:var(--a3)}
.wf-val{font-family:"JetBrains Mono",monospace; font-size:11px; font-weight:600; color:var(--ink); margin-bottom:4px}
.wf-lbl{font-family:"JetBrains Mono",monospace; font-size:10px; color:var(--ink-faint); text-align:center; line-height:1.3; min-height:26px}

/* ---------- aging buckets (AR/AP) ---------- */
.agebar{display:flex; height:12px; border-radius:6px; overflow:hidden; background:var(--line-soft); min-width:130px}
.agebar span{display:block; height:100%}
.age-cur{background:var(--pos)} .age-30{background:var(--a4)} .age-60{background:var(--a8)} .age-90{background:var(--neg)}
.agelegend{display:flex; flex-wrap:wrap; gap:14px; margin:6px 0 0}
.agelegend .al{display:flex; align-items:center; gap:6px; font-family:"JetBrains Mono",monospace; font-size:11px; color:var(--ink-soft)}
.agelegend .sw{width:11px; height:11px; border-radius:3px}

/* ---------- reconciliation tolerance bar ---------- */
.tol{display:flex; align-items:center; gap:8px}
.tol-track{position:relative; width:120px; height:8px; border-radius:999px; background:var(--line-soft); overflow:visible}
.tol-band{position:absolute; top:0; bottom:0; background:color-mix(in srgb,var(--pos) 26%,var(--mix)); border-radius:999px}
.tol-mark{position:absolute; top:-3px; width:3px; height:14px; border-radius:2px; background:var(--ink)}
.tol-mark.over{background:var(--neg)}

/* ---------- connector health cards ---------- */
.conn-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); gap:14px; margin:14px 0}
.conn{background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:16px 18px; display:flex; flex-direction:column; gap:10px}
.conn.warnstate{border-color:color-mix(in srgb,var(--a4) 40%,var(--line))}
.conn.deadstate{border-color:color-mix(in srgb,var(--neg) 40%,var(--line))}
.conn-top{display:flex; align-items:center; gap:10px}
.conn-top .nm{font-family:"Space Grotesk",sans-serif; font-weight:600; font-size:15px}
.conn-top .spacer{flex:1}
.conn-meta{display:flex; flex-direction:column; gap:5px; font-size:12.5px; color:var(--ink-soft)}
.conn-meta .ln{display:flex; justify-content:space-between; gap:10px}
.conn-meta .ln b{font-family:"JetBrains Mono",monospace; font-weight:500; color:var(--ink)}

/* ---------- drawer (eComma styling) ---------- */
.scrim{position:fixed; inset:0; background:color-mix(in srgb,var(--ink) 34%,transparent); opacity:0; pointer-events:none; transition:opacity .22s; z-index:1100}
.scrim.show{opacity:1; pointer-events:auto}
.drawer{position:fixed; top:0; right:0; bottom:0; width:720px; max-width:96vw; background:var(--paper);
  box-shadow:-26px 0 70px rgba(2,6,23,.30); transform:translateX(100%); transition:transform .26s cubic-bezier(.4,0,.2,1);
  z-index:1200; display:flex; flex-direction:column; border-left:1px solid var(--line)}
.drawer.show{transform:translateX(0)}
.dhead{padding:22px 26px 16px; border-bottom:1px solid var(--line); background:var(--card)}
.dhead-top{display:flex; align-items:flex-start; gap:14px}
.dhead .dico{width:44px; height:44px; border-radius:11px; display:grid; place-items:center; flex:0 0 auto;
  font-family:"Space Grotesk",sans-serif; font-weight:700; font-size:14px; color:#fff}
.dhead .eyebrow{margin:0 0 6px}
.dhead h1{font-size:24px; margin:0}
.dhead .dx{margin-left:auto; width:32px; height:32px; border-radius:9px; display:grid; place-items:center;
  color:var(--ink-faint); cursor:pointer; border:1px solid var(--line); background:var(--card); flex:0 0 auto}
.dhead .dx:hover{color:var(--ink)}
.dpills{display:flex; flex-wrap:wrap; gap:7px; margin:14px 0 0}
.dactions{display:flex; gap:9px; margin:16px 0 2px; flex-wrap:wrap}
.dactions .btn{padding:9px 16px}
.db{flex:1; overflow-y:auto; padding:8px 26px 28px}
.dgrid{display:grid; grid-template-columns:repeat(2,1fr); gap:12px; margin:14px 0 6px}
.dtile{background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:13px 15px}
.dtile .k{font-family:"JetBrains Mono",monospace; font-size:10px; letter-spacing:.07em; text-transform:uppercase; color:var(--ink-faint)}
.dtile .v{font-family:"Space Grotesk",sans-serif; font-weight:600; font-size:20px; line-height:1.15; margin-top:6px}
.dstat{display:flex; justify-content:space-between; gap:14px; padding:8px 0; border-bottom:1px solid var(--line-soft); font-size:13px; color:var(--ink-soft)}
.dstat:last-child{border-bottom:0}
.dstat b{color:var(--ink); text-align:right; font-weight:600; font-family:"JetBrains Mono",monospace}
.dstat a{color:var(--accent)}
.prov{font-family:"JetBrains Mono",monospace; font-size:10.5px; color:var(--ink-faint); margin-top:8px; line-height:1.5}

/* ---------- estatus pending ---------- */
.estatus{font-family:"JetBrains Mono",monospace; font-size:11px; padding:3px 9px}
.estatus.pending{color:var(--ink-faint); background:var(--line-soft)}
.estatus.flagged{color:var(--neg); background:color-mix(in srgb,var(--neg) 13%,var(--mix))}

/* ---------- responsive ---------- */
@media (max-width:1100px){ .dgrid{grid-template-columns:1fr} }
@media (max-width:760px){
  .drawer{width:100vw} .topnav{gap:10px; padding:0 14px; height:auto; flex-wrap:wrap; padding-top:10px; padding-bottom:10px}
  .topnav .navlinks{order:3; width:100%} .page{padding:20px 14px 60px}
}
