/* ---- vendored fonts (offline) ---- */
@font-face{font-family:"Fraunces";src:url("vendor/fonts/fraunces-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"InterDM";src:url("vendor/fonts/inter-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"InterDM";src:url("vendor/fonts/inter-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"InterDM";src:url("vendor/fonts/inter-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}

/* ============================================================
   DM Receipts — shared design system (refined dark, monochrome)
   Brand is neutral (logo #231f20). One swappable accent: --brand.
   Used by index.html (PWA) and backend.html (admin console).
   ============================================================ */
:root{
  --bg:#0A0B0D;
  --surface:#131418;
  --surface-2:#0E0F12;
  --elev:#1A1C22;
  --line:rgba(255,255,255,.07);
  --line-2:rgba(255,255,255,.13);
  --text:#ECEDEF;
  --text-2:#9DA3AE;
  --muted:#686E78;
  --accent:#ECEDEF;        /* primary button fill (near-white) */
  --accent-ink:#0B0C0E;    /* text on accent */
  --brand:#ECEDEF;         /* identity accent — swap to a DM hex anytime */
  --ok:#6FB98C; --okbg:rgba(111,185,140,.12); --okbd:rgba(111,185,140,.30);
  --warn:#D6A24B; --warnbg:rgba(214,162,75,.12); --warnbd:rgba(214,162,75,.30);
  --bad:#D7706A; --badbg:rgba(215,112,106,.12); --badbd:rgba(215,112,106,.32);
  --info:#8AA0B8; --infobg:rgba(138,160,184,.12); --infobd:rgba(138,160,184,.30);
  --r:12px; --r-lg:16px; --r-sm:9px;
  --shadow:0 1px 0 rgba(255,255,255,.02) inset, 0 10px 34px rgba(0,0,0,.45);
  --font:"InterDM",system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --font-serif:"Fraunces",Georgia,"Times New Roman",serif;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{background:var(--bg);color:var(--text);font:15px/1.55 var(--font);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;letter-spacing:-.006em}
::selection{background:rgba(236,237,239,.18)}
a{color:var(--text);text-decoration:none;border-bottom:1px solid var(--line-2)}
a:hover{color:#fff}
h1,h2,h3{letter-spacing:-.022em;font-weight:600;margin:0}
.amt,.kpi .n,.item .amt,td.r,th.r,.pill,.num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}
.muted{color:var(--muted)} .right{margin-left:auto} .grow{flex:1} .hidden{display:none!important}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#23262d;border-radius:8px;border:2px solid var(--bg)}
::-webkit-scrollbar-track{background:transparent}

/* icons */
.ic{display:inline-flex;align-items:center;justify-content:center}
.ic svg,.btn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;flex:none}
nav.tabs .ic svg,nav.side .ic svg{width:21px;height:21px;stroke-width:1.6}

/* buttons */
.btn{appearance:none;border:1px solid var(--line-2);background:transparent;color:var(--text);
  padding:9px 14px;border-radius:var(--r-sm);font:inherit;font-weight:600;cursor:pointer;
  display:inline-flex;align-items:center;gap:8px;transition:background .15s,border-color .15s,opacity .15s;letter-spacing:-.01em}
.btn:hover{background:var(--elev);border-color:var(--line-2)}
.btn.primary{background:var(--accent);color:var(--accent-ink);border-color:transparent}
.btn.primary:hover{background:#fff}
.btn.ghost{border-color:transparent;color:var(--text-2)}
.btn.ghost:hover{color:var(--text);background:var(--elev)}
.btn.block{width:100%;justify-content:center}
.btn.sm{padding:6px 10px;font-size:12px;border-radius:8px}
.btn.ok{color:var(--ok);border-color:var(--okbd)} .btn.ok:hover{background:var(--okbg)}
.btn.bad{color:var(--bad);border-color:var(--badbd)} .btn.bad:hover{background:var(--badbg)}
.btn:disabled{opacity:.45;cursor:not-allowed}

/* form controls */
input,select,textarea{width:100%;background:var(--surface-2);border:1px solid var(--line);color:var(--text);
  padding:10px 11px;border-radius:var(--r-sm);font:inherit;transition:border-color .15s,box-shadow .15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--line-2);box-shadow:0 0 0 3px rgba(236,237,239,.06)}
textarea{min-height:70px;resize:vertical}
label.fld{display:block;margin:10px 0 5px;font-size:12px;color:var(--text-2)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:520px){.grid2{grid-template-columns:1fr}}
.row{display:flex;gap:10px;flex-wrap:wrap}.row.tight{gap:8px}

/* cards / panels */
.card,.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px;margin-bottom:16px;box-shadow:var(--shadow)}
.card h2,.panel h2{font-size:15px;margin:0 0 3px}
.card p.hint,.panel .hint{color:var(--text-2);font-size:13px;margin:0 0 14px}
.panel .head{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.panel .head h2{margin:0}

/* chips */
.chip{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;border:1px solid var(--line);background:var(--elev);color:var(--text-2);white-space:nowrap;letter-spacing:0}
.chip.ok{color:var(--ok);border-color:var(--okbd);background:var(--okbg)}
.chip.warn{color:var(--warn);border-color:var(--warnbd);background:var(--warnbg)}
.chip.bad{color:var(--bad);border-color:var(--badbd);background:var(--badbg)}
.chip.inv,.chip.matched{color:var(--info);border-color:var(--infobd);background:var(--infobg)}

/* tables */
table{width:100%;border-collapse:collapse;font-size:13px}
th,td{text-align:left;padding:10px;border-bottom:1px solid var(--line);vertical-align:middle}
th{color:var(--muted);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.06em}
td.r,th.r{text-align:right}
tbody tr{transition:background .12s}
tbody tr:hover td{background:var(--surface-2)}

/* progress */
.progress{height:6px;background:var(--surface-2);border-radius:999px;overflow:hidden;border:1px solid var(--line);margin-top:10px;display:none}
.progress>i{display:block;height:100%;width:0;background:var(--text);transition:width .2s}
.ocrstat,.stat-line{font-size:12px;color:var(--text-2);margin-top:8px;min-height:16px}

/* empty state */
.empty{text-align:center;color:var(--muted);padding:34px 12px}
.empty .big{display:flex;justify-content:center;margin-bottom:10px;opacity:.5}
.empty .big svg{width:34px;height:34px;stroke:currentColor;fill:none;stroke-width:1.4}

/* ---------- PWA (index.html) ---------- */
header.app{position:sticky;top:0;z-index:20;background:rgba(10,11,13,.86);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);padding:14px 16px;display:flex;align-items:center;gap:12px}
header.app .brandmark{height:18px;width:auto;display:block}
header.app .appname{font-size:12px;color:var(--muted);border-left:1px solid var(--line-2);padding-left:11px;letter-spacing:.02em}
.pill{font-size:11px;color:var(--text-2);background:var(--elev);border:1px solid var(--line);padding:5px 10px;border-radius:999px}
main{max-width:860px;margin:0 auto;padding:18px 16px 96px}
.view{display:none}.view.active{display:block;animation:fade .18s ease}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.drop{border:1px dashed var(--line-2);border-radius:var(--r);padding:22px;text-align:center;color:var(--text-2);background:var(--surface-2);cursor:pointer;transition:.15s}
.drop:hover{border-color:var(--text-2);color:var(--text)}
.preview{margin-top:12px;display:none}.preview img{max-width:100%;border-radius:var(--r);border:1px solid var(--line)}
.item{display:flex;gap:12px;align-items:center;padding:11px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface-2);margin-bottom:9px}
.item .thumb{width:46px;height:46px;border-radius:var(--r-sm);object-fit:cover;background:var(--bg);border:1px solid var(--line);flex:none;display:grid;place-items:center;color:var(--muted);font-size:10px}
.item .meta{flex:1;min-width:0}.item .meta .t{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.item .meta .s{font-size:12px;color:var(--text-2)}.item .amt{font-weight:600;white-space:nowrap}
.item input[type=checkbox]{width:18px;height:18px;accent-color:var(--text)}
.stat{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:12px}
.stat .box{flex:1;min-width:120px;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r);padding:13px}
.stat .box .n{font-size:22px;font-weight:600}.stat .box .l{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-top:2px}
nav.tabs{position:fixed;bottom:0;left:0;right:0;z-index:30;display:flex;background:rgba(14,15,18,.94);border-top:1px solid var(--line);backdrop-filter:blur(12px);padding:6px 6px env(safe-area-inset-bottom)}
nav.tabs button{flex:1;background:none;border:0;color:var(--muted);padding:7px 4px;font-size:11px;font-weight:600;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;border-radius:10px;position:relative}
nav.tabs button.active{color:var(--text)}
nav.tabs button.active::after{content:"";position:absolute;top:-7px;width:22px;height:2px;border-radius:2px;background:var(--brand)}
.toast{position:fixed;left:50%;bottom:104px;transform:translateX(-50%) translateY(20px);opacity:0;background:#16181d;border:1px solid var(--line-2);color:var(--text);padding:11px 16px;border-radius:var(--r);box-shadow:var(--shadow);z-index:50;transition:.25s;font-size:13px;max-width:90%}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.banner{display:none;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--line-2);border-left:2px solid var(--brand);border-radius:var(--r);padding:12px 14px;margin-bottom:16px}
.banner.show{display:flex}.banner .x{margin-left:auto;cursor:pointer;color:var(--muted)}
details summary{cursor:pointer;color:var(--text-2);font-size:12px}

/* ---------- Admin (backend.html) ---------- */
body.admin{display:flex}
aside{width:220px;flex:none;background:var(--surface-2);border-right:1px solid var(--line);height:100vh;position:sticky;top:0;display:flex;flex-direction:column;padding:18px 12px}
.brand{display:flex;gap:10px;align-items:center;padding:4px 8px 18px}
.brand .brandmark{height:17px;width:auto}
.brand .sub{font-size:11px;color:var(--muted);margin-top:3px}
nav.side{display:flex;flex-direction:column;gap:2px;margin-top:4px}
nav.side button{display:flex;align-items:center;gap:11px;background:none;border:0;color:var(--text-2);padding:9px 11px;border-radius:10px;font:inherit;font-weight:600;cursor:pointer;text-align:left;width:100%;letter-spacing:-.01em}
nav.side button:hover{background:var(--elev);color:var(--text)}
nav.side button.active{background:var(--elev);color:var(--text);box-shadow:inset 2px 0 0 var(--brand)}
nav.side button .badge{margin-left:auto;background:var(--bad);color:#fff;font-size:10px;font-weight:700;padding:1px 7px;border-radius:999px;display:none}
nav.side button .badge.show{display:inline-block}
aside .foot{margin-top:auto;font-size:11px;color:var(--muted);padding:12px 8px 2px;border-top:1px solid var(--line)}
aside .foot .dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--ok);margin-right:6px}
main.adminmain{flex:1;min-width:0;max-width:none;margin:0;padding:0;height:100vh;overflow:auto}
header.top{position:sticky;top:0;z-index:10;background:rgba(10,11,13,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);padding:16px 24px;display:flex;align-items:center;gap:14px}
header.top h1{font-size:18px}header.top .crumb{font-size:12px;color:var(--muted);margin-top:2px}
.content{padding:26px 44px 72px;max-width:1380px;width:100%;margin:0 auto}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(168px,1fr));gap:14px;margin-bottom:18px}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px;box-shadow:var(--shadow);min-width:0}
.kpi .l{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.kpi .n{font-size:clamp(18px,1.7vw,26px);font-weight:600;margin-top:5px;letter-spacing:-.02em;overflow-wrap:anywhere;word-break:break-word}
.kpi .n.warn{color:var(--warn)} .kpi .n.bad{color:var(--bad)} .kpi .n.ok{color:var(--ok)}
.kpi .d{font-size:11px;color:var(--text-2);margin-top:3px}
.bars{display:flex;align-items:flex-end;gap:14px;height:150px;padding:10px 4px 0}
.bars .b{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;justify-content:flex-end}
.bars .b .bar{width:100%;max-width:46px;background:var(--text-2);border-radius:5px 5px 0 0;min-height:3px;transition:.3s}
.bars .b:last-child .bar{background:var(--text)}
.bars .b .v,.bars .b .lab{font-size:10px;color:var(--muted)}
.feed{list-style:none;margin:0;padding:0}
.feed li{display:flex;gap:10px;padding:9px 0;border-bottom:1px solid var(--line);font-size:13px;align-items:center}
.feed li:last-child{border:0}.feed .t{color:var(--muted);font-size:11px;white-space:nowrap}
.avatar{width:28px;height:28px;border-radius:50%;display:inline-grid;place-items:center;font-size:11px;font-weight:700;color:var(--text);background:var(--elev);border:1px solid var(--line-2);margin-right:8px;vertical-align:middle}
.thumb{width:40px;height:40px;border-radius:var(--r-sm);object-fit:cover;border:1px solid var(--line);background:var(--bg);display:grid;place-items:center;color:var(--muted);font-size:10px}
.folder{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.file{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r);padding:11px;cursor:pointer;transition:.15s}
.file:hover{border-color:var(--line-2);background:var(--elev)}
.file .fi{color:var(--text-2)}.file .fi svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.5}
.file .fn{font-size:12px;margin-top:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file .fm{font-size:11px;color:var(--muted)}
/* hamburger (hidden on desktop) */
.navtoggle{display:none;align-items:center;justify-content:center;width:38px;height:38px;flex:none;padding:0;border:1px solid var(--line);border-radius:9px;background:var(--surface-2);color:var(--text);cursor:pointer}
.navtoggle svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2}
#navScrim{display:none}

