/* ============================================================
   Ledgerline ERP — cool-gray ledger theme, mobile-first.
   teal #0d6e6e · navy #14213d
   ============================================================ */
:root{
  --ink:#14213d; --ink-soft:#48516b; --soft:#5b6479;
  --paper:#eef1f4; --surface:#ffffff; --surface-2:#f7f9fb;
  --line:#dce1e9; --line-2:#e9edf2;
  --accent:#0d6e6e; --accent-d:#0a5454; --accent-soft:#e3f0ef;
  --navy:#14213d; --navy-2:#1b2c4d;
  --good:#15803d; --good-bg:#e7f4ec; --bad:#b3261e; --bad-bg:#fdeceb;
  --amber:#a85a08; --amber-bg:#fbf0df; --blue:#1d4ed8; --blue-bg:#e7edfd;
  --mono:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  --r:12px; --r-sm:9px;
  --shadow:0 1px 2px rgba(20,33,61,.04),0 1px 3px rgba(20,33,61,.06);
  --shadow-pop:0 6px 24px -12px rgba(20,33,61,.22);
}
*{box-sizing:border-box}
html,body{margin:0}
body{font:15px/1.55 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--paper);-webkit-text-size-adjust:100%}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{margin:0 0 .5em}
[hidden]{display:none !important}
h2{font-size:17px}h3{font-size:14px;letter-spacing:.01em}
hr{border:0;border-top:1px solid var(--line);margin:18px 0}
.muted{color:var(--soft)}.small{font-size:12.5px}
.mono{font-family:var(--mono)}
.num{font-variant-numeric:tabular-nums;font-family:var(--mono)}
code{font-family:var(--mono);background:var(--surface-2);border:1px solid var(--line-2);padding:1px 5px;border-radius:5px;font-size:.88em}

/* ---- Icons ---- */
.ic{width:18px;height:18px;display:inline-block;vertical-align:-3px;fill:none;stroke:currentColor;
  stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex:none}
.ic.i-sm{width:15px;height:15px;vertical-align:-2px}
.ic.flip{transform:scaleX(-1)}
.nav-ico{width:19px;height:19px;vertical-align:-4px}

/* ============================================================ Shell */
.shell{display:flex;min-height:100vh}
.sidebar{width:236px;flex:none;background:var(--surface-2);color:var(--ink);
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh;border-right:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:11px;padding:18px 18px 14px}
.brand .mark{font-family:var(--mono);font-weight:700;letter-spacing:-2px;color:var(--accent);font-size:22px}
.brand .name{display:flex;flex-direction:column;font-weight:700;line-height:1.1}
.brand .name small{font-weight:500;font-size:11px;color:var(--soft);letter-spacing:.02em;margin-top:2px;max-width:150px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nav{display:flex;flex-direction:column;gap:1px;padding:6px 10px;overflow-y:auto;flex:1}
.nav-link{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:8px;color:var(--ink-soft);font-size:14px;font-weight:500}
.nav-link:hover{background:var(--surface);color:var(--ink);text-decoration:none}
.nav-link.on{background:var(--accent-soft);color:var(--accent-d);font-weight:600}
.sidebar-foot{padding:12px 18px;color:var(--soft);font-size:11px;border-top:1px solid var(--line)}
.main{flex:1;min-width:0;display:flex;flex-direction:column}

.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:12px;padding:11px 20px;
  background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.topbar .ttl{font-size:17px;font-weight:700;margin:0;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.topbar .right{display:flex;align-items:center;gap:10px}
.nav-burger{display:none;cursor:pointer;color:var(--ink);padding:4px;border-radius:8px}
.fy-switch{display:flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--line);border-radius:9px;padding:4px 8px}
.fy-switch .fy-ico{color:var(--accent)}
.fy-switch select{border:0;background:transparent;font:inherit;font-weight:600;color:var(--ink);padding:2px;height:auto}
.fy-switch select:focus{outline:none}
.whoami{display:flex;align-items:center;gap:9px}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-weight:700;font-size:14px}
.who{display:flex;flex-direction:column;line-height:1.15}
.who-name{font-weight:600;font-size:13px}.who-role{font-size:11px;color:var(--soft)}
.icon-btn{padding:0;width:38px}
.btn.sm.icon-btn{width:32px}
.content{padding:20px;max-width:1200px;width:100%;margin:0 auto;flex:1}

