/* ===== Lockersmiths ERP — refined industrial ===== */
:root{
  --blue:#007CC4; --blue-700:#0063a0; --blue-050:#e9f3fa;
  --ink:#0e1626; --ink-2:#1b2433; --ink-soft:#5a6573;
  --paper:#f4f6f9; --card:#ffffff; --line:#e4e8ee; --line-strong:#ccd3dd;
  --grey:#A8A8AC; --pos:#1f9d63; --neg:#d1483a; --warn:#e08b18;
  --r:10px; --shadow:0 1px 2px rgba(14,22,38,.05),0 8px 24px rgba(14,22,38,.06);
  --sidebar-w:236px;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family:'Archivo',system-ui,sans-serif; color:var(--ink);
  background:var(--paper); -webkit-font-smoothing:antialiased;
}
.boot{display:grid;place-items:center;height:100vh;color:var(--ink-soft);font-family:'JetBrains Mono',monospace;letter-spacing:.05em}
.mono{font-family:'JetBrains Mono',monospace}
.num{font-family:'JetBrains Mono',monospace;font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}
button{font-family:inherit;cursor:pointer}
input,select{font-family:inherit}
a{color:inherit;text-decoration:none}

/* labels */
.eyebrow{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft)}

/* ===== LOGIN ===== */
.login{
  min-height:100vh;display:grid;place-items:center;padding:24px;
  background:
    linear-gradient(0deg,rgba(0,124,196,.04),rgba(0,124,196,.04)),
    repeating-linear-gradient(0deg,transparent 0 31px,rgba(14,22,38,.045) 31px 32px),
    repeating-linear-gradient(90deg,transparent 0 31px,rgba(14,22,38,.045) 31px 32px),
    var(--paper);
}
.login-card{
  position:relative;width:100%;max-width:392px;background:var(--card);
  border:1px solid var(--line-strong);border-radius:14px;padding:38px 34px 30px;
  box-shadow:var(--shadow);
}
.login-card::before,.login-card::after{
  content:"";position:absolute;width:14px;height:14px;border:2px solid var(--blue);
}
.login-card::before{top:-1px;left:-1px;border-right:0;border-bottom:0;border-top-left-radius:14px}
.login-card::after{bottom:-1px;right:-1px;border-left:0;border-top:0;border-bottom-right-radius:14px}
.brand{display:flex;align-items:center;gap:11px;margin-bottom:26px}
.brand .mark{
  width:38px;height:38px;border-radius:9px;background:var(--ink);display:grid;place-items:center;
  position:relative;flex:none;
}
.brand .mark::before{content:"";width:18px;height:18px;border:2.5px solid var(--blue);border-radius:3px;transform:rotate(45deg)}
.brand .mark::after{content:"";position:absolute;width:6px;height:6px;background:var(--blue);border-radius:1px}
.brand h1{margin:0;font-size:17px;font-weight:800;letter-spacing:-.01em}
.brand span{display:block;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;color:var(--ink-soft);text-transform:uppercase;margin-top:2px}
.field{margin-bottom:14px}
.field label{display:block;font-size:12px;font-weight:600;margin-bottom:6px;color:var(--ink)}
.field input{
  width:100%;padding:11px 13px;border:1px solid var(--line-strong);border-radius:9px;
  font-size:14px;background:#fcfdfe;transition:border-color .15s,box-shadow .15s;
}
.field input:focus{outline:0;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-050)}
.btn{
  width:100%;padding:12px;border:0;border-radius:9px;background:var(--blue);color:#fff;
  font-weight:700;font-size:14px;letter-spacing:.01em;transition:background .15s,transform .05s;
}
.btn:hover{background:var(--blue-700)} .btn:active{transform:translateY(1px)}
.btn:disabled{opacity:.6;cursor:default}
.err{background:#fdecea;border:1px solid #f5c4be;color:#a23226;font-size:12.5px;padding:9px 12px;border-radius:8px;margin-bottom:14px}
.login-foot{margin-top:18px;text-align:center;font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.1em;color:var(--grey);text-transform:uppercase}

/* ===== SHELL ===== */
.shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}
.side{background:var(--ink);color:#aeb8c6;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.side .brand{padding:18px 18px 14px;margin:0;border-bottom:1px solid rgba(255,255,255,.07)}
.side .brand h1{color:#fff;font-size:15px}
.nav{padding:10px 10px;overflow:auto;flex:1}
.nav .grp{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:#5d6b7d;padding:14px 10px 6px}
.nav a{
  display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:8px;font-size:13.5px;
  font-weight:500;color:#aeb8c6;margin-bottom:2px;transition:background .12s,color .12s;
}
.nav a:hover{background:rgba(255,255,255,.05);color:#fff}
.nav a.active{background:var(--blue);color:#fff}
.nav a .ic{width:7px;height:7px;border:1.5px solid currentColor;border-radius:2px;flex:none;opacity:.8}
.nav a.active .ic{background:#fff;border-color:#fff}
.side-foot{padding:12px 16px;border-top:1px solid rgba(255,255,255,.07);font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.12em;color:#5d6b7d}

.main{display:flex;flex-direction:column;min-width:0}
.topbar{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:0 26px;height:60px;background:var(--card);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5;
}
.topbar .co{display:flex;align-items:center;gap:4px}
.topbar .co b{font-size:14px;font-weight:700}
.topbar .co .chip{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);background:var(--blue-050);padding:3px 8px;border-radius:20px}
.co-switch{display:flex;align-items:center;gap:9px;background:transparent;border:1px solid transparent;border-radius:9px;padding:5px 9px;cursor:pointer;color:var(--ink)}
.co-switch:hover{background:#f4f6f9;border-color:var(--line)}
.co-caret{font-size:11px;color:var(--ink-soft)}
/* choose-company list */
.co-list{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.co-row{display:flex;align-items:stretch;border-bottom:1px solid var(--line)}
.co-row:last-child{border-bottom:0}
.co-row.on{background:var(--blue-050)}
.co-pick{flex:1;display:flex;flex-direction:column;gap:2px;text-align:left;background:transparent;border:0;padding:11px 14px;cursor:pointer}
.co-pick:disabled{cursor:default}
.co-pick:not(:disabled):hover{background:#f4f6f9}
.co-row-name{font-size:13.5px;font-weight:600;color:var(--ink)}
.co-row-id{font-size:11px;color:var(--ink-soft)}
.co-badge{font-size:10px;font-weight:700;color:var(--pos);background:rgba(58,157,107,.12);padding:1px 7px;border-radius:10px;margin-left:6px;text-transform:uppercase;letter-spacing:.06em}
.co-acts{display:flex;align-items:center;border-left:1px solid var(--line)}
.co-act{background:transparent;border:0;border-right:1px solid var(--line);padding:0 11px;cursor:pointer;font-size:11.5px;font-weight:600;color:var(--blue);white-space:nowrap}
.co-act:hover{background:var(--blue-050)}
.co-act.warn{color:#c47a13}
.co-act.warn:hover{background:rgba(224,163,42,.1)}
.co-del{background:transparent;border:0;padding:0 13px;cursor:pointer;font-size:14px;opacity:.65}
.co-del:hover{opacity:1;background:rgba(214,69,69,.08)}
.co-new{margin-top:12px}

/* ===== Chart of Accounts — collapsible tree ===== */
.coa-head{display:flex;align-items:center;gap:8px;cursor:pointer;user-select:none}
.coa-head:hover{color:var(--blue)}
.coa-count{font-size:11px;font-weight:600;color:var(--ink-soft);background:#eef1f5;border-radius:10px;padding:1px 8px}
.coa-group.collapsed .coa-body{display:none}
.coa-chev{background:none;border:0;cursor:pointer;font-size:11px;color:var(--ink-soft);width:16px;height:16px;line-height:1;padding:0;transition:transform .15s;display:inline-flex;align-items:center;justify-content:center}
.coa-chev.closed{transform:rotate(-90deg)}
.coa-chev-sp{display:inline-block;width:16px}
.coa-code{white-space:nowrap}
.coa-code .coa-chev,.coa-code .coa-chev-sp{margin-right:6px;vertical-align:middle}
.coa-num{font-variant-numeric:tabular-nums}

/* ===== Business Partner master ===== */
.bp-code{display:flex;align-items:center;gap:14px;background:#f4f6f9;border:1px solid var(--line);border-radius:9px;padding:9px 13px;margin-bottom:12px;font-size:12.5px;color:var(--ink-soft)}
.bp-code b{color:var(--ink);font-size:13.5px}
.bp-ctrl{margin-left:auto;font-size:11.5px}
.field textarea{width:100%;box-sizing:border-box;padding:9px 11px;border:1px solid var(--line-strong);border-radius:9px;font-size:13px;font-family:inherit;background:#fcfdfe;resize:vertical}
.who{display:flex;align-items:center;gap:12px}
.who .u{text-align:right;line-height:1.2}
.who .u b{font-size:13px;font-weight:600;display:block}
.who .u span{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.who .av{width:34px;height:34px;border-radius:9px;background:var(--ink);color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px}
.logout{border:1px solid var(--line-strong);background:#fff;border-radius:8px;padding:7px 12px;font-size:12.5px;font-weight:600;color:var(--ink)}
.bell-wrap{position:relative}
.bell{background:none;border:0;font-size:17px;cursor:pointer;line-height:1;padding:4px;position:relative}
.bell-badge{position:absolute;top:-2px;right:-2px;background:var(--neg);color:#fff;font-size:9px;font-weight:700;min-width:15px;height:15px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;padding:0 3px}
.notif-panel{position:absolute;top:36px;right:0;width:320px;max-height:62vh;overflow:auto;background:#fff;border:1px solid var(--line-strong);border-radius:10px;box-shadow:0 14px 40px rgba(14,22,38,.22);z-index:70}
.np-head{padding:10px 14px;font-weight:700;font-size:13px;border-bottom:1px solid var(--line);position:sticky;top:0;background:#fff}
.np-item{padding:10px 14px;border-bottom:1px solid var(--line);cursor:pointer}
.np-item:last-child{border-bottom:0}
.np-item:hover{background:var(--blue-050)}
.np-item.unread{background:#f3f8fd}
.np-item.unread .np-title{font-weight:700}
.np-title{font-size:13px;color:var(--ink)}
.np-sub{font-size:11.5px;color:var(--ink-soft);margin-top:2px}
.np-time{font-size:10.5px;color:var(--ink-soft);margin-top:3px;font-family:'JetBrains Mono',monospace}
/* document change-log timeline */
.timeline{padding:6px 2px 2px}
.tl-item{display:flex;padding:10px 0 10px 18px;border-left:2px solid var(--line);margin-left:9px;position:relative}
.tl-ic{position:absolute;left:-11px;top:8px;width:20px;height:20px;background:#fff;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px}
.tl-head{font-size:13px;color:var(--ink)}
.tl-detail{font-size:12px;color:var(--ink);margin-top:2px}
.tl-time{font-size:10.5px;color:var(--ink-soft);margin-top:2px}
.logout:hover{border-color:var(--neg);color:var(--neg)}

.content{padding:26px;max-width:1180px;width:100%}
.content.wide-page{max-width:none}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:20px}
.page-head h2{margin:0;font-size:23px;font-weight:800;letter-spacing:-.02em}
.page-head .sub{margin-top:3px}

/* KPI tiles */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(208px,1fr));gap:14px;margin-bottom:14px}
.kpi{position:relative;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:16px 16px 15px;box-shadow:var(--shadow);overflow:hidden}
.kpi::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--blue)}
.kpi.pos::before{background:var(--pos)} .kpi.neg::before{background:var(--neg)} .kpi.muted::before{background:var(--grey)}
.kpi .k-label{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-soft)}
.kpi .k-val{font-family:'JetBrains Mono',monospace;font-variant-numeric:tabular-nums;font-size:24px;font-weight:700;margin-top:10px;letter-spacing:-.01em}
.kpi .k-val small{font-size:13px;color:var(--ink-soft);font-weight:500;margin-right:3px}
.kpi .k-foot{font-size:11.5px;color:var(--ink-soft);margin-top:5px}
.k-val.pos{color:var(--pos)} .k-val.neg{color:var(--neg)}
.kpi-link{cursor:pointer;transition:border-color .12s,box-shadow .12s,transform .12s}
.kpi-link:hover{border-color:var(--blue);box-shadow:0 4px 14px rgba(20,80,160,.10);transform:translateY(-1px)}
.kpi-link .k-label::after{content:"  \2197";color:var(--blue);font-weight:700}

/* ===== SAP B1-style cockpit widgets ===== */
.dash-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:14px;margin-top:14px;align-items:start}
.widget{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column}
.widget.wide{grid-column:span 2}
@media(max-width:760px){.widget.wide{grid-column:span 1}}
.widget-h{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:11px 14px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,#fbfcfe,#f6f8fb)}
.widget-h h4{margin:0;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);font-weight:700;display:flex;align-items:center;gap:7px}
.widget-h .tick{width:8px;height:8px;border-radius:2px;background:var(--blue);display:inline-block}
.wlink{font-size:11.5px;font-weight:600;color:var(--blue);cursor:pointer;white-space:nowrap}
.wlink:hover{text-decoration:underline}
.widget-b{padding:13px 14px}

/* stat rows (open documents, cash & bank) */
.wstat{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 0;border-bottom:1px dashed var(--line);cursor:pointer}
.wstat:last-child{border-bottom:0}
.wstat:hover .wstat-l{color:var(--blue)}
.wstat-l{font-size:13px;color:var(--ink)}
.wstat-v{font-size:13px;color:var(--ink)}
.wstat-v b{font-size:15px;font-variant-numeric:tabular-nums}
.wstat-v small{color:var(--ink-soft);margin-right:4px}

/* sales/purchases bar chart */
.wlegend{display:flex;gap:16px;font-size:11.5px;color:var(--ink-soft);margin-bottom:10px}
.wlegend i.sw{display:inline-block;width:10px;height:10px;border-radius:2px;margin-right:5px;vertical-align:-1px}
.sw.sales{background:var(--blue)} .sw.purch{background:#c9d3e0}
.chartcols{display:flex;align-items:flex-end;justify-content:space-around;gap:8px;height:140px;padding-top:6px}
.ccol{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;justify-content:flex-end}
.cbars{display:flex;align-items:flex-end;gap:3px;height:120px;width:100%;justify-content:center}
.cbar{width:14px;border-radius:3px 3px 0 0;min-height:2px;transition:height .3s}
.cbar.sales{background:var(--blue)} .cbar.purch{background:#c9d3e0}
.clabel{font-size:10.5px;color:var(--ink-soft);font-family:'JetBrains Mono',monospace}

/* ageing bars */
.ageblock{display:flex;flex-direction:column;gap:9px}
.agerow{display:grid;grid-template-columns:62px 1fr auto;align-items:center;gap:9px}
.agelbl{font-size:11.5px;color:var(--ink-soft)}
.agebar{height:9px;background:#eef1f5;border-radius:5px;overflow:hidden}
.agefill{display:block;height:100%;border-radius:5px}
.agefill.a0{background:#3a9d6b} .agefill.a1{background:#5b8def} .agefill.a2{background:#e0a32a} .agefill.a3{background:#e07a2a} .agefill.a4{background:var(--neg)}
.ageamt{font-size:11.5px;min-width:64px;text-align:right}

/* mini ranked rows (top receivables) */
.minirow{display:grid;grid-template-columns:1fr 70px auto;align-items:center;gap:9px;padding:6px 0}
.mini-l{font-size:12.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini-bar{height:7px;background:#eef1f5;border-radius:4px;overflow:hidden}
.mini-bar span{display:block;height:100%;background:var(--blue);border-radius:4px}
.mini-v{font-size:11.5px;min-width:62px;text-align:right}
table.tbl.mini td,table.tbl.mini th{padding:6px 8px;font-size:12px}
.ok-note{font-size:12.5px;color:var(--ink-soft);display:flex;align-items:center;gap:8px}
.appr-banner{border-left:3px solid var(--blue)}

.section{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);margin-top:16px}
.section h3{margin:0;padding:15px 18px;font-size:14px;font-weight:700;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:9px}
.section h3 .tick{width:8px;height:8px;background:var(--blue);border-radius:2px}
.section .body{padding:18px}
.statusline{display:flex;align-items:center;gap:9px;font-size:13px;padding:14px 18px}
.dot{width:9px;height:9px;border-radius:50%}
.dot.ok{background:var(--pos)} .dot.bad{background:var(--neg)}

/* tables */
table.tbl{width:100%;border-collapse:collapse;font-size:13px}
table.tbl th{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);text-align:left;padding:10px 18px;border-bottom:1px solid var(--line)}
table.tbl td{padding:10px 18px;border-bottom:1px solid var(--line)}
table.tbl td.r,table.tbl th.r{text-align:right;font-family:'JetBrains Mono',monospace;font-variant-numeric:tabular-nums}
table.tbl tr:last-child td{border-bottom:0}
table.tbl tr.rowlink{cursor:pointer}
table.tbl tr.rowlink:hover td{background:var(--blue-050)}

/* placeholder */
.soon{display:grid;place-items:center;padding:70px 20px;text-align:center}
.soon .b{width:46px;height:46px;border:2px dashed var(--line-strong);border-radius:11px;display:grid;place-items:center;margin:0 auto 14px}
.soon .b::after{content:"";width:16px;height:16px;border:2px solid var(--blue);border-radius:3px;transform:rotate(45deg)}
.soon h3{margin:0 0 6px;font-size:16px} .soon p{margin:0;color:var(--ink-soft);font-size:13px;max-width:340px}

.skel{height:24px;border-radius:6px;background:linear-gradient(90deg,#eef1f5 25%,#e3e8ef 37%,#eef1f5 63%);background-size:400% 100%;animation:sh 1.3s infinite}
@keyframes sh{0%{background-position:100% 0}100%{background-position:-100% 0}}

@media (max-width:780px){
  .shell{grid-template-columns:1fr}
  .side{position:fixed;left:0;top:0;z-index:40;width:240px;transform:translateX(-100%);transition:transform .2s}
  .side.open{transform:none}
  .topbar{padding:0 16px}.content{padding:16px}
  .menu-btn{display:grid}
}
.menu-btn{display:none;width:36px;height:36px;border:1px solid var(--line-strong);border-radius:8px;background:#fff;place-items:center}
.menu-btn span,.menu-btn span::before,.menu-btn span::after{content:"";display:block;width:16px;height:2px;background:var(--ink);position:relative}
.menu-btn span::before{position:absolute;top:-5px}.menu-btn span::after{position:absolute;top:5px}

/* ===== shared components (added for module screens) ===== */
.page-head .actions{display:flex;gap:8px}
.btn-sm{background:var(--blue);color:#fff;border:0;border-radius:8px;padding:9px 15px;font-size:13px;font-weight:700}
.btn-sm:hover{background:var(--blue-700)} .btn-sm:disabled{opacity:.6;cursor:default}
.btn-ghost{background:#fff;color:var(--ink);border:1px solid var(--line-strong);border-radius:8px;padding:9px 14px;font-size:13px;font-weight:600}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue)}
.lnk{background:none;border:0;color:var(--blue);font-size:12.5px;font-weight:600;padding:2px 4px}
.lnk:hover{text-decoration:underline}
.lnk.del{color:var(--neg)}

.toolbar{display:flex;align-items:center;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.seg{display:inline-flex;background:#fff;border:1px solid var(--line-strong);border-radius:9px;overflow:hidden}
.seg button{background:#fff;border:0;padding:8px 14px;font-size:12.5px;font-weight:600;color:var(--ink-soft);border-right:1px solid var(--line)}
.seg button:last-child{border-right:0}
.seg button.on{background:var(--blue);color:#fff}
.search{flex:1;min-width:180px;max-width:340px;padding:9px 12px;border:1px solid var(--line-strong);border-radius:9px;font-size:13px;background:#fcfdfe}
.search:focus{outline:0;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-050)}
.toolbar .inline{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;color:var(--ink-soft)}
.toolbar .inline input[type=date]{padding:7px 9px;border:1px solid var(--line-strong);border-radius:8px;font-size:12.5px;background:#fcfdfe}

.badge{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.08em;text-transform:uppercase;padding:3px 8px;border-radius:20px;font-weight:600}
.badge.cust{background:var(--blue-050);color:var(--blue)}
.badge.supp{background:#fdf0e3;color:var(--warn)}

.empty{padding:42px 20px;text-align:center;color:var(--ink-soft);font-size:13px}
.tbl tr.op td{background:#f9fbfd;font-style:italic;color:var(--ink-soft)}
.ledger-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding:16px 18px;border-bottom:1px solid var(--line)}

/* modal */
.modal-overlay{position:fixed;inset:0;background:rgba(14,22,38,.45);display:grid;place-items:center;z-index:60;padding:20px}
.modal{background:var(--card);border-radius:14px;width:100%;max-width:520px;box-shadow:0 20px 60px rgba(14,22,38,.3);max-height:90vh;display:flex;flex-direction:column}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line)}
.modal-head h3{margin:0;font-size:16px;font-weight:700}
.modal-head .x{background:none;border:0;font-size:24px;line-height:1;color:var(--ink-soft)}
.modal-head .x:hover{color:var(--neg)}
.modal-body{padding:18px 20px;overflow:auto}
.modal-foot{display:flex;justify-content:flex-end;gap:9px;padding:14px 20px;border-top:1px solid var(--line)}
/* Choose-from-List picker (stacks above an open modal) */
.pick-overlay{z-index:70}
.pick-field{display:flex;align-items:center;gap:8px}
.pick-field .pick-val{flex:1;min-width:0}
input.pick-val{padding:9px 12px;border:1px solid var(--line-strong);border-radius:9px;font-size:13px;background:#f6f8fa;color:var(--ink);cursor:default}
.btn-pick{padding:9px 13px;white-space:nowrap}
.pick-overlay .pick-search{width:100%;max-width:none;box-sizing:border-box}
.pick-add{display:flex;gap:8px;margin-top:10px}
.pick-add .pick-new{flex:1;max-width:none}
.pick-list{margin-top:10px;max-height:46vh;overflow:auto;border:1px solid var(--line);border-radius:10px}
.pick-row{display:flex;justify-content:space-between;align-items:center;gap:12px;width:100%;text-align:left;background:#fff;border:0;border-bottom:1px solid var(--line);padding:11px 14px;font-size:13px;font-weight:600;color:var(--ink);cursor:pointer}
.pick-row:last-child{border-bottom:0}
.pick-row:hover{background:var(--blue-050)}
.pick-row.on{background:var(--blue-050);box-shadow:inset 3px 0 0 var(--blue)}
.pick-sub{font-size:11.5px;font-weight:500;color:var(--ink-soft)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.form-grid .full{grid-column:1/-1}
.form-grid .field{margin-bottom:0}
.form-grid label{display:block;font-size:12px;font-weight:600;margin-bottom:6px}
.form-grid select,.form-grid input{width:100%;padding:10px 12px;border:1px solid var(--line-strong);border-radius:9px;font-size:13.5px;background:#fcfdfe}
.form-grid select:focus,.form-grid input:focus{outline:0;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-050)}

/* toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;padding:11px 18px;border-radius:10px;font-size:13px;font-weight:600;z-index:80;opacity:0;transition:opacity .2s,transform .2s;box-shadow:0 10px 30px rgba(0,0,0,.25)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.bad{background:var(--neg)}

/* ===== inventory ===== */
.sub-divider{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin:16px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--line)}
.badge.stock{background:var(--blue-050);color:var(--blue)}
.badge.svc{background:#eef0f3;color:var(--ink-soft)}
.badge.low{background:#fdecea;color:var(--neg)}

/* ===== transactional modules ===== */
.tabs{display:flex;gap:2px;border-bottom:1px solid var(--line);margin-bottom:16px;flex-wrap:wrap}
.tabs button{background:none;border:0;border-bottom:2px solid transparent;padding:10px 16px;font-size:13px;font-weight:600;color:var(--ink-soft);margin-bottom:-1px}
.tabs button:hover{color:var(--ink)}
.tabs button.on{color:var(--blue);border-bottom-color:var(--blue)}
.line-tbl{width:100%;border-collapse:collapse;margin-bottom:10px}
.line-tbl th{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);text-align:left;padding:4px 6px}
.line-tbl td{padding:3px 5px;vertical-align:middle}
.line-tbl input,.line-tbl select{width:100%;padding:8px 9px;border:1px solid var(--line-strong);border-radius:7px;font-size:13px;background:#fcfdfe}
.line-tbl input:focus,.line-tbl select:focus{outline:0;border-color:var(--blue);box-shadow:0 0 0 2px var(--blue-050)}
.line-tbl.perm td{text-align:center}
.line-tbl.perm td:first-child{text-align:left;font-size:12.5px;white-space:nowrap}
.line-tbl.perm input[type=checkbox]{width:auto}
.badge.ok2{background:#e6f4ec;color:var(--pos)}
.badge.pend{background:#fdf0e3;color:var(--warn)}
.report-row{display:flex;justify-content:space-between;align-items:center;padding:11px 18px;border-bottom:1px solid var(--line);font-size:13.5px}
.report-row:last-child{border-bottom:0}
.report-row.tot{font-weight:700;background:#f9fbfd}
.report-row .num{font-family:'JetBrains Mono',monospace;font-variant-numeric:tabular-nums}
.warnbar{background:#fdf0e3;border:1px solid #f0d4a8;color:#8a5a12;font-size:12.5px;padding:11px 14px;border-radius:9px;margin-bottom:16px}
.modal.wide{max-width:760px}
@media print{.side,.topbar,.page-head .actions,.tabs{display:none!important}.shell{grid-template-columns:1fr}.content{padding:0}}

/* ===== attachments (camera + file) ===== */
.attach-btns{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}
.attach-btns .btn-ghost{font-size:13px}
.attach-list{display:flex;flex-direction:column;gap:6px}
.attach-item{display:flex;align-items:center;gap:10px;background:#f6f8fa;border:1px solid var(--line);border-radius:8px;padding:7px 10px;font-size:12.5px}
.attach-item .nm{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.attach-item .sz{font-family:'JetBrains Mono',monospace;color:var(--ink-soft);font-size:11px}

/* ===== security policy screen ===== */
.toggle{display:flex;align-items:center;gap:9px;font-size:13.5px;cursor:pointer}
.toggle input{width:auto}
.hint{font-size:12px;color:var(--ink-soft);margin:0 0 8px}
.mono-area{width:100%;padding:10px 12px;border:1px solid var(--line-strong);border-radius:9px;font-family:'JetBrains Mono',monospace;font-size:12.5px;background:#fcfdfe;resize:vertical}
.mono-area:focus{outline:0;border-color:var(--blue);box-shadow:0 0 0 2px var(--blue-050)}
.secwin{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:10px 0;border-bottom:1px solid var(--line)}
.secdays{display:flex;gap:4px;flex-wrap:wrap}
.daychip{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;background:#f3f5f8;border:1px solid var(--line);border-radius:6px;padding:4px 7px;cursor:pointer}
.daychip input{width:auto}
.fromto{font-size:12.5px;color:var(--ink-soft)}
.fromto input{padding:6px 8px;border:1px solid var(--line-strong);border-radius:7px;font-size:12.5px}

/* ===== item master (tabbed) ===== */
.tabpane{padding-top:4px}
.flagrow{display:flex;gap:18px;flex-wrap:wrap;margin-bottom:4px}
.chk{display:inline-flex;align-items:center;gap:7px;font-size:13px;cursor:pointer}
.chk input{width:auto}
.itemthumb{width:38px;height:38px;border-radius:8px;object-fit:cover;background:#eef1f4;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--ink-soft);border:1px solid var(--line)}
.itemthumb.ph{font-family:'JetBrains Mono',monospace}
.thumbs{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:10px}
.thumb{position:relative;width:96px}
.thumb img{width:96px;height:96px;object-fit:cover;border-radius:10px;border:1px solid var(--line);background:#eef1f4}
.thumb-x{position:absolute;top:-6px;right:-6px;width:22px;height:22px;border-radius:50%;border:0;background:var(--neg);color:#fff;cursor:pointer;font-size:12px;line-height:1}
.thumb-set{display:block;width:100%;margin-top:4px;font-size:10.5px;background:none;border:0;color:var(--blue);cursor:pointer}
.thumb-primary{display:block;margin-top:4px;font-size:10px;text-align:center;color:var(--pos);font-weight:700;text-transform:uppercase;letter-spacing:.05em}

/* ===== sales order ===== */
.netchip{float:right;font-family:inherit;font-size:12px;letter-spacing:0;text-transform:none;color:var(--ink-soft)}
.netchip b{color:var(--blue);font-size:13px}
.inforow{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 24px}
@media(min-width:560px){.inforow{grid-template-columns:repeat(4,1fr)}}
.kv{display:flex;flex-direction:column;gap:2px}
.kv .k{font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);font-family:'JetBrains Mono',monospace}
.kv .v{font-size:13px;color:var(--ink)}

/* ===== Relationship Map (SAP B1 document flow) ===== */
.rm-legend{display:flex;gap:16px;flex-wrap:wrap;font-size:11.5px;color:var(--ink-soft);margin-bottom:12px}
.rm-legend span{display:inline-flex;align-items:center;gap:5px}
.rm-swatch.entry{width:14px;height:14px;border-radius:4px;border:1px solid #e0962a;box-shadow:0 0 0 2px #fbeed2;display:inline-block}
.rm-flow{display:flex;align-items:stretch;overflow-x:auto;padding:4px 2px 8px}
.rm-node{flex:0 0 160px;border:1px solid var(--line);border-radius:12px;background:var(--card);padding:11px 12px;position:relative}
.rm-node.entry{border-color:#e0962a;box-shadow:0 0 0 3px #fbeed2}
.rm-node .rm-kind{font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);font-weight:700}
.rm-node .rm-no{font-size:13.5px;font-weight:700;margin:3px 0}
.rm-node .rm-amt{font-size:12px;color:var(--ink-soft)}
.rm-node .rm-st{display:flex;align-items:center;gap:6px;margin-top:8px;font-size:11px;color:var(--ink-soft)}
.rm-node .rm-glyphs{position:absolute;top:9px;right:10px;font-size:11px}
.rm-conn{flex:0 0 30px;display:flex;align-items:center;justify-content:center;color:var(--line-strong);font-size:18px}
.rm-flow .dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.rm-flow .dot.open{background:var(--pos)} .rm-flow .dot.part{background:var(--warn)} .rm-flow .dot.closed{background:var(--ink-soft)}
.rm-open{position:absolute;bottom:8px;right:9px}
.ga{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;border:1px solid transparent;border-radius:4px;background:transparent;color:#e0962a;font-weight:800;font-size:13px;cursor:pointer;line-height:1}
.ga:hover{background:#fbf1de;border-color:#e6cf9b}
.u-paid{border-bottom:2px solid var(--pos)} .u-unpaid{border-bottom:2px solid var(--neg)}

/* ===== SAP B1 document layout (full-page marketing document) ===== */
.sapdoc-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.sapdoc-toolbar .seg{display:flex;border:1px solid var(--line-strong);border-radius:8px;overflow:hidden}
.sapdoc-toolbar .seg button{background:#fff;border:0;border-right:1px solid var(--line);padding:6px 12px;font-size:12.5px;color:var(--ink-soft);cursor:pointer}
.sapdoc-toolbar .seg button:last-child{border-right:0}
.sapdoc-toolbar .seg button.on{background:var(--blue);color:#fff}
.sapdoc-tbtn{background:#fff;border:1px solid var(--line-strong);border-radius:8px;padding:6px 12px;font-size:12.5px;color:var(--ink);cursor:pointer;display:inline-flex;align-items:center;gap:6px}
.sapdoc-tbtn:hover:not(:disabled){border-color:var(--blue);color:var(--blue)}
.sapdoc-tbtn:disabled{opacity:.45;cursor:not-allowed}
.sapdoc-tbtn.primary{background:var(--blue);border-color:var(--blue);color:#fff}
.sapdoc-tbtn.primary:hover{background:var(--blue-700)}
.sapdoc-sp{flex:1}
.sapdoc-nav{display:inline-flex;gap:3px}
.sapdoc-nav .sapdoc-tbtn{padding:6px 9px}
.sapdoc{background:var(--card);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);overflow:hidden}
.sapdoc-head{display:flex;justify-content:space-between;gap:20px;padding:18px 22px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,#fbfdff,#fff)}
.sapdoc-title{font-size:20px;font-weight:800;margin:0}
.sapdoc-no{color:var(--ink-soft);font-size:12.5px;margin-top:3px}
.statuschip{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line-strong);border-radius:999px;padding:5px 12px;font-size:12px;font-weight:600;background:#fff}
.statuschip .dot{width:8px;height:8px;border-radius:50%;background:var(--warn);display:inline-block}
.statuschip.s-done .dot{background:var(--pos)}
.statuschip.s-cancel .dot{background:var(--neg)}
.sapdoc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px 26px;padding:18px 22px}
.sapdoc-grid .f label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);margin-bottom:3px;font-weight:600}
.sapdoc-grid .f input,.sapdoc-grid .f select{width:100%;border:1px solid var(--line-strong);border-radius:8px;padding:7px 9px;font-size:14px;font-family:inherit}
.sapdoc-grid .f .ro{font-size:14px;padding:7px 0}
.cfl{display:flex;align-items:center;gap:6px;border:1px solid var(--line-strong);border-radius:8px;padding:0 8px;background:#fff}
.cfl select,.cfl input{border:0;outline:0;flex:1;font-size:14px;font-family:inherit;background:transparent;padding:7px 0}
.ga{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;border-radius:4px;color:#e0962a;font-weight:800;font-size:13px;border:0;background:transparent;cursor:pointer;line-height:1}
.ga:hover{background:#fbf1de}
.sapdoc .tabs{display:flex;gap:2px;padding:0 22px;border-bottom:1px solid var(--line);background:#fff;overflow-x:auto}
.sapdoc .tabs button{background:transparent;border:0;border-bottom:2px solid transparent;padding:12px 14px;font-size:13px;font-weight:600;color:var(--ink-soft);white-space:nowrap;cursor:pointer}
.sapdoc .tabs button.on{color:var(--blue);border-bottom-color:var(--blue)}
.sapdoc .tabpane{padding:16px 22px}
.linegrid{width:100%;border-collapse:collapse;font-size:13px}
.linegrid th{text-align:right;font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);padding:8px;border-bottom:1px solid var(--line)}
.linegrid th:nth-child(1),.linegrid th:nth-child(2){text-align:left}
.linegrid td{padding:5px 6px;border-bottom:1px solid var(--line);vertical-align:middle}
.linegrid td.r{text-align:right}
.linegrid input,.linegrid select{border:1px solid transparent;border-radius:6px;padding:6px;font-size:13px;font-family:inherit;width:100%;background:transparent}
.linegrid input:focus,.linegrid select:focus{border-color:var(--blue);background:#fff;outline:0}
.linegrid input.num{text-align:right}
.linegrid td.ln-total{font-weight:600;white-space:nowrap}
.linegrid .ln-del{border:0;background:transparent;color:var(--neg);cursor:pointer;font-size:13px;width:auto}
.addrow-btn{margin-top:8px;background:#fff;border:1px dashed var(--line-strong);border-radius:8px;padding:8px 12px;color:var(--blue);font-size:12.5px;cursor:pointer}
.sapdoc-foot{display:grid;grid-template-columns:1fr 320px;gap:24px;padding:18px 22px;border-top:1px solid var(--line);background:#fbfdff}
.sapdoc-foot textarea{width:100%;min-height:84px;border:1px solid var(--line-strong);border-radius:8px;padding:10px;font-family:inherit;font-size:13px;margin-top:4px}
.totbox .row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px dashed var(--line);font-size:13px}
.totbox .row input{width:120px;text-align:right;border:1px solid var(--line-strong);border-radius:6px;padding:4px 6px;font-family:inherit}
.totbox .row.grand{border-bottom:0;border-top:2px solid var(--ink);margin-top:4px;padding-top:10px;font-weight:800;font-size:16px}
.ro-grid{width:100%;border-collapse:collapse;font-size:13px}
.ro-grid th{text-align:right;font-size:10.5px;text-transform:uppercase;color:var(--ink-soft);padding:8px;border-bottom:1px solid var(--line)}
.ro-grid th:first-child{text-align:left}
.ro-grid td{padding:8px;border-bottom:1px solid var(--line);text-align:right}
.ro-grid td:first-child{text-align:left}
@media(max-width:760px){.sapdoc-grid{grid-template-columns:1fr}.sapdoc-foot{grid-template-columns:1fr}}