/* ---- admin console on mobile: off-canvas drawer + natural scroll ---- */
@media(max-width:860px){
  body.admin{display:block}
  .navtoggle{display:inline-flex}
  aside{position:fixed;z-index:60;top:0;left:0;height:100vh;width:266px;transform:translateX(-100%);transition:transform .25s ease;box-shadow:0 0 50px rgba(0,0,0,.55);border-right:1px solid var(--line-2)}
  aside.open{transform:none}
  #navScrim{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:55}
  #navScrim.show{display:block}
  main.adminmain{height:auto;min-height:100vh;overflow:visible}
  header.top{padding:12px 14px;gap:10px}
  header.top h1{font-size:16px}
  header.top .crumb{font-size:11px}
  .content{padding:16px 14px 72px}
  .panel,.card{padding:14px}
  #globalMonth{font-size:12px;padding:7px 26px 7px 10px}
}

/* ---- brand lockup (financius) ---- */
.brandrow{display:flex;align-items:baseline;gap:9px;min-width:0}
.wordmark{font-family:var(--font-serif);font-weight:600;color:var(--text);line-height:1;letter-spacing:-.012em}
.tagline{font-family:var(--font);font-weight:400;color:var(--text-2);letter-spacing:.005em;white-space:nowrap}
header.app .wordmark{font-size:21px}
header.app .tagline{font-size:12px}
@media(max-width:430px){header.app .tagline{display:none}}
aside .brand{flex-direction:column;align-items:flex-start;gap:0}
aside .brand .wordmark{font-size:20px}
aside .brand .tagline{font-size:11px;margin-top:3px}