/* off-canvas plumbing */
#navtoggle{position:absolute;opacity:0;pointer-events:none}
.scrim{display:none;position:fixed;inset:0;background:rgba(10,16,30,.45);z-index:40}

/* ============================================================ Cards & layout */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:18px;margin-bottom:18px;box-shadow:var(--shadow)}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.card-head h2{margin:0}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start}
.grid-2>*{min-width:0}
.grid-aside{display:grid;grid-template-columns:1fr 330px;gap:18px;align-items:start}
.grid-aside.wide-aside{grid-template-columns:1fr 400px}
.grid-aside>*{min-width:0}
.empty{text-align:center;padding:40px 18px}

/* ============================================================ Tables */
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:10px 11px;border-bottom:1px solid var(--line-2);text-align:left;vertical-align:middle}
.table th{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--soft);font-weight:600}
.table.tight th,.table.tight td{padding:7px 9px}
.table .r{text-align:right}
.table tr:last-child td,.table tbody tr:last-child td{border-bottom:none}
.table.linked tr.clickable{cursor:pointer}
.table.linked tr.clickable:hover{background:var(--surface-2)}
.neg{color:var(--bad)}.pos{color:var(--ink)}
.row-total td{border-top:2px solid var(--ink);font-weight:700}
.dept-head{display:flex;align-items:center;gap:7px;margin:16px 0 4px;color:var(--accent-d);font-size:13px;
  text-transform:uppercase;letter-spacing:.04em}
.editrow td{padding-top:0;border-bottom:1px solid var(--line-2)}
.editrow details{margin:2px 0 8px}
.editrow summary{cursor:pointer;list-style:none}

/* GL combined cell: label on top, code below, left aligned */
.gl-cell{display:flex;flex-direction:column;line-height:1.25}
.gl-cell .gl-label{font-weight:600}
.gl-cell .gl-code{font-family:var(--mono);font-size:11.5px;color:var(--soft);letter-spacing:.02em}

