.sidebar nav{display:flex;flex-direction:column;gap:4px}
.sidebar details{margin:2px 0}
.sidebar details>summary{list-style:none;cursor:pointer;padding:9px 14px;border-radius:10px;color:#9fb0c9;font-size:11px;letter-spacing:.06em;text-transform:uppercase;font-weight:700;display:flex;align-items:center;justify-content:space-between}
.sidebar details>summary::-webkit-details-marker{display:none}
.sidebar details>summary::after{content:"\25B8";transition:transform .2s;opacity:.6}
.sidebar details[open]>summary::after{transform:rotate(90deg)}
.sidebar details>summary:hover{background:#1d2939;color:#fff}
.sidebar .group-links{display:flex;flex-direction:column;gap:3px;margin:2px 0 6px;padding-left:10px;border-left:1px solid #26344a}
.sidebar .group-links a{padding:9px 12px;border-radius:10px;color:#d8e1f0;font-size:14px}
.sidebar .group-links a:hover{background:#1d2939;color:#fff}
.sidebar a.active{background:#2563eb!important;color:#fff!important}
.hamburger{display:none;margin-right:6px;background:#edf2fb}
.nav-overlay{display:none;border:0;padding:0}
.topbar{gap:10px}
.info-wrap{position:relative;flex:0 0 auto}
.info-btn{width:36px;height:36px;border-radius:50%;border:0;background:#eef2fb;color:#2563eb;font-weight:800;font-size:15px;cursor:pointer;font-style:italic}
.info-btn:hover{background:#dbe6fb}
.info-pop{position:absolute;right:0;top:46px;width:290px;max-width:82vw;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 12px 30px rgba(15,23,42,.16);padding:14px 16px;font-size:13px;color:#334155;line-height:1.55;z-index:70;display:none}
.info-pop.open{display:block}
.info-pop h4{margin:0 0 6px;font-size:14px}
.rbac-tree{display:flex;flex-direction:column;gap:8px}
.rbac-group{border:0}
.rbac-parent{list-style:none;cursor:pointer;display:flex;align-items:center;gap:12px;flex-wrap:wrap;background:#f1f5fb;border:1px solid #dbe4f3;border-radius:14px;padding:12px 16px}
.rbac-parent::-webkit-details-marker{display:none}
.rbac-parent .rbac-mod{flex:1 1 auto}
.rbac-parent .rbac-name{font-weight:800;font-size:15px}
.rbac-children{margin:8px 0 4px 16px;border-left:2px solid #e5e9f2;padding-left:14px;display:flex;flex-direction:column;gap:8px;transition:opacity .2s}
.rbac-children.dim{opacity:.45}
.rbac-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;background:#fff;border:1px solid #eef2f7;border-radius:14px;padding:11px 15px;box-shadow:0 3px 12px rgba(15,23,42,.04)}
.rbac-mod{display:flex;align-items:center;gap:12px;flex:1 1 auto}
.rbac-ico{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#eef2ff,#dbeafe);display:inline-flex;align-items:center;justify-content:center;font-size:18px;flex:0 0 auto}
.rbac-ico.sm{width:32px;height:32px;font-size:15px}
.rbac-name{font-weight:700;color:#0f172a;white-space:nowrap}
.crud{display:flex;gap:12px 16px;flex-wrap:wrap;align-items:center;justify-content:flex-end;margin-left:auto}
.sw-item{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;color:#334155;font-weight:500;user-select:none}
.sw{width:40px;height:23px;border-radius:999px;background:#cbd5e1;position:relative;flex:0 0 auto;transition:background .15s}
.sw::after{content:"";position:absolute;top:2px;left:2px;width:19px;height:19px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.2);transition:left .15s}
.sw.on{background:#16a34a}
.sw.on::after{left:19px}
.form-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px;padding:16px 0 6px;border-top:1px solid #eef2f7}
.app-footer{margin-top:28px;padding:16px 0 calc(40px + env(safe-area-inset-bottom));text-align:center;color:#94a3b8;font-size:12px;border-top:1px solid #eef2f7}
.asset-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}
.asset-card{border:1px solid #e5e7eb;border-radius:14px;padding:14px;text-align:center;background:#fff}
.asset-card h4{margin:0 0 10px}
.asset-prev{background:#f1f5f9;border-radius:10px;padding:12px;min-height:90px;display:flex;align-items:center;justify-content:center;margin-bottom:10px}
.asset-prev img{max-width:100%;max-height:120px;object-fit:contain}
.asset-prev.empty{color:#94a3b8}
@media(min-width:901px){body.collapsed .sidebar{width:86px}}
@media(max-width:900px){
  .app{display:block}
  .sidebar{position:fixed;top:0;left:0;height:100dvh;width:272px;z-index:60;transform:translateX(-100%);transition:transform .25s ease;overflow-y:auto;box-shadow:0 0 40px rgba(0,0,0,.4)}
  body.nav-open .sidebar{transform:translateX(0)}
  .nav-overlay{position:fixed;inset:0;background:rgba(2,6,23,.55);z-index:50}
  body.nav-open .nav-overlay{display:block}
  .content{padding:14px}
  .hamburger{display:inline-flex}
  .topbar{position:sticky;top:0;z-index:40}
  .crud{gap:10px 14px}
  .rbac-children{margin-left:8px;padding-left:10px}
}
html{background:#f5f7fb}
body.nav-open{overflow:hidden}
@media(max-width:900px){.app{min-height:100dvh}.nav-overlay{height:100dvh}}

.panel{overflow-x:auto}
.appbar{position:fixed;top:0;left:0;right:0;height:58px;background:#101828;color:#fff;display:flex;align-items:center;gap:12px;padding:0 14px;z-index:150;box-shadow:0 2px 10px rgba(0,0,0,.18)}
.appbar .hamburger{display:none;background:rgba(255,255,255,.14);color:#fff;border:0}
.appbar-logo{display:flex;align-items:center;color:#fff}.appbar-logo b{font-size:18px;color:#fff}
.appbar-title{font-weight:600;color:#cbd5e1}
.appbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.appbar .info-wrap,.appbar .profile-wrap{position:relative}
.appbar .info-btn{background:rgba(255,255,255,.14);color:#fff;border:0;width:30px;height:30px;border-radius:50%;cursor:pointer}
.profile-btn{background:rgba(255,255,255,.14);color:#fff;border:0;border-radius:10px;padding:8px 12px;cursor:pointer;font-size:14px}
.profile-pop{display:none;position:absolute;right:0;top:44px;background:#fff;color:#111;border-radius:12px;box-shadow:0 14px 34px rgba(0,0,0,.22);min-width:210px;padding:8px;z-index:200}
.profile-pop.open{display:block}
.profile-pop .pinfo{padding:8px 10px;border-bottom:1px solid #eef2f7;margin-bottom:4px}
.profile-pop a{display:block;padding:9px 10px;border-radius:8px;color:#334155}
.profile-pop a:hover{background:#f1f5f9}
.app{padding-top:58px}
@media(min-width:901px){.sidebar{position:sticky;top:58px;height:calc(100vh - 58px)}}
@media(max-width:900px){.appbar .hamburger{display:inline-flex}.appbar-title{display:none}.sidebar{position:fixed;top:58px;left:0;height:calc(100dvh - 58px);z-index:140;transition:transform .2s}body:not(.nav-open) .sidebar{transform:translateX(-100%)}body.nav-open .sidebar{transform:none}.nav-overlay{position:fixed;inset:58px 0 0 0;background:rgba(0,0,0,.4);border:0;display:none}body.nav-open .nav-overlay{display:block}}
.tbl-ctrl{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:2px 0 12px;font-size:13px;color:#64748b}
.tbl-ctrl select{width:auto;padding:5px 8px;border-radius:8px}
.tbl-pager{display:flex;gap:4px;margin-left:auto;flex-wrap:wrap}
.tbl-pg{border:1px solid #cbd5e1;background:#fff;border-radius:8px;padding:5px 10px;cursor:pointer;font-size:13px;color:#334155}
.tbl-pg.act{background:#2563eb;color:#fff;border-color:#2563eb}
.tbl-pg:disabled{opacity:.4;cursor:default}
th .sort-arrow{font-size:11px;margin-left:4px;user-select:none}
.tbl-ctrl .tbl-xls,.tbl-ctrl .tbl-pdf{border:1px solid #cbd5e1;background:#fff;border-radius:8px;padding:5px 10px;cursor:pointer;font-size:13px;color:#334155}
.tbl-ctrl .tbl-xls:hover,.tbl-ctrl .tbl-pdf:hover{background:#f1f5f9}
@media print{
  .appbar,.sidebar,.nav-overlay,.app-footer,.tbl-ctrl,.hamburger,.actions,#delModal{display:none!important}
  .app{padding-top:0!important} .content{padding:0!important}
  .panel{box-shadow:none!important;border:1px solid #ccc!important;break-inside:avoid;margin:0 0 10px}
  body{background:#fff!important}
  a[href]:after{content:""}
}
/* ===== design-polish-v1 ===== */
:root{--radius:14px;--shadow:0 6px 20px rgba(16,24,40,.06)}
body{font-family:Inter,"Segoe UI",system-ui,Arial,sans-serif;color:#1f2937}
h2{font-size:19px;font-weight:700} h3{font-size:16px;font-weight:700}
.panel{border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid #eef1f6}
.card{border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid #eef1f6}
.card b{letter-spacing:-.5px}
.btn,button{transition:filter .15s,box-shadow .15s,background .15s;font-weight:600}
.btn:hover{filter:brightness(.96)}
.btn.primary,.primary{box-shadow:0 4px 12px rgba(37,99,235,.22)}
input,select,textarea{transition:border-color .15s,box-shadow .15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.15)}
table{border-collapse:separate;border-spacing:0}
table th{font-size:12px;text-transform:uppercase;letter-spacing:.4px;color:#64748b;font-weight:700}
table tbody tr:hover{background:#f8fafc}
.badge{font-weight:600}
.alert{border-radius:12px;font-size:14px;border:1px solid transparent}
.alert.success{border-color:#bbf7d0}.alert.error{border-color:#fecaca}
.sidebar details{margin-bottom:2px}
.sidebar details>summary{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:#8ea2c0;padding:12px 14px 4px;cursor:pointer;list-style:none}
.sidebar details>summary::-webkit-details-marker{display:none}
.sidebar a{border-radius:10px}
.sidebar a.active{background:#2563eb;color:#fff;font-weight:600}
.group-links a{font-size:14px}
.tbl-ctrl{align-items:center}
/* ===== sidebar-scroll-fix ===== */
.sidebar{overflow-y:auto;overflow-x:hidden}
.sidebar::-webkit-scrollbar{width:8px}
.sidebar::-webkit-scrollbar-thumb{background:#33415580;border-radius:8px}
.sidebar::-webkit-scrollbar-track{background:transparent}
@media(min-width:901px){.sidebar{position:sticky;top:58px;height:calc(100vh - 58px)}}
@media(max-width:900px){.sidebar{position:fixed;top:58px;left:0;height:calc(100dvh - 58px)}}
/* ===== nav-accordion ===== */
.sidebar details>summary{position:relative;padding-right:30px}
.sidebar details>summary::after{content:"\25B8";position:absolute;right:14px;top:12px;opacity:.6;transition:transform .2s}
.sidebar details[open]>summary::after{transform:rotate(90deg)}
.nav-search{width:100%;box-sizing:border-box;margin:0 0 10px;padding:9px 11px;border-radius:10px;border:1px solid #334155;background:#1d2939;color:#fff;font-size:13px}
.nav-search::placeholder{color:#8ea2c0}
.nav-search:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.25)}
/* ===== mobile-cards ===== */
@media(max-width:760px){
  .panel{overflow-x:visible}
  .content table{white-space:normal;overflow:visible;display:block;border-spacing:0}
  .content table thead{display:none}
  .content table tbody{display:block}
  .content table tr{display:block;margin:0 0 12px;border:1px solid #e5e7eb;border-radius:12px;padding:6px 12px;background:#fff;box-shadow:0 2px 8px rgba(16,24,40,.05)}
  .content table td{display:flex;justify-content:space-between;gap:12px;align-items:center;border:0;border-bottom:1px solid #f1f5f9;padding:10px 2px;text-align:right}
  .content table td:last-child{border-bottom:0}
  .content table td[data-label]::before{content:attr(data-label);font-weight:600;color:#64748b;text-align:left;flex:0 0 42%}
  .content table td.actions{justify-content:flex-start;flex-wrap:wrap;gap:8px}
  .btn,button{padding:11px 15px;font-size:14px}
  .actions a{padding:9px 12px;font-size:13px}
  .form-grid{grid-template-columns:1fr}
  .tbl-ctrl{gap:8px;flex-wrap:wrap}
  h2{font-size:18px}
}
/* ===== empty-state-polish ===== */
td.hint{text-align:center;padding:26px 12px !important;color:#94a3b8}
@media(max-width:760px){ td.hint{display:block !important} td.hint::before{content:"" !important} }
/* ===== theme-vars-surfaces ===== */
.appbar{background:var(--header-bg,#101828)!important;color:var(--header-text,#fff)!important}
.appbar-title,.appbar-logo b{color:var(--header-text,#fff)!important}
.profile-btn,.appbar .info-btn,.appbar .hamburger{color:var(--header-text,#fff)!important}
.sidebar{background:var(--sidebar-bg,#101828)!important;color:var(--sidebar-text,#d8e1f0)!important}
.sidebar a{color:var(--sidebar-text,#d8e1f0)!important}
.sidebar a.active{background:var(--primary,#2563eb)!important;color:#fff!important}
.sidebar details>summary{color:var(--sidebar-text,#94a3b8)!important;opacity:.75}
body{background:var(--body-bg,#f5f7fb)!important}
input[type=color]{width:56px;height:36px;padding:2px;border-radius:8px;cursor:pointer}
.preset{border:1px solid #cbd5e1}
/* ===== login-page-themed ===== */
.login-page{background:linear-gradient(135deg,var(--sidebar-bg,#101828),var(--primary,#2563eb))!important}
/* ===== table-polish ===== */
.content table tbody tr:nth-child(odd){background:#fafbfc}
.content table tbody tr:hover{background:#eef4ff}
.content table th{background:#f1f5f9;background:color-mix(in srgb,var(--primary,#2563eb) 9%,#ffffff)}
.content table td{font-variant-numeric:tabular-nums}
td.cell-num{text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums}
td.cell-neg{color:#dc2626;font-weight:600}
@media(min-width:901px){ .content table thead th{position:sticky;top:58px;z-index:2} }
@media(max-width:760px){ .content table tbody tr:nth-child(odd){background:#fff} .content table td.cell-num{white-space:normal} }
/* ===== row-status ===== */
.content table tbody tr.rowok{background:#f0fdf4}
.content table tbody tr.rowok:hover{background:#dcfce7}
.content table tbody tr.rowwarn{background:#fffbeb}
.content table tbody tr.rowwarn:hover{background:#fef3c7}
.content table tbody tr.rowbad{background:#fef2f2}
.content table tbody tr.rowbad:hover{background:#fee2e2}
.content table tbody tr.rowok td:first-child{box-shadow:inset 4px 0 0 #16a34a}
.content table tbody tr.rowwarn td:first-child{box-shadow:inset 4px 0 0 #f59e0b}
.content table tbody tr.rowbad td:first-child{box-shadow:inset 4px 0 0 #dc2626}
@media(max-width:760px){
  .content table tr.rowok{border-left:4px solid #16a34a}
  .content table tr.rowwarn{border-left:4px solid #f59e0b}
  .content table tr.rowbad{border-left:4px solid #dc2626}
}
/* ===== print-simple ===== */
.print-only{display:none}
@media print{
  .tbl-ctrl,.act-toggle,.nav-search,.sort-arrow{display:none!important}
  .print-only{display:block!important}
  .print-header{border-bottom:2px solid #000;padding-bottom:6px;margin-bottom:12px;font-size:14px}
  .panel,.card{box-shadow:none!important;border:1px solid #ccc!important;page-break-inside:avoid}
  .content table tbody tr{background:#fff!important}
  .content table tbody tr td:first-child{box-shadow:none!important}
  .content table th{background:#eee!important;color:#000!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .content table td,.content table th{border:1px solid #999!important}
  .badge{background:#fff!important;color:#000!important;border:1px solid #999}
  .act-menu{display:inline-flex!important;position:static!important;box-shadow:none!important;border:0!important;padding:0!important}
  body{font-size:12px;color:#000;background:#fff!important}
}
/* ===== actions dropdown (mobile) ===== */
.act-toggle{display:none}
.act-menu{display:inline-flex;gap:8px;align-items:center;flex-wrap:wrap}
@media(max-width:760px){
  td.actions,.actions{position:relative;justify-content:flex-end!important}
  .act-toggle{display:inline-flex;background:#eef2ff;color:#3730a3;border:0;border-radius:8px;padding:6px 12px;cursor:pointer;font-size:18px;line-height:1}
  .act-menu{display:none;position:absolute;right:0;top:calc(100% + 4px);background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 12px 28px rgba(0,0,0,.18);padding:8px;z-index:60;flex-direction:column;align-items:stretch;min-width:160px}
  .act-menu.open{display:flex}
  .act-menu a{display:block;padding:9px 10px;border-radius:8px}
  .act-menu a:hover{background:#f1f5f9}
  .act-menu form{margin:0}.act-menu form button{width:100%}
}

/* ===== actions dropdown (all screens) ===== */
td.actions,.actions{position:relative}
.act-toggle{display:inline-flex;background:#eef2ff;color:#3730a3;border:0;border-radius:8px;padding:6px 12px;cursor:pointer;font-size:18px;line-height:1}
.act-menu{display:none;position:absolute;right:0;top:calc(100% + 4px);background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 12px 28px rgba(0,0,0,.18);padding:8px;z-index:60;flex-direction:column;align-items:stretch;min-width:170px}
.act-menu.open{display:flex}
.act-menu a{display:block;padding:9px 10px;border-radius:8px}
.act-menu a:hover{background:#f1f5f9}
.act-menu form{margin:0}.act-menu form button{width:100%}
@media print{.act-toggle{display:none!important}.act-menu{display:inline-flex!important;position:static!important;box-shadow:none!important;border:0!important;padding:0!important}}

/* dropup saat dekat bawah layar */
.act-menu.up{top:auto!important;bottom:calc(100% + 4px)!important}

/* ===== mobile-compact-v1 (kartu lebih ramping) ===== */
@media(max-width:900px){
  .content table td{padding:5px 10px!important;font-size:13px!important;line-height:1.4!important}
  .content table td::before{font-size:11px!important}
  .content table tr{margin-bottom:8px!important}
  /* khusus kartu Inbox Transaksi: sembunyikan kolom sekunder */
  #inboxTbl td[data-label="Tipe"],
  #inboxTbl td[data-label="Debit"],
  #inboxTbl td[data-label="Kredit"]{display:none!important}
  #inboxTbl td[data-label="Keterangan"]{font-size:12px!important;color:#64748b}
  #inboxTbl td:empty{display:none!important}
}

/* ===== mobile-mbanking-v2 (4 sel: partner+keterangan kiri, nominal+status kanan) ===== */
@media(max-width:900px){
  #inboxTbl tr.mtrx{display:grid!important;grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"partner amount" "desc status";gap:2px 12px;align-items:center;padding:10px 12px!important}
  #inboxTbl tr.mtrx td{display:block!important;padding:0!important;margin:0!important;border:none!important;min-height:0!important;font-size:13px!important;background:none!important}
  #inboxTbl tr.mtrx td::before{display:none!important}
  #inboxTbl tr.mtrx td:first-child,
  #inboxTbl tr.mtrx td[data-label="Tanggal"],
  #inboxTbl tr.mtrx td[data-label="Aksi"],
  #inboxTbl tr.mtrx td:last-child{display:none!important}
  #inboxTbl tr.mtrx td[data-label="Partner"]{grid-area:partner;font-weight:700;font-size:14px!important;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  #inboxTbl tr.mtrx td[data-label="Keterangan"]{grid-area:desc;font-size:12px!important;color:#64748b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  #inboxTbl tr.mtrx td[data-label="Nominal"]{grid-area:amount;font-weight:700;text-align:right;white-space:nowrap}
  #inboxTbl tr.mtrx td[data-label="Status"]{grid-area:status;justify-self:end}
  #inboxTbl tr.mtrx.mtrx-income td[data-label="Nominal"]{color:#16a34a}
  #inboxTbl tr.mtrx.mtrx-expense td[data-label="Nominal"],#inboxTbl tr.mtrx.mtrx-purchase td[data-label="Nominal"]{color:#dc2626}
  #inboxTbl tr.mtrx.mtrx-transfer td[data-label="Nominal"]{color:#2563eb}
  #inboxTbl tr.mtrx.mtrx-income td[data-label="Nominal"]::before{content:"+";display:inline!important}
  #inboxTbl tr.mtrx.mtrx-expense td[data-label="Nominal"]::before,#inboxTbl tr.mtrx.mtrx-purchase td[data-label="Nominal"]::before{content:"-";display:inline!important}
}

/* ===== mobile-mbanking-v2-1 (fix hide + kartu bisa diketuk) ===== */
@media(max-width:900px){
  #inboxTbl tr.mtrx{cursor:pointer}
  #inboxTbl tr.mtrx td[data-label="Tipe"],
  #inboxTbl tr.mtrx td[data-label="Debit"],
  #inboxTbl tr.mtrx td[data-label="Kredit"]{display:none!important}
  /* saat kartu diketuk (terbuka): tampilkan info lain + aksi */
  #inboxTbl tr.mtrx.xopen td[data-label="Tipe"],
  #inboxTbl tr.mtrx.xopen td[data-label="Debit"],
  #inboxTbl tr.mtrx.xopen td[data-label="Kredit"],
  #inboxTbl tr.mtrx.xopen td[data-label="Tanggal"]{display:block!important;grid-column:1/-1;grid-area:auto;font-size:12px!important;color:#475569;justify-self:start}
  #inboxTbl tr.mtrx.xopen td[data-label="Tipe"]::before,
  #inboxTbl tr.mtrx.xopen td[data-label="Debit"]::before,
  #inboxTbl tr.mtrx.xopen td[data-label="Kredit"]::before,
  #inboxTbl tr.mtrx.xopen td[data-label="Tanggal"]::before{content:attr(data-label) ": ";display:inline!important;color:#94a3b8}
  #inboxTbl tr.mtrx.xopen td[data-label="Aksi"],
  #inboxTbl tr.mtrx.xopen td:last-child{display:block!important;grid-column:1/-1;grid-area:auto;justify-self:start;padding-top:8px!important;border-top:1px dashed #e2e8f0!important;width:100%}
}

/* ===== mobile-mbanking-v2-2 (perataan + fix tanda minus) ===== */
@media(max-width:900px){
  #inboxTbl tr.mtrx td[data-label="Partner"],
  #inboxTbl tr.mtrx td[data-label="Keterangan"]{text-align:left!important;justify-self:start;width:100%}
  #inboxTbl tr.mtrx td[data-label="Nominal"],
  #inboxTbl tr.mtrx td[data-label="Status"]{text-align:right!important;justify-self:end}
  #inboxTbl tr.mtrx.mtrx-income td[data-label="Nominal"]::before{content:"+";display:inline!important}
  #inboxTbl tr.mtrx.mtrx-expense td[data-label="Nominal"]::before,
  #inboxTbl tr.mtrx.mtrx-purchase td[data-label="Nominal"]::before{content:"-";display:inline!important}
  #inboxTbl tr.mtrx.mtrx-transfer td[data-label="Nominal"]::before{content:"";display:inline!important}
}

/* ===== inbox-desktop-sign-v1 (warna & tanda +/- di semua layar) ===== */
#inboxTbl tr.mtrx-income .tdnom{color:#16a34a!important;font-weight:600}
#inboxTbl tr.mtrx-income .tdnom::before{content:"+"}
#inboxTbl tr.mtrx-expense .tdnom,#inboxTbl tr.mtrx-purchase .tdnom{color:#dc2626!important;font-weight:600}
#inboxTbl tr.mtrx-expense .tdnom::before,#inboxTbl tr.mtrx-purchase .tdnom::before{content:"-"}
#inboxTbl tr.mtrx-transfer .tdnom{color:#2563eb!important;font-weight:600}

/* ===== filter-pop-responsive-v1 ===== */
@media(max-width:900px){
  #fltPop{left:0!important;right:0!important;width:auto!important;max-width:none!important}
  #fltPop form{flex-direction:column!important;align-items:stretch!important}
  #fltPop form input,#fltPop form select{width:100%!important;max-width:none!important;min-width:0!important;box-sizing:border-box}
  #fltPop form button,#fltPop form a.btn{width:100%!important;text-align:center;box-sizing:border-box}
}
@media(min-width:901px) and (max-width:1200px){
  #fltPop{width:440px!important}
}

/* ===== bulk-slim-v1 ===== */
#inboxTbl .blkchk{width:15px;height:15px;accent-color:#2563eb;cursor:pointer;margin:0}
#inboxTbl thead th:first-child{width:28px;font-size:12px;color:#94a3b8}
.bulk-btn{padding:3px 12px!important;font-size:12px!important;border-radius:99px!important;line-height:1.5}


/* ===== mobile-mbanking-v2-3 (centang & aksi massal di mobile) ===== */
@media(max-width:900px){
  #bulkForm{display:inline-flex!important;width:100%;box-sizing:border-box;border-radius:12px!important;justify-content:flex-start}
  #inboxTbl tr.mtrx{grid-template-columns:auto minmax(0,1fr) auto!important;grid-template-areas:"chk partner amount" "chk desc status"!important}
  #inboxTbl tr.mtrx td:first-child{display:block!important;grid-area:chk;align-self:center;width:auto!important}
  #inboxTbl tr.mtrx td:first-child:empty{display:block!important;width:15px}
}

/* ===== lock-zoom-v1 (mobile: kunci zoom & scroll samping) ===== */
html,body{overflow-x:hidden;max-width:100vw}
@media(max-width:900px){
  body{touch-action:pan-y}
  a,button,label,td,th{touch-action:manipulation}
  input,select,textarea{font-size:16px!important}
  .content{overflow-x:hidden}
}

/* ===== xopen-align-fix-v1 (baris detail kartu rapat kiri penuh) ===== */
@media(max-width:900px){
  #inboxTbl tr.mtrx.xopen td[data-label="Tipe"],
  #inboxTbl tr.mtrx.xopen td[data-label="Debit"],
  #inboxTbl tr.mtrx.xopen td[data-label="Kredit"],
  #inboxTbl tr.mtrx.xopen td[data-label="Tanggal"]{grid-column:1 / -1!important;grid-row:auto!important;justify-self:start!important;text-align:left!important;width:100%!important}
  #inboxTbl tr.mtrx.xopen td[data-label="Aksi"],
  #inboxTbl tr.mtrx.xopen td:last-child{grid-column:1 / -1!important;grid-row:auto!important;justify-self:start!important;text-align:left!important;width:100%!important}
}

/* ===== xopen-act-right-v1 (tombol Aksi di kanan bawah kartu terbuka) ===== */
@media(max-width:900px){
  #inboxTbl tr.mtrx.xopen td[data-label="Aksi"],
  #inboxTbl tr.mtrx.xopen td:last-child{justify-self:end!important;text-align:right!important;width:100%!important}
}

/* ===== xopen-act-side-v1 (Aksi kanan, sejajar baris 3-4) ===== */
@media(max-width:900px){
  #inboxTbl tr.mtrx.xopen{position:relative}
  #inboxTbl tr.mtrx.xopen td[data-label="Aksi"],
  #inboxTbl tr.mtrx.xopen td:last-child{position:absolute!important;right:12px;bottom:12px;width:auto!important;border-top:none!important;padding:0!important;grid-column:auto!important}
  #inboxTbl tr.mtrx.xopen td[data-label="Tipe"],
  #inboxTbl tr.mtrx.xopen td[data-label="Debit"],
  #inboxTbl tr.mtrx.xopen td[data-label="Kredit"],
  #inboxTbl tr.mtrx.xopen td[data-label="Tanggal"]{padding-right:64px!important}
}

/* ===== role-chip-hide-v1 (mobile: sembunyikan chip izin/user) ===== */
@media(max-width:900px){.role-chip{display:none!important}}

/* ===== split2-v1 ===== */
.split2{display:grid;grid-template-columns:1fr;gap:14px;align-items:start}
@media(min-width:901px){.split2{grid-template-columns:1fr 1fr}}
@media(max-width:900px){.desk-only{display:none!important}}