/* ---- org switcher (admin top bar) ---- */
.orgbar{display:flex;align-items:center;gap:8px}
.orgbar .lbl{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
select.orgswitch{width:auto;min-width:150px;font-weight:600}
.orgpill{font-size:11px;color:var(--text-2);background:var(--elev);border:1px solid var(--line);padding:5px 10px;border-radius:999px;white-space:nowrap}

/* ---- sidebar organisation block ---- */
.orgblock{display:flex;flex-direction:column;gap:8px;padding:14px 10px 16px;margin:8px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.orgblock .orglabel{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.orgblock select.orgswitch{width:100%;font-weight:600;font-size:14px;padding:10px 34px 10px 12px;background-color:var(--elev)}
.orgblock .btn{width:100%;justify-content:center;color:var(--text-2);border-style:dashed}
.orgblock .btn:hover{color:var(--text);border-style:solid}

/* ---- sidebar account block ---- */
.account{margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}
.account .acctline{display:flex;align-items:center;gap:9px;margin-bottom:9px}
.account .avatar{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:12px;color:var(--text);background:var(--elev);border:1px solid var(--line-2);flex:none}
.account .acctname{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:130px}
.account .acctmail{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}
.account .acctbtns{display:flex;gap:6px}
.account .acctbtns .btn{flex:1;justify-content:center}

/* ---- login overlay ---- */
.loginov{position:fixed;inset:0;z-index:2000;background:#08090B;display:none;align-items:center;justify-content:center;padding:24px}
.logincard{width:100%;max-width:384px;background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:34px 32px 24px;box-shadow:0 30px 90px rgba(0,0,0,.6)}
.logincard .brand{display:flex;flex-direction:column;align-items:flex-start;gap:3px;margin-bottom:0}
.logincard .wordmark{font-size:30px;line-height:1}
.logincard .tagline{font-size:12.5px;margin-left:1px}
.loginsub{font-size:13px;color:var(--text-2);margin:16px 0 22px;padding-bottom:20px;border-bottom:1px solid var(--line)}
.logincard .field{margin-bottom:15px}
.logincard label.fld{margin:0 0 6px;font-size:12px;color:var(--text-2)}
.logincard input{padding:12px 13px;font-size:14px;background:var(--surface-2)}
.logincard input:focus{border-color:var(--line-2);box-shadow:0 0 0 3px rgba(236,237,239,.07)}
.logincard .btn.primary{margin-top:4px;padding:12px;font-size:14px}
.loginerr{color:var(--bad);font-size:12px;min-height:15px;margin:2px 0 6px}
.loginhint{font-size:11px;color:var(--muted);text-align:center;margin-top:20px;padding-top:15px;border-top:1px solid var(--line)}

/* ---- PWA account footer ---- */
.pwafoot{display:flex;align-items:center;justify-content:center;gap:12px;margin:6px 0 4px;font-size:12px;color:var(--muted)}
.pwafoot .btn{padding:5px 9px}

/* ---- refined select (custom caret, no native chrome) ---- */
select{
  -webkit-appearance:none;appearance:none;cursor:pointer;
  padding:10px 34px 10px 12px;line-height:1.2;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239DA3AE' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>");
  background-repeat:no-repeat;background-position:right 11px center;background-size:15px;
}
select:hover{border-color:var(--line-2)}
select::-ms-expand{display:none}
option{background:var(--surface);color:var(--text)}

/* ===================== SIDEBAR REDESIGN ===================== */
aside{width:224px;padding:20px 14px 16px}
aside .brand{padding:2px 8px 16px;margin-bottom:6px;border-bottom:1px solid var(--line)}
aside .brand .wordmark{font-size:20px}
aside .brand .tagline{font-size:11px;margin-top:3px;color:var(--muted)}

.orgblock{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:11px;margin:0 0 16px;gap:8px}
.orgblock .orglabel{font-size:10px;letter-spacing:.08em}
.orgblock select.orgswitch{background-color:var(--surface-2);font-size:13.5px}
.orgblock .btn{font-size:12px;padding:8px}

.navlabel{font-size:10px;text-transform:uppercase;letter-spacing:.09em;color:var(--muted);padding:0 12px;margin:2px 0 8px}
nav.side{gap:3px;margin-top:0}
nav.side button{position:relative;gap:12px;padding:10px 12px;border-radius:10px;font-size:13.5px;font-weight:500;color:var(--text-2)}
nav.side button .ic{color:var(--muted);transition:color .15s}
nav.side button:hover{background:var(--elev);color:var(--text)}
nav.side button:hover .ic{color:var(--text-2)}
nav.side button.active{background:var(--elev);color:var(--text);box-shadow:none}
nav.side button.active .ic{color:var(--text)}
nav.side button.active::before{content:"";position:absolute;left:3px;top:9px;bottom:9px;width:3px;border-radius:3px;background:var(--brand)}

aside .foot{margin-top:auto;padding-top:14px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:11px;font-size:11px}
.account{margin-top:0;padding:11px;border:1px solid var(--line);border-radius:12px;background:var(--surface)}
.account .acctbtns{margin-top:10px}
.statusrow{display:flex;align-items:center;gap:7px;color:var(--muted);padding:0 4px}
.statusrow .dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--ok);flex:none}
.statusrow .grow{flex:1}
.statusrow .sep{opacity:.45}
.statusrow a,.linkbtn{color:var(--text-2);border:0;background:none;font:inherit;font-size:11px;cursor:pointer;padding:0;text-decoration:none}
.statusrow a:hover,.linkbtn:hover{color:var(--text)}

/* ===== People management + roles + modal ===== */
.chip.role-owner{color:#E6C07A;border-color:rgba(230,192,122,.30);background:rgba(230,192,122,.12)}
.chip.role-admin{color:var(--info);border-color:var(--infobd);background:var(--infobg)}
.chip.role-staff{color:var(--text-2);background:var(--elev)}
.chip.off{color:var(--bad);border-color:var(--badbd);background:var(--badbg)}
.orgtag{font-size:12px;color:var(--text-2);background:var(--elev);border:1px solid var(--line);padding:6px 11px;border-radius:999px;font-weight:500;white-space:nowrap}
.modal{position:fixed;inset:0;z-index:1500;background:rgba(5,8,12,.72);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;padding:22px}
.modal.show{display:flex}
.modalcard{width:100%;max-width:430px;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:22px 22px 18px;box-shadow:0 30px 80px rgba(0,0,0,.55)}
.modalcard h3{font-size:16px;margin:0 0 16px}
.modalcard .field{margin-bottom:13px}
.modalcard label.fld{margin:0 0 6px}
.modalcard .mrow{display:flex;gap:10px;align-items:center;margin-top:18px}
.modalcard .mrow .grow{flex:1}

/* ===== Mailbox (email forwarding) ===== */
.mailaddr{display:flex;align-items:center;gap:12px;background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:12px 14px}
.mailaddr code.addr{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;color:var(--text)}
.mailaddr .btn{margin-left:auto}

/* ===== Dashboard widgets (draggable) ===== */
.dashbar{display:flex;align-items:center;margin-bottom:10px}
.widgetgrid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}
@media(max-width:980px){.widgetgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.widgetgrid{grid-template-columns:1fr}}
.widget{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow);position:relative;min-width:0;display:flex;flex-direction:column}
.widget.w2{grid-column:span 2}.widget.w4{grid-column:span 4}
@media(max-width:980px){.widget.w2,.widget.w4{grid-column:span 2}}
@media(max-width:680px){.widget.w2,.widget.w4{grid-column:span 1}}
.widget .wh{display:flex;align-items:center;gap:8px;margin-bottom:12px;cursor:grab}
.widget .wh .wt{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.07em}
.widget .wh .drag{margin-left:auto;color:var(--muted);opacity:.45;font-size:13px;letter-spacing:1px}
.widget.dragging{opacity:.35}
.widget.over{outline:2px dashed var(--line-2);outline-offset:2px}
.widget:not(.w2):not(.w4){min-height:124px}
.widget .big{font-size:clamp(26px,2.1vw,34px);font-weight:600;letter-spacing:-.025em;line-height:1.05;overflow-wrap:anywhere;word-break:break-word;margin-top:auto}
.widget .big.knock{color:var(--warn)}
.widget .sub{font-size:12px;color:var(--text-2);margin-top:4px;overflow-wrap:anywhere}
.widget .feed{margin-top:-2px}
.catbar{height:6px;background:var(--surface-2);border-radius:4px;margin-top:4px;overflow:hidden}
.catbar i{display:block;height:100%;background:var(--text-2)}

/* compact org switcher in sidebar foot */
.orgblock{flex-direction:row;align-items:center;gap:8px;padding:8px 10px;margin:0 0 12px}
.orgblock .orglabel{font-size:10px}
.orgblock select.orgswitch{flex:1;font-size:13px;padding:8px 30px 8px 10px}

/* separate Settings as a utility item at the bottom of the nav */
nav.side .navsep{height:1px;background:var(--line);margin:10px 10px 8px}

/* ---- statement itemized: keep wide rich table inside its panel ---- */
.tablewrap{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch}
#itemTable{min-width:880px}
#itemTable th,#itemTable td{vertical-align:top;padding-top:10px;padding-bottom:10px}
#itemTable tbody tr{transition:background .12s}
#itemTable tbody tr:hover{background:var(--elev)}
#itemTable td.dsc{max-width:210px}
#itemTable td.dtl{max-width:440px}
#itemTable td.dtl>div{max-width:440px;word-break:break-word}
/* full details laid out inline — no hover/expand needed */
#itemTable td.dtl .det{display:block;margin-bottom:2px;color:var(--text-2)}
#itemTable td.dtl .raw{font-size:11px;color:var(--muted);line-height:1.45;white-space:normal;word-break:break-word}
#itemTable td .chip{font-size:10px}
#itemTable td input{cursor:text}


/* ---- splash screen ---- */
#splash{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(120% 120% at 50% 40%, #14161a 0%, var(--bg,#0A0B0D) 70%);
  animation:splashOut .7s ease 1.7s forwards}