/* ============================================================ Status & tags */
.status{display:inline-block;font-size:11px;font-weight:700;padding:2px 9px;border-radius:999px;white-space:nowrap;letter-spacing:.02em}
.st-grey{background:#eceef2;color:#5b6479}.st-amber{background:var(--amber-bg);color:var(--amber)}
.st-blue{background:var(--blue-bg);color:var(--blue)}.st-green{background:var(--good-bg);color:var(--good)}
.st-red{background:var(--bad-bg);color:var(--bad)}
.pay-tag{display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;border-radius:6px;background:#eef1f4;color:#48516b}
.pay-credit_card{background:#eaf2ff;color:#1d4ed8}.pay-reimbursement{background:#fdf0e3;color:#a85a08}.pay-ap{background:#e8f1f0;color:#0d6e6e}

/* ============================================================ Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:1px solid transparent;border-radius:var(--r-sm);
  height:38px;padding:0 15px;font:inherit;font-weight:600;font-size:14px;cursor:pointer;background:var(--surface-2);color:var(--ink);
  border-color:var(--line);text-decoration:none;line-height:1;white-space:nowrap;vertical-align:middle}
.btn:hover{background:#eef2f5;text-decoration:none}
.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn.primary:hover{background:var(--accent-d)}
.btn.ghost{background:transparent}
.btn.ghost:hover{background:var(--surface-2)}
.btn.danger{background:var(--bad);color:#fff;border-color:var(--bad)}
.btn.danger.ghost{background:transparent;color:var(--bad);border-color:#e7c4c1}
.btn.danger.ghost:hover{background:var(--bad-bg)}
.btn.sm{height:32px;padding:0 11px;font-size:13px;border-radius:8px}
.btn.block{width:100%}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn .ic{width:16px;height:16px}
.btn.sm .ic{width:14px;height:14px}
.page-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.action-group{display:flex;gap:8px;flex-wrap:wrap;align-items:center}

/* ============================================================ Forms */
.field{display:block;margin-bottom:13px}
.field>span{display:block;font-size:12.5px;font-weight:600;margin-bottom:5px;color:var(--ink-soft)}
.field em{font-style:normal;font-weight:500}
input,select,textarea{width:100%;height:38px;padding:0 11px;border:1px solid var(--line);border-radius:var(--r-sm);
  font:inherit;background:var(--surface-2);color:var(--ink);vertical-align:middle}
select{padding-right:8px}
textarea{height:auto;min-height:76px;padding:8px 11px;resize:vertical;line-height:1.5}
input[type=checkbox],input[type=radio]{appearance:none;-webkit-appearance:none;accent-color:var(--accent);
  width:18px !important;height:18px !important;min-width:18px;max-width:18px;min-height:18px;max-height:18px;
  flex:0 0 auto;aspect-ratio:1;box-sizing:border-box;padding:0 !important;
  border:1.5px solid var(--line);background:var(--surface);cursor:pointer;position:relative;margin:0;vertical-align:middle;
  transition:border-color .12s ease,background .12s ease}
input[type=checkbox]{border-radius:5px}
input[type=radio]{border-radius:50%}
input[type=checkbox]:hover,input[type=radio]:hover{border-color:var(--accent)}
input[type=checkbox]:checked,input[type=radio]:checked{background:var(--accent);border-color:var(--accent)}
input[type=checkbox]:checked::after{content:"";position:absolute;left:5px;top:1.5px;width:5px;height:9px;
  border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}
input[type=radio]:checked::after{content:"";position:absolute;left:50%;top:50%;width:7px;height:7px;border-radius:50%;
  background:#fff;transform:translate(-50%,-50%)}
input[type=checkbox]:focus-visible,input[type=radio]:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
input[type=checkbox]:disabled,input[type=radio]:disabled{opacity:.5;cursor:not-allowed}
input:focus,select:focus,textarea:focus{outline:2px solid var(--accent);outline-offset:-1px;border-color:var(--accent);background:#fff}
input[readonly]{background:#eef1f4;color:var(--soft)}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.form-stack>.btn{margin-top:4px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 14px}
.form-grid .span2{grid-column:1/-1}
.check{display:flex;align-items:center;gap:9px;margin:7px 0;font-size:14px;cursor:pointer}
.check input{margin:0}
.check.inline{display:inline-flex;margin-right:14px}
.inline-form{display:flex;align-items:center;gap:8px}
.inline-form.wrap{flex-wrap:wrap}
.inline-form input,.inline-form select{width:auto}
.form-foot{display:flex;gap:10px;align-items:center;margin-top:6px}

/* segmented GL entry */
.seg-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(74px,1fr));gap:10px}
.seg-grid .seg-field,.seg-grid input,.seg-grid select{min-width:0}
.seg-field>span em{font-size:11px;color:var(--soft);margin-left:3px}
.seg-config input{background:var(--surface-2)}

/* ============================================================ Tabs */
.filter-tabs,.report-tabs{display:flex;gap:6px;flex-wrap:wrap}
.report-tabs{margin-bottom:16px}
.tab{padding:7px 13px;border-radius:999px;background:var(--surface);border:1px solid var(--line);color:var(--ink-soft);
  font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:6px}
.tab:hover{text-decoration:none;border-color:var(--accent);color:var(--accent)}
.tab.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.tab-c{background:rgba(255,255,255,.3);border-radius:999px;padding:0 6px;font-size:11px}
.tab.on .tab-c{background:rgba(255,255,255,.25)}
.tab:not(.on) .tab-c{background:var(--surface-2);color:var(--soft)}

/* ============================================================ KPIs / bars */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:15px 16px;box-shadow:var(--shadow)}
.kpi-k{display:block;font-size:12px;color:var(--soft);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.kpi-v{display:block;font-size:clamp(16px,4.6vw,24px);font-weight:700;margin-top:4px;font-variant-numeric:tabular-nums;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.2px}
.kpi-good .kpi-v{color:var(--good)}.kpi-bad .kpi-v{color:var(--bad)}
.dash-note{margin:0 0 14px;color:var(--ink-soft);font-size:15px}
.bar{height:8px;background:var(--line-2);border-radius:99px;overflow:hidden}
.bar-fill{height:100%;background:var(--accent);border-radius:99px}
.bar-fill.over{background:var(--bad)}
.big-amount{font-size:18px}

/* ============================================================ Upload / dropzone */
.dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;text-align:center;
  border:2px dashed var(--line);border-radius:var(--r);padding:34px 18px;background:var(--surface-2);cursor:pointer;margin-bottom:16px}
.dropzone.drag{border-color:var(--accent);background:var(--accent-soft)}
.dz-ico .ic{width:30px;height:30px;color:var(--accent)}
.dz-main{font-weight:600}.dz-sub{font-size:12.5px;color:var(--soft)}
.dz-file{font-size:13px;color:var(--accent);font-weight:600;margin-top:4px}
.pay-choices{display:grid;grid-template-columns:1fr;gap:8px;margin:6px 0 12px}
.pay-choice{position:relative;cursor:pointer}
.pay-choice input{position:absolute;opacity:0}
.pc-body{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:var(--r-sm);padding:11px 13px;background:var(--surface-2)}
.pc-ico .ic{color:var(--accent)}
.pay-choice input:checked+.pc-body{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 1px var(--accent)}

/* ocr/status, kv */
.ocr-status{display:flex;align-items:center;gap:8px;font-size:13px;padding:9px 11px;border-radius:var(--r-sm)}
.ocr-status.ok{background:var(--good-bg);color:var(--good)}
.ocr-status.off{background:var(--amber-bg);color:var(--amber)}
.kv{list-style:none;padding:0;margin:8px 0}
.kv li{display:flex;justify-content:space-between;gap:14px;padding:7px 0;border-bottom:1px solid var(--line-2)}
.kv li span{color:var(--soft)}.kv li strong{text-align:right;font-weight:600}.kv.small li{padding:5px 0;font-size:13px}
.kv.big li{padding:9px 0}
.codeblock{margin-top:14px;background:var(--surface-2);border:1px solid var(--line-2);border-radius:var(--r-sm);
  padding:11px;font-family:var(--mono);font-size:11.5px;line-height:1.7;color:var(--ink-soft);word-break:break-word}

/* ============================================================ Review (two-column) */
.review-grid{display:grid;grid-template-columns:minmax(0,440px) 1fr;gap:18px;align-items:start}
.review-left{position:sticky;top:78px}
.review-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.ackbox{margin-top:6px}
.reject-box{margin-top:10px;border-top:1px solid var(--line-2);padding-top:8px}
.gl-derived{margin:-6px 0 12px}
.doc-stage{position:relative;border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden;background:#5b6479;
  max-height:78vh;display:flex;justify-content:center}
.doc-stage img{max-width:100%;height:auto;display:block;user-select:none;-webkit-user-drag:none}
.stamp-ghost{position:absolute;background:#fff;border:1.5px solid var(--accent);
  border-radius:0;padding:8px 11px 9px;cursor:grab;touch-action:none;display:flex;flex-direction:column;gap:1px;
  width:min(62%,340px);box-shadow:var(--shadow-pop);color:var(--ink);user-select:none}
.stamp-ghost .sg-title{font-weight:800;color:var(--accent-d);letter-spacing:.04em;font-size:1.18em;text-transform:uppercase;margin-bottom:0}
.stamp-ghost .sg-line{font-size:1em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.stamp-ghost .sg-note{font-weight:600;color:var(--accent-d)}
.stamp-ghost .sg-date{color:var(--soft)}
.stamp-ghost .sg-grip{position:absolute;top:5px;right:6px;color:var(--accent);opacity:.6}
.stamp-ghost .sg-grip .ic{width:14px;height:14px}
.stamp-ghost.dragging{cursor:grabbing;box-shadow:0 12px 30px -10px rgba(13,110,110,.6)}
.doc-frame{border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden;height:74vh}
.doc-frame iframe{width:100%;height:100%;border:0}
.corner-grid{display:flex;gap:6px;flex-wrap:wrap;margin:8px 0}

/* ============================================================ Permission editor */
.perm-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px 16px;margin:4px 0 10px}
.scope-list{border:1px solid var(--line-2);border-radius:var(--r-sm);padding:8px 11px;margin:6px 0 12px;max-height:220px;overflow:auto;background:var(--surface-2)}
.scope-list.tall{max-height:300px}
.scope-group{font-family:var(--mono);font-size:11px;color:var(--soft);margin:8px 0 2px;text-transform:uppercase;letter-spacing:.04em}
.gl-scope{margin:8px 0;border:1px solid var(--line-2);border-radius:var(--r-sm);padding:8px 11px}
.gl-scope summary{cursor:pointer;font-weight:600;font-size:13px}

/* doc tabs (invoice view) */
.doc-tabs{display:flex;gap:6px;margin-bottom:8px}
.doc-tab{padding:5px 11px;border-radius:7px;background:var(--surface-2);border:1px solid var(--line);font-size:13px;font-weight:600}
.doc-tab.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.doc-view{border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden;height:420px;background:#5b6479}
.doc-view iframe{width:100%;height:100%;border:0}
.doc-dl{margin-top:0}
.approval-block{margin-top:16px}

/* templates */
.tpl-group{margin-bottom:14px}
.tpl-group h3{display:flex;align-items:center;gap:8px}

/* ============================================================ Flash */
.flash{padding:11px 14px;border-radius:var(--r-sm);margin-bottom:14px;font-size:14px;border:1px solid transparent}
.flash-error{background:var(--bad-bg);color:#7c1d1d;border-color:#f0c8c5}
.flash-success{background:var(--good-bg);color:#14532d;border-color:#bfe3cd}
.flash-warn{background:var(--amber-bg);color:#7c3f06;border-color:#eccfa1}
.flash-info{background:var(--blue-bg);color:#1e3a8a;border-color:#c7d6fb}

/* ============================================================ Auth */
.auth-body{min-height:100vh;min-height:100dvh;display:grid;place-items:center;align-content:center;
  padding:max(20px,env(safe-area-inset-top)) 20px max(20px,env(safe-area-inset-bottom));
  background:radial-gradient(1100px 500px at 100% -10%,#dceae9 0,transparent 55%),
             radial-gradient(900px 500px at -10% 110%,#e2e8f1 0,transparent 55%),var(--paper)}
.auth-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--line);border-radius:16px;
  padding:30px 28px;box-shadow:var(--shadow)}
.auth-mark{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.auth-mark .mark{font-family:var(--mono);font-weight:700;letter-spacing:-2px;color:var(--accent);font-size:24px}
.auth-mark .name{font-weight:700}
.auth-card h1{font-size:20px;margin-bottom:2px}
.auth-card .muted{margin:0 0 16px}

/* ---- Settings: field-detection ---- */
.card.span-2{grid-column:1 / -1}
.span-2{grid-column:1 / -1}
.ocr-train .row-2{margin-bottom:2px}
.ocr-train textarea,.ocr-test textarea{min-height:64px}
hr.rule{border:0;border-top:1px solid var(--line-2);margin:18px 0 14px}
.test-out{margin-top:12px;background:var(--surface-2);border:1px solid var(--line-2);border-radius:var(--r-sm);padding:12px 14px}
.test-out h4{margin:0 0 8px;font-size:13px}
.test-out .table td{padding:6px 8px}

/* ============================================================ Responsive */
@media (max-width:980px){
  .grid-aside,.grid-aside.wide-aside,.review-grid{grid-template-columns:1fr}
  .review-left{position:static}
  .kpis{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:860px){
  .sidebar{position:fixed;left:0;top:0;z-index:50;transform:translateX(-100%);transition:transform .22s ease;width:262px;box-shadow:0 0 60px rgba(20,33,61,.25)}
  #navtoggle:checked ~ .shell .scrim{display:block}
  #navtoggle:checked ~ .shell .sidebar{transform:translateX(0)}
  .nav-burger{display:inline-flex}
  .who{display:none}
  .content{padding:15px}
}
@media (max-width:700px){
  /* Any wide table scrolls horizontally instead of pushing content off-screen */
  .table{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap}
  .table thead,.table tbody,.table tr{white-space:nowrap}
  .gl-cell,.wrap-cell{white-space:normal}
  .table.no-scroll{display:table;white-space:normal}
  .tscroll>.table{display:table;width:auto;overflow:visible}
}
@media (max-width:560px){
  .grid-2,.row-2,.row-3,.form-grid,.perm-grid{grid-template-columns:1fr}
  .span-2{grid-column:auto}
  .kpis{grid-template-columns:1fr 1fr}
  .topbar{padding:10px 14px}
  .topbar .ttl{font-size:15px}
  .fy-switch{padding:3px 6px}
  .card{padding:15px}
  .table th,.table td{padding:9px 8px}
  .pay-choices{grid-template-columns:1fr}
  .stamp-ghost{width:min(80%,300px)}
}
@media (max-width:380px){
  .kpis{grid-template-columns:1fr}
}

/* PWA standalone niceties — keep content clear of the status bar / dynamic island */
@media (display-mode:standalone){
  .topbar{padding-top:calc(11px + env(safe-area-inset-top))}
  .sidebar{padding-top:calc(env(safe-area-inset-top) + 6px)}
  .scrim{top:0}
}
@supports (-webkit-touch-callout: none){
  /* iOS Safari/standalone fallback when display-mode query is flaky */
  @media (max-width:860px){
    .sidebar{padding-top:calc(env(safe-area-inset-top) + 6px)}
    .topbar{padding-top:calc(11px + env(safe-area-inset-top))}
  }
}

/* ===================================================================
   New components: settings hub, profile menu, mobile FY, adjustments,
   document preview modal, search bar, status pills, upload column.
   =================================================================== */

/* Page action header (read-only lists, search, etc.) */
.page-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.action-group{display:flex;align-items:center;gap:8px;flex-wrap:wrap}

/* --- Profile dropdown ------------------------------------------------ */
.profile{position:relative}
.profile>summary{display:flex;align-items:center;gap:9px;cursor:pointer;list-style:none;padding:3px 6px 3px 3px;border-radius:10px}
.profile>summary::-webkit-details-marker{display:none}
.profile>summary:hover{background:var(--surface-2)}
.profile>summary .who.i-sm{color:var(--soft)}
.profile[open]>summary{background:var(--surface-2)}
.profile-menu{position:absolute;right:0;top:calc(100% + 8px);min-width:220px;background:var(--surface);border:1px solid var(--line);
  border-radius:12px;box-shadow:var(--shadow-pop);padding:8px;z-index:60}
.profile-menu .pm-head{display:flex;flex-direction:column;gap:1px;padding:7px 10px 9px;border-bottom:1px solid var(--line);margin-bottom:6px}
.profile-menu a{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:8px;color:var(--ink-soft);font-size:14px;font-weight:500}
.profile-menu a:hover{background:var(--surface-2);color:var(--accent-d);text-decoration:none}

/* --- Sidebar FY selector (mobile) ----------------------------------- */
.fy-menu{display:none;margin:10px 12px 0;padding-top:12px;border-top:1px solid var(--line)}
.fy-menu .fy-menu-lbl{display:flex;align-items:center;gap:9px;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--soft);font-weight:600;margin-bottom:6px}
.fy-menu select{width:100%;border:1px solid var(--line);background:var(--surface);border-radius:9px;padding:9px 10px;font:inherit;font-weight:600;color:var(--ink)}

/* --- Settings hub --------------------------------------------------- */
.settings-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px}
.stab{display:inline-flex;align-items:center;gap:7px;white-space:nowrap;padding:7px 13px;border-radius:999px;
  background:var(--surface);border:1px solid var(--line);color:var(--ink-soft);font-size:13.5px;font-weight:600;margin-bottom:4px}
.stab:hover{border-color:var(--accent);color:var(--accent);text-decoration:none}
.stab .ic{width:16px;height:16px}
.stab.on{background:var(--accent);border-color:var(--accent);color:#fff}
.settings-body{min-height:200px}

/* report tabs scroll horizontally now that there are many */
/* report tabs wrap onto multiple rows like the invoices filter tabs */
.report-tabs{flex-wrap:wrap;overflow:visible}
.report-tabs .tab{white-space:normal}

/* --- GL adjustments ------------------------------------------------- */
.adj-form{margin-top:8px;padding-top:8px;border-top:1px dashed var(--line)}
.adj-hist{margin-top:10px}
.adj-hist td{padding:6px 8px}

/* --- Seg config (GL structure) -------------------------------------- */
.seg-config input:not([type=radio]):not([type=checkbox]){width:100%}

/* --- Document preview modal ----------------------------------------- */
body.modal-open{overflow:hidden}
.modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px}
.modal[hidden]{display:none}
.modal-backdrop{position:absolute;inset:0;background:rgba(20,33,61,.55);backdrop-filter:blur(2px)}
.modal-box{position:relative;width:min(960px,96vw);height:88vh;max-height:92vh;display:flex;flex-direction:column;background:var(--surface);
  border-radius:14px;box-shadow:0 24px 60px -20px rgba(20,33,61,.55);overflow:hidden}
.modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-bottom:1px solid var(--line)}
.modal-body{flex:1;min-height:0;background:#5b6479}
.modal-body iframe{width:100%;height:100%;border:0;display:block;background:#fff}

/* --- Document tabs as buttons --------------------------------------- */
.doc-tab{font:inherit;cursor:pointer;background:var(--surface-2);border:1px solid var(--line);color:var(--ink-soft);
  padding:6px 12px;border-radius:999px;font-size:13px;font-weight:600}
.doc-tab:hover{border-color:var(--accent);color:var(--accent-d)}
.doc-tab.on{background:var(--accent);border-color:var(--accent);color:#fff}

/* --- Search ---------------------------------------------------------- */
.search-card{padding:16px 18px}
.search-form{display:flex;flex-direction:column;gap:12px}
.search-main{display:flex;align-items:center;gap:10px;position:relative}
.search-ico{position:absolute;left:14px;color:var(--soft);display:flex}
.search-ico .ic{width:18px;height:18px}
.search-big{flex:1;font-size:16px;padding:13px 14px 13px 42px;border:1px solid var(--line);border-radius:11px;background:var(--surface);color:var(--ink)}
.search-big:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.status-pills{display:flex;gap:7px;flex-wrap:wrap}
.pill{padding:6px 12px;border-radius:999px;background:var(--surface-2);border:1px solid var(--line);color:var(--ink-soft);font-size:12.5px;font-weight:600}
.pill:hover{border-color:var(--accent);color:var(--accent-d);text-decoration:none}
.pill.on{background:var(--accent);border-color:var(--accent);color:#fff}
.adv{border:1px solid var(--line);border-radius:11px;padding:0 14px;background:var(--surface-2)}
.adv>summary{cursor:pointer;padding:11px 0;font-weight:600;color:var(--ink-soft);font-size:13.5px;display:flex;align-items:center;gap:7px}
.adv[open]{padding-bottom:14px}
.filter-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:6px 0 12px}

/* --- Upload single column ------------------------------------------- */
.upload-wrap{max-width:560px;margin:0 auto}

@media (max-width:900px){ .filter-grid{grid-template-columns:repeat(2,1fr)} }
@media (max-width:860px){
  /* On mobile the topbar FY switch is hidden; the menu version shows instead */
  .fy-switch{display:none}
  .fy-menu{display:block}
  .modal{padding:0}
  .modal-box{width:100vw;max-height:100dvh;height:100dvh;border-radius:0}
  .modal-head{padding-top:calc(12px + env(safe-area-inset-top))}
  #previewOpen{display:none}
  .modal-body iframe{height:100%}
}
@media (max-width:560px){
  .filter-grid{grid-template-columns:1fr}
  .search-big{font-size:15px}
  .profile>summary .who{display:none}
}

/* ---- GL accounts: Fund -> Department hierarchy ---- */
.gl-fund{margin-bottom:16px}
.gl-fund .fund-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap;
  padding-bottom:8px;margin-bottom:4px;border-bottom:2px solid var(--accent-soft)}
.gl-fund .fund-head h2{font-size:17px;display:flex;align-items:center;gap:8px;color:var(--accent-d)}
.fund-tot{font-size:12.5px;color:var(--soft)}
.fund-tot strong{font-variant-numeric:tabular-nums}
.gl-seg{display:inline-flex;align-items:center;gap:0}
.gl-seg .seg{font-family:var(--mono);font-size:11.5px;color:var(--soft);letter-spacing:.02em}
.gl-seg .seg-dept{color:var(--accent-d);font-weight:700;background:var(--accent-soft);border-radius:4px;padding:0 4px}
.gl-seg .seg-sep{color:var(--line);font-family:var(--mono);padding:0 1px}

/* ---- Print / generic dropdown menu (details.menu) ---- */
.menu{position:relative}
.menu>summary{cursor:pointer;list-style:none}
.menu>summary::-webkit-details-marker{display:none}
.menu-list{position:absolute;right:0;top:calc(100% + 6px);z-index:40;min-width:208px;
  background:var(--surface);border:1px solid var(--line);border-radius:11px;box-shadow:var(--shadow-pop);padding:6px}
.menu-list a{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:8px;
  color:var(--ink-soft);font-size:14px;font-weight:500}
.menu-list a:hover{background:var(--surface-2);color:var(--accent-d);text-decoration:none}

/* ---- Review: place-stamp vs read/copy toggle ---- */
.doc-modes{display:inline-flex;gap:4px;padding:3px;background:var(--surface-2);border:1px solid var(--line);
  border-radius:10px;margin-bottom:8px}
.doc-modes .js-docmode{border:0;background:transparent}
.doc-modes .js-docmode.on{background:var(--surface);box-shadow:var(--shadow);color:var(--accent-d)}
.doc-read{border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden;height:74vh;background:#fff}
.doc-read iframe{width:100%;height:100%;border:0}

/* ---- Reports: inline date filter ---- */
.report-filter{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap;margin:4px 0 14px;
  padding:10px 12px;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-sm)}
.report-filter .field{margin:0}
.report-filter .field span{font-size:11px}
.report-filter input[type=date]{min-width:0}
/* Date pickers must shrink to the device width like every other field */
input[type=date],input[type=datetime-local],input[type=month],input[type=time]{width:100%;min-width:0;max-width:100%}
/* Horizontal-scroll wrapper for wide tables on narrow screens */
.tscroll{width:100%;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
.tscroll>.table{margin:0}

/* keep the live stamp faithful to the printed stamp */
.stamp-ghost{line-height:1.45}
.stamp-ghost .sg-line{color:var(--ink)}

/* ---- Styled file inputs (adjustments, etc.) ---- */
input[type=file]{appearance:none;-webkit-appearance:none;width:100%;height:auto;min-height:44px;display:flex;align-items:center;
  font:inherit;color:var(--ink-soft);background:var(--surface-2);border:1px dashed var(--line);border-radius:var(--r-sm);padding:8px 11px;cursor:pointer;line-height:1.2}
input[type=file]:hover{border-color:var(--accent)}
input[type=file]::file-selector-button{font:inherit;font-weight:600;margin-right:10px;padding:7px 12px;cursor:pointer;
  color:#fff;background:var(--accent);border:0;border-radius:8px}
input[type=file]::file-selector-button:hover{background:var(--accent-d)}
input[type=file]::-webkit-file-upload-button{font:inherit;font-weight:600;margin-right:10px;padding:7px 12px;cursor:pointer;
  color:#fff;background:var(--accent);border:0;border-radius:8px}

/* ---- Mobile: keep wide tables and numbers on-screen ---- */
@media (max-width:560px){
  .table{font-size:12.5px}
  .table th,.table td{padding:8px 7px}
  .gl-seg .seg,.gl-cell .gl-code{font-size:10.5px}
  .kpi{padding:13px 13px}
  .kpi-k{font-size:11px}
}

/* keep small icon-button groups on one line (e.g. attachment preview/download) */
.action-group.nowrap{flex-wrap:nowrap}