#splash .splashinner{display:flex;flex-direction:column;align-items:center;gap:14px;animation:splashIn .7s cubic-bezier(.2,.8,.2,1) both}
#splash .splashlogo{width:min(150px,38vw);height:auto;filter:invert(1);opacity:.88}
#splash .splashrule{width:120px;height:1.5px;background:rgba(255,255,255,.1);border-radius:2px;overflow:hidden}
#splash .splashrule i{display:block;height:100%;width:40%;background:var(--brand,#c9a24b);border-radius:2px;animation:splashBar 1.6s ease-in-out infinite}
@keyframes splashIn{from{opacity:0;transform:translateY(8px) scale(.99)}to{opacity:1;transform:none}}
@keyframes splashOut{to{opacity:0;visibility:hidden;pointer-events:none}}
@keyframes splashBar{0%{transform:translateX(-110%)}100%{transform:translateX(360%)}}
@media(prefers-reduced-motion:reduce){#splash{animation:splashOut .3s linear 1.2s forwards}#splash .splashrule i{animation:none}}


/* ---- brand logo (replaces text wordmark on all pages) ---- */
.brandlogo{display:block;height:auto;margin:0 auto;filter:invert(1);opacity:.95}
aside .brand{display:flex;justify-content:center;padding:6px 4px 2px}
aside .brand .brandlogo{width:108px;opacity:.9}
header.app .brandrow{position:absolute;left:50%;transform:translateX(-50%)}
header.app .brandrow .brandlogo{width:92px;opacity:.9}
.logincard .brand{display:flex;justify-content:center;margin-bottom:6px}
.logincard .brandlogo{width:112px;opacity:.92}
@media(max-width:430px){header.app .brandrow .brandlogo{width:80px}}


/* ---- settings cog at bottom-left of sidebar ---- */
.statusrow .cogbtn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;padding:0;margin-right:9px;border:0;border-radius:7px;background:none;color:var(--muted);cursor:pointer;flex:none}
.statusrow .cogbtn:hover{background:var(--elev);color:var(--text)}
.statusrow .cogbtn.active{color:var(--brand)}
.statusrow .cogbtn svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:1.6}


/* ---- sidebar footer (clean) ---- */
aside .foot{margin-top:auto;padding-top:12px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:9px}
.acctcard{display:flex;align-items:center;gap:5px;padding:6px;border:1px solid var(--line);border-radius:11px;background:var(--surface)}
.acctcard .acctmain{display:flex;align-items:center;gap:9px;flex:1;min-width:0;cursor:pointer;border-radius:8px;padding:3px 4px}
.acctcard .acctmain:hover{background:var(--elev)}
.acctcard .avatar{flex:none;margin:0;width:30px;height:30px}
.acctcard .acctmeta{min-width:0;line-height:1.25}
.acctcard .acctname{font-size:12.5px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:108px}
.acctcard .acctmail{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:108px}
.acctcard .cogbtn{flex:none;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:8px;background:none;color:var(--muted);cursor:pointer;padding:0}
.acctcard .cogbtn:hover{background:var(--elev);color:var(--text)}
.acctcard .cogbtn.active{color:var(--brand)}
.acctcard .cogbtn.danger:hover{color:var(--bad)}
.acctcard .cogbtn svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:1.7}
.footbar{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--muted);padding:0 5px}
.footbar .dot{width:7px;height:7px;border-radius:50%;background:var(--ok);flex:none}
.footbar .grow{flex:1}
.footbar a{color:var(--text-2);text-decoration:none}
.footbar a:hover{color:var(--text)}


/* header month picker: size to content ("Jul 2025"), not full width */
header.top #globalMonth{width:auto;min-width:0;flex:none;padding:8px 30px 8px 12px;font-size:13px;font-weight:600}


/* ---- theatre / lightbox preview (images + PDFs in-app) ---- */
.theatre{position:fixed;inset:0;z-index:1000;display:none;flex-direction:column;background:rgba(6,7,9,.93);backdrop-filter:blur(7px);padding:18px 20px 20px;animation:fade .15s ease}
.theatre.show{display:flex}
.theatre .theatrebar{display:flex;align-items:center;gap:10px;padding:2px 4px 12px}
.theatre .theatrebar .grow{flex:1}
.theatre .tname{font-size:13px;color:var(--text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:58vw}
.theatre .theatrebody{flex:1;min-height:0;display:flex;align-items:center;justify-content:center}
.theatre .theatrebody img{max-width:100%;max-height:100%;object-fit:contain;border-radius:10px;box-shadow:0 24px 70px rgba(0,0,0,.6)}
.theatre .theatrebody iframe{width:100%;height:100%;border:0;border-radius:10px;background:#fff;box-shadow:0 24px 70px rgba(0,0,0,.6)}

#itemTable td.dtl .code{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.03em;color:var(--text-2);background:var(--elev);border:1px solid var(--line);border-radius:5px;padding:0 5px;margin-right:2px}

#itemTable td.typ{white-space:normal;max-width:180px}
#itemTable td.typ .typechip{display:inline-block;font-size:10.5px;background:var(--elev);border:1px solid var(--line);color:var(--text-2);border-radius:6px;padding:2px 7px;margin-right:4px}
#itemTable td.typ .code{vertical-align:middle}

#itemTable td.typ .codeline{margin-top:5px;display:flex;align-items:baseline;gap:5px;flex-wrap:wrap}
#itemTable td.typ .codename{font-size:10.5px;color:var(--muted);line-height:1.3}

#itemTable td.dtl .payee{margin-bottom:3px}
#itemTable td.dtl .payee .who{font-weight:700;color:var(--text)}
#itemTable td.dtl .payee .payee-assign{color:var(--brand);font-size:11px}


/* ---- in-app live camera (PWA scanner) ---- */
.camview{position:fixed;inset:0;z-index:1000;display:none;background:#000}
.camview.show{display:block}
.camview video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.camview .camframe{position:absolute;left:7%;right:7%;top:14%;bottom:20%;border:2px dashed rgba(255,255,255,.7);border-radius:14px;box-shadow:0 0 0 100vmax rgba(0,0,0,.25);pointer-events:none}
.camview .camhint{position:absolute;top:calc(14% - 34px);left:0;right:0;text-align:center;color:#fff;font-size:13px;text-shadow:0 1px 4px rgba(0,0,0,.7);padding:0 16px}
.camview .cambar{position:absolute;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 22px calc(20px + env(safe-area-inset-bottom));background:linear-gradient(to top,rgba(0,0,0,.65),transparent)}
.camview .camshutter{width:68px;height:68px;border-radius:50%;background:#fff;border:4px solid rgba(255,255,255,.45);cursor:pointer;flex:none;box-shadow:0 2px 10px rgba(0,0,0,.4)}
.camview .camshutter:active{transform:scale(.94)}
.camview .camspacer{width:64px;flex:none}
.camview .btn.ghost{color:#fff;border-color:rgba(255,255,255,.4);background:rgba(0,0,0,.25)}
