*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  /* surfaces */
  --bg:#F3F6FB; --bg-2:#FFFFFF; --sunken:#EDF1F8;
  /* ink */
  --ink:#0B1220; --t2:#334155; --t3:#5B6A85; --muted:#5B6A85; --t4:#94A3B8;
  --line:#E4E9F2; --line-2:#D2DBEA;
  /* brand: navy + teal + gold (the gateway identity) */
  --teal:#0D9488; --teal-600:#0F766E; --teal-bg:#E5F4F2;
  --gold:#B8902A; --gold-bright:#D4AF37; --gold-bg:#FAF2D9;
  --green:#0E9C6F; --green-bg:#E6F8EE;
  --amber:#B7791F; --amber-bg:#FBF1DD;
  --red:#C8463B; --red-bg:#FBE7E5;
  --indigo:#4F46E5; --indigo-bg:#EEF0FE;
  --accent:var(--teal);                 /* repoints every legacy indigo usage to brand teal */
  --sidebar-1:#0A1020; --sidebar-2:#101c33;
  /* shape + depth */
  --r:14px; --r-sm:10px; --r-lg:18px;
  --sh-sm:0 1px 2px rgba(13,20,35,.05),0 1px 3px rgba(13,20,35,.05);
  --sh-md:0 6px 20px rgba(13,20,35,.09);
  --sh-lg:0 24px 56px rgba(13,20,35,.16);
  /* type */
  --fd:'Bricolage Grotesque',system-ui,-apple-system,'Segoe UI',sans-serif;
  --fb:system-ui,-apple-system,'Segoe UI',Roboto,Arial,sans-serif;
  --fm:'JetBrains Mono',ui-monospace,Menlo,Consolas,monospace;
}
body{font-family:var(--fb);background:var(--bg);color:var(--ink);line-height:1.5;-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:var(--fd);letter-spacing:-.01em}
.app{display:flex;min-height:100vh}

/* ===== sidebar ===== */
.side{width:236px;background:linear-gradient(180deg,var(--sidebar-2),var(--sidebar-1));color:#aeb9d0;display:flex;flex-direction:column;flex-shrink:0;position:sticky;top:0;height:100vh;align-self:flex-start;border-right:1px solid rgba(255,255,255,.04)}
.side-brand{display:flex;align-items:center;gap:9px;padding:16px 18px 12px}
.side-brand .mark{width:26px;height:26px;flex:0 0 26px}
.side-brand .wm{font-family:var(--fd);font-weight:800;font-size:.98rem;color:#fff;letter-spacing:-.01em}
.side-brand .wm b{color:var(--gold-bright);font-weight:800}
.side-h{padding:0 14px 14px;flex-shrink:0}
.brand-id{display:flex;align-items:center;gap:11px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:10px 11px}
.brand-av{width:38px;height:38px;flex:0 0 38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-weight:800;font-size:.95rem;color:#fff;box-shadow:inset 0 0 0 1px rgba(255,255,255,.18)}
.brand-meta{min-width:0}
.brand-meta .lbl{font-size:.6rem;letter-spacing:.1em;color:#7d8aa6;text-transform:uppercase;font-weight:700}
.brand-meta .name{color:#fff;font-family:var(--fd);font-weight:800;font-size:1rem;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nav{padding:6px 10px 12px;display:flex;flex-direction:column;gap:1px;font-size:.875rem;font-weight:600;flex:1 1 auto;min-height:0;overflow-y:auto}
.nav-cap{font-size:.62rem;letter-spacing:.11em;text-transform:uppercase;color:#5e6b86;font-weight:800;padding:14px 12px 5px}
.nav a{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:10px;color:#aeb9d0;text-decoration:none;cursor:pointer;position:relative;transition:background .14s,color .14s}
.nav a svg{width:17px;height:17px;flex:0 0 17px;opacity:.85}
.nav a:hover{background:rgba(255,255,255,.05);color:#fff}
.nav a.active{background:rgba(13,148,136,.16);color:#fff}
.nav a.active svg{opacity:1;color:var(--teal)}
.nav a.active::before{content:"";position:absolute;left:-10px;top:7px;bottom:7px;width:3px;border-radius:0 3px 3px 0;background:var(--gold-bright)}
.side-f{margin-top:auto;padding:13px 16px;border-top:1px solid rgba(255,255,255,.06);font-size:.82rem}
.side-f .email{color:#fff;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.side-f .out{color:#8b97b3;cursor:pointer;margin-top:3px;display:inline-flex;align-items:center;gap:6px}
.side-f .out:hover{color:var(--gold-bright)}

/* ===== main ===== */
.main{flex:1;display:flex;flex-direction:column;min-width:0}
.topbar{background:rgba(255,255,255,.86);backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--line);padding:15px 26px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;position:sticky;top:0;z-index:9}
.topbar h1{font-size:1.32rem;font-weight:800}
.topbar .sub{font-size:.82rem;color:var(--muted);margin-top:1px}
.content{padding:24px 26px;display:flex;flex-direction:column;gap:18px}

/* ===== controls ===== */
.btn{font:inherit;font-weight:650;border:1px solid var(--line);background:var(--bg-2);color:var(--ink);border-radius:10px;padding:8px 15px;cursor:pointer;transition:border-color .14s,box-shadow .14s,transform .04s}
.btn:hover{border-color:var(--teal);box-shadow:var(--sh-sm)}
.btn:active{transform:translateY(1px)}
.btn.primary{background:linear-gradient(180deg,var(--teal),var(--teal-600));color:#fff;border-color:var(--teal-600);box-shadow:0 2px 6px rgba(13,148,136,.28)}
.btn.primary:hover{box-shadow:0 4px 12px rgba(13,148,136,.34)}
.btn.sm{padding:6px 11px;font-size:.85rem}
input,select,textarea{font:inherit;padding:8px 11px;border:1px solid var(--line);border-radius:9px;background:#fff;color:var(--ink);transition:border-color .14s,box-shadow .14s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(13,148,136,.14)}

/* ===== cards / KPIs ===== */
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.grid2{display:grid;grid-template-columns:2fr 1fr;gap:14px}
.card{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r);padding:17px;box-shadow:var(--sh-sm)}
.card .k{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:700}
.card .v{font-family:var(--fd);font-size:1.62rem;font-weight:800;margin-top:7px;line-height:1.15;letter-spacing:-.02em}
.card .d{font-size:.74rem;font-weight:700;margin-top:5px}
.d.up{color:var(--green)}.d.flat{color:var(--muted)}.d.warn{color:var(--amber)}
/* KPI with accent + sparkline */
.kpi{position:relative;overflow:hidden}
.kpi::after{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--teal)}
.kpi.teal::after{background:var(--teal)}.kpi.gold::after{background:var(--gold-bright)}.kpi.green::after{background:var(--green)}.kpi.amber::after{background:var(--amber)}.kpi.red::after{background:var(--red)}.kpi.indigo::after{background:var(--indigo)}
.kpi .spark{margin-top:10px;height:30px}
.kpi .spark svg{display:block;width:100%;height:30px}

/* ===== money hero ===== */
.money-hero{display:grid;grid-template-columns:1.3fr 2fr;gap:1px;background:linear-gradient(135deg,#0A1020 0%,#10263a 55%,#0c3b39 100%);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-md);color:#fff;position:relative}
.money-hero::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:linear-gradient(90deg,var(--teal),var(--gold-bright))}
.mh-main{padding:22px 24px}
.mh-cap{font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:#9fb0c9;font-weight:700;display:flex;align-items:center;gap:7px}
.mh-amt{font-family:var(--fd);font-weight:800;font-size:2.5rem;line-height:1.1;letter-spacing:-.02em;margin-top:8px;font-variant-numeric:tabular-nums}
.mh-sub{font-size:.82rem;color:#b9c6da;margin-top:6px}
.mh-side{display:grid;grid-template-columns:1fr 1fr;background:rgba(255,255,255,.03)}
.mh-stat{padding:20px 22px;border-left:1px solid rgba(255,255,255,.07)}
.mhs-cap{font-size:.68rem;letter-spacing:.06em;text-transform:uppercase;color:#9fb0c9;font-weight:700}
.mhs-v{font-family:var(--fd);font-weight:800;font-size:1.45rem;margin-top:6px;font-variant-numeric:tabular-nums}
.mhs-sub{font-size:.76rem;color:#9fb0c9;margin-top:3px}
.mhs-v.gold{color:var(--gold-bright)}

/* ===== attention rail ===== */
.attn-rail{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}
.attn-rail:empty{display:none}
.attn{display:flex;align-items:center;gap:12px;background:var(--bg-2);border:1px solid var(--line);border-radius:12px;padding:13px 15px;text-decoration:none;color:var(--ink);box-shadow:var(--sh-sm);transition:border-color .14s,box-shadow .14s,transform .08s}
.attn:hover{border-color:var(--teal);box-shadow:var(--sh-md);transform:translateY(-1px)}
.attn.warn:hover{border-color:var(--amber)}.attn.bad:hover{border-color:var(--red)}
.attn-ic{flex:0 0 38px;width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--teal-bg);color:var(--teal)}
.attn.warn .attn-ic{background:var(--amber-bg);color:var(--amber)}.attn.bad .attn-ic{background:var(--red-bg);color:var(--red)}
.attn-ic svg{width:19px;height:19px}
.attn-tx{flex:1;min-width:0;font-size:.86rem;color:var(--t2);line-height:1.3}
.attn-tx b{font-family:var(--fd);font-weight:800;color:var(--ink)}
.attn-go{color:var(--t4);font-weight:800}

/* ===== interactive area chart ===== */
.mchart{position:relative;cursor:crosshair;margin-top:10px}
.mchart svg{display:block;width:100%}
.mc-guide{position:absolute;top:0;bottom:0;width:1px;background:var(--line-2);pointer-events:none;transform:translateX(-.5px)}
.mc-dot{position:absolute;width:9px;height:9px;border-radius:50%;background:#fff;pointer-events:none;transform:translate(-50%,-50%);box-shadow:0 0 0 2.5px currentColor}
.mc-tip{position:absolute;pointer-events:none;transform:translate(-50%,calc(-100% - 12px));background:var(--ink);color:#fff;padding:6px 10px;border-radius:9px;font-family:var(--fm);font-size:.68rem;line-height:1.35;white-space:nowrap;box-shadow:var(--sh-md);z-index:5}
.mc-tip b{font-family:var(--fd);font-size:.84rem;display:block}
.mc-tip span{opacity:.72}
.mc-axis{display:flex;justify-content:space-between;font-family:var(--fm);font-size:.64rem;color:var(--t4);margin-top:6px}

/* ===== panel + table ===== */
.panel{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-sm)}
.panel-h{padding:14px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.panel-h h2{font-size:1rem;font-weight:800}
table{width:100%;border-collapse:collapse;font-size:.875rem}
th,td{text-align:left;padding:11px 18px;border-bottom:1px solid #EEF1F7;white-space:nowrap}
thead th{background:#FAFBFE;font-size:.68rem;color:var(--t3);text-transform:uppercase;letter-spacing:.05em;font-weight:800;position:sticky;top:0}
tbody tr{transition:background .1s}
tbody tr:hover{background:#F7F9FD}
td.amt{font-family:var(--fm);font-variant-numeric:tabular-nums;font-weight:700}
/* Transactions table: keep it within the viewport - long reference/customer values truncate */
.tx-table{table-layout:fixed;width:100%}
.tx-table td.ref,.tx-table td.cust{max-width:0;overflow:hidden;text-overflow:ellipsis}
.tx-table th:nth-child(2),.tx-table td:nth-child(2){width:160px}
.tx-table th:nth-child(3),.tx-table td:nth-child(3){width:120px}
.tx-table th:nth-child(5),.tx-table td:nth-child(5){width:120px;text-align:right}
.tx-table th:nth-child(6),.tx-table td:nth-child(6){width:110px}
.tx-table th:nth-child(7),.tx-table td:nth-child(7){width:110px}
tr.clickable{cursor:pointer}
tr.clickable:hover{background:var(--teal-bg)}
.mono{font-family:var(--fm)}
.muted{color:var(--muted)}
.empty{padding:30px 18px;text-align:center;color:var(--muted)}

/* ===== pagination ===== */
.pager{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:12px 18px;border-top:1px solid var(--line)}
.pager:empty{display:none}
.pg-info{color:var(--muted);font-size:.82rem}
.pg-nav{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.pgbtn{font:inherit;font-size:.84rem;font-weight:600;min-width:34px;padding:7px 10px;border:1px solid var(--line);background:var(--bg-2);color:var(--ink);border-radius:8px;cursor:pointer}
.pgbtn:hover:not(:disabled):not(.active){background:var(--teal-bg);border-color:var(--teal)}
.pgbtn.active{background:var(--teal);border-color:var(--teal);color:#fff;cursor:default}
.pgbtn:disabled{opacity:.45;cursor:default}
.pg-ell{color:var(--muted);padding:0 4px}
.foot{padding:14px 18px;text-align:center}

/* ===== chips ===== */
.chip{display:inline-flex;align-items:center;gap:5px;padding:2px 10px;border-radius:999px;font-size:.73rem;font-weight:700;line-height:1.7}
.chip::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.9}
.chip.ok{background:var(--green-bg);color:var(--green)}
.chip.info{background:var(--indigo-bg);color:#3a44d8}
.chip.warn{background:var(--amber-bg);color:var(--amber)}
.chip.bad{background:var(--red-bg);color:var(--red)}

/* ===== drawer ===== */
.drawer-bg{position:fixed;inset:0;background:rgba(11,18,32,.42);display:none;backdrop-filter:blur(2px)}
.drawer-bg.open{display:block}
.drawer{position:fixed;top:0;right:0;height:100vh;width:380px;max-width:94vw;background:#fff;border-left:1px solid var(--line);box-shadow:var(--sh-lg);transform:translateX(100%);transition:transform .2s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;z-index:20}
.drawer.open{transform:translateX(0)}
.drawer-h{padding:16px 20px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.drawer-h h2{font-size:1.05rem;font-weight:800}
.drawer-b{padding:20px;display:flex;flex-direction:column;gap:16px;overflow:auto}
.kv{display:grid;grid-template-columns:1fr 1fr;gap:12px;font-size:.85rem}
.kv .k{color:var(--muted);font-size:.68rem;text-transform:uppercase;letter-spacing:.04em;font-weight:700}
.timeline{display:flex;flex-direction:column;gap:10px;font-size:.82rem}
.timeline .dot{color:var(--green);margin-right:8px}
.cols2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
/* vertical status stepper (transaction drawer) */
.vstep{display:flex;flex-direction:column}
.vstep .s{display:flex;gap:12px;position:relative;padding-bottom:18px}
.vstep .s:last-child{padding-bottom:0}
.vstep .s::before{content:"";position:absolute;left:7px;top:18px;bottom:0;width:2px;background:var(--line-2)}
.vstep .s:last-child::before{display:none}
.vstep .s .pt{flex:0 0 16px;width:16px;height:16px;border-radius:50%;border:2px solid var(--line-2);background:#fff;margin-top:1px;z-index:1}
.vstep .s.done .pt{background:var(--green);border-color:var(--green)}
.vstep .s.done::before{background:var(--green)}
.vstep .s.cur .pt{border-color:var(--teal);box-shadow:0 0 0 3px rgba(13,148,136,.18)}
.vstep .s.fail .pt{background:var(--red);border-color:var(--red)}
.vstep .s .tt{font-weight:700;font-size:.86rem}
.vstep .s.todo .tt{color:var(--t4)}
.vstep .s .tm{font-size:.78rem;color:var(--muted);margin-top:1px}
/* copy-to-clipboard pill */
.copy{cursor:pointer;border:0;background:var(--sunken);color:var(--teal);font-size:.68rem;font-weight:800;padding:2px 7px;border-radius:6px;flex:0 0 auto}
.copy:hover{background:var(--teal-bg)}

/* ===== skeleton loaders ===== */
.sk{position:relative;overflow:hidden;background:var(--sunken);border-radius:8px}
.sk::after{content:"";position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.65),transparent);animation:sksh 1.2s infinite}
@keyframes sksh{100%{transform:translateX(100%)}}
.sk-card{height:104px;border-radius:var(--r)}
.sk-line{height:14px;margin:9px 0}

/* ===== top-bar search trigger + hamburger ===== */
.hamb{display:none;width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:var(--bg-2);color:var(--t2);cursor:pointer;align-items:center;justify-content:center;flex:0 0 auto}
.hamb svg{width:20px;height:20px}
.top-search{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);background:var(--bg-2);color:var(--t3);border-radius:10px;padding:8px 12px;font:inherit;font-size:.85rem;font-weight:600;cursor:pointer;transition:border-color .14s,color .14s}
.top-search:hover{border-color:var(--teal);color:var(--teal)}
.top-search svg{width:15px;height:15px}
.top-search kbd{font-family:var(--fm);font-size:.66rem;background:var(--sunken);border:1px solid var(--line);border-radius:5px;padding:1px 5px;color:var(--t3)}

/* ===== command palette ===== */
.cmdk-back{position:fixed;inset:0;background:rgba(11,18,32,.5);backdrop-filter:blur(3px);z-index:100;display:flex;align-items:flex-start;justify-content:center;padding:12vh 18px 18px}
.cmdk-back[hidden]{display:none}
.cmdk{width:100%;max-width:560px;background:var(--bg-2);border:1px solid var(--line);border-radius:16px;box-shadow:var(--sh-lg);overflow:hidden;animation:notifIn .16s cubic-bezier(.16,1,.3,1)}
.cmdk-input{width:100%;border:0;border-bottom:1px solid var(--line);border-radius:0;padding:16px 18px;font-size:1rem;outline:none;font-family:var(--fd)}
.cmdk-input:focus{box-shadow:none;border-color:var(--line)}
.cmdk-list{max-height:54vh;overflow-y:auto;padding:6px}
.cmdk-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;cursor:pointer}
.cmdk-item .ic{flex:0 0 30px;width:30px;height:30px;border-radius:8px;background:var(--teal-bg);color:var(--teal);display:flex;align-items:center;justify-content:center}
.cmdk-item .ic svg{width:16px;height:16px}
.cmdk-item .nm{flex:1;font-weight:600;color:var(--ink);font-size:.9rem}
.cmdk-item .hint{font-size:.66rem;font-weight:700;color:var(--t4);text-transform:uppercase;letter-spacing:.05em}
.cmdk-item.sel{background:var(--teal-bg)}
.cmdk-empty{padding:24px;text-align:center;color:var(--muted);font-size:.88rem}

/* ===== mobile: off-canvas sidebar drawer ===== */
#sideBg{position:fixed;inset:0;background:rgba(11,18,32,.45);z-index:55;display:none}
#sideBg.open{display:block}
@media(min-width:761px){#sideBg{display:none!important}}
@media(max-width:760px){
  .app{flex-direction:column}
  .hamb{display:inline-flex}
  .side{position:fixed;top:0;left:0;height:100vh;width:264px;max-width:84vw;transform:translateX(-100%);transition:transform .22s cubic-bezier(.16,1,.3,1);z-index:60;align-self:auto;overflow-y:auto}
  .side.open{transform:none;box-shadow:var(--sh-lg)}
  .topbar{padding:12px 16px}
  .content{padding:18px 16px}
  .grid4{grid-template-columns:repeat(2,1fr)}.grid2{grid-template-columns:1fr}.cols2{grid-template-columns:1fr}
  .money-hero{grid-template-columns:1fr}.mh-side{grid-template-columns:1fr 1fr;border-top:1px solid rgba(255,255,255,.07)}
  .top-search span,.top-search kbd{display:none}
}

/* ---- Connected devices (security) ---- */
.sess-row{display:flex;align-items:center;gap:14px;padding:14px 18px;border-bottom:1px solid var(--line)}
.sess-row:last-child{border-bottom:0}
.sess-ic{flex:0 0 42px;width:42px;height:42px;border-radius:11px;background:var(--teal-bg);color:var(--teal);display:flex;align-items:center;justify-content:center}
.sess-ic svg{width:21px;height:21px}
.sess-main{flex:1;min-width:0}
.sess-t{font-weight:700;font-size:.92rem;display:flex;align-items:center;gap:8px}
.sess-badge{font-size:.66rem;font-weight:800;color:var(--green);background:var(--green-bg);border:1px solid #BBE9D1;border-radius:20px;padding:1px 8px;text-transform:uppercase;letter-spacing:.03em}
.sess-meta{font-size:.78rem;color:var(--muted);margin-top:2px}
.sess-act{flex:0 0 auto}
.sess-revoke{color:var(--red)}
.sess-revoke:hover{border-color:var(--red)}

/* ---- Segmented control (e.g. currency switch) ---- */
.seg{display:inline-flex;background:var(--sunken);border:1px solid var(--line);border-radius:10px;padding:3px;gap:2px}
.seg button{font:inherit;font-weight:700;font-size:.8rem;border:0;background:none;color:var(--muted);padding:5px 12px;border-radius:7px;cursor:pointer;display:flex;align-items:center;gap:6px;transition:color .12s}
.seg button.on{background:var(--bg-2);color:var(--ink);box-shadow:0 1px 3px rgba(12,19,34,.14)}
.seg button svg{width:14px;height:14px}

/* ---- Notifications (bell + popover) ---- */
.bell{position:relative;width:40px;height:40px;border-radius:11px;border:1px solid var(--line);background:var(--bg-2);color:#475569;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .15s,background .15s,color .15s}
.bell:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-bg)}
.bell.on{border-color:var(--teal);color:var(--teal);background:var(--teal-bg)}
.bell svg{width:19px;height:19px}
.bell-dot{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:#E5484D;color:#fff;font-size:.66rem;font-weight:800;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg-2);box-shadow:0 1px 4px rgba(229,72,77,.5)}
/* the [hidden] attribute must win over display:flex above, else the dot shows even when empty */
.bell-dot[hidden]{display:none}

/* ---- Reusable date-range filter (presets + From/To) ---- */
.dfilter{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.dfilter .df-presets{display:inline-flex;background:var(--sunken);border:1px solid var(--line);border-radius:10px;padding:3px;gap:2px}
.dfilter .df-presets button{font:inherit;font-weight:700;font-size:.76rem;border:0;background:none;color:var(--t3);padding:5px 11px;border-radius:7px;cursor:pointer;transition:color .12s,background .12s,box-shadow .12s;white-space:nowrap}
.dfilter .df-presets button:hover{color:var(--ink)}
.dfilter .df-presets button.on{background:var(--bg-2);color:var(--teal);box-shadow:0 1px 3px rgba(12,19,34,.14)}
.dfilter .df-range{display:inline-flex;align-items:center;gap:6px;background:var(--bg-2);border:1px solid var(--line);border-radius:10px;padding:4px 10px;transition:border-color .14s,box-shadow .14s}
.dfilter .df-range:focus-within{border-color:var(--teal);box-shadow:0 0 0 3px rgba(13,148,136,.14)}
.dfilter .df-range > svg{width:15px;height:15px;color:var(--t3);flex:0 0 auto}
.dfilter .df-range input[type=date]{border:0;padding:3px 0;font-size:.8rem;background:none;color:var(--ink);font-family:var(--fm);width:108px}
.dfilter .df-range input[type=date]:focus{outline:none;box-shadow:none}
.dfilter .df-range .df-sep{color:var(--t4);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.dfilter .df-reset{font:inherit;font-size:.76rem;font-weight:700;border:1px solid var(--line);background:var(--bg-2);color:var(--t3);border-radius:9px;padding:5px 11px;cursor:pointer}
.dfilter .df-reset:hover{border-color:var(--teal);color:var(--teal)}
/* friendlier native calendar trigger */
.dfilter input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.55;padding:2px;border-radius:5px}
.dfilter input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1;background:var(--teal-bg)}
@media(max-width:560px){.dfilter .df-range input[type=date]{width:92px}}
/* trigger button that opens the custom calendar */
.dfilter .df-cal{display:inline-flex;align-items:center;gap:7px;background:var(--bg-2);border:1px solid var(--line);border-radius:10px;padding:6px 12px;font:inherit;font-size:.8rem;font-weight:600;color:var(--t2);cursor:pointer;transition:border-color .14s,box-shadow .14s}
.dfilter .df-cal:hover{border-color:var(--teal);box-shadow:var(--sh-sm)}
.dfilter .df-cal[data-active]{border-color:var(--teal);color:var(--teal);background:var(--teal-bg)}
.dfilter .df-cal svg{width:15px;height:15px;color:var(--t3);flex:0 0 auto}
.dfilter .df-cal[data-active] svg{color:var(--teal)}

/* themed native select (custom chevron, teal focus) */
.fsel{appearance:none;-webkit-appearance:none;-moz-appearance:none;font:inherit;font-size:.8rem;font-weight:600;color:var(--t2);background-color:var(--bg-2);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%235B6A85' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;border:1px solid var(--line);border-radius:10px;padding:7px 30px 7px 12px;cursor:pointer;transition:border-color .14s,box-shadow .14s}
.fsel:hover{border-color:var(--teal)}
.fsel:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(13,148,136,.14)}
.fsel option{font-weight:500;color:var(--ink)}

/* ---- Custom range-calendar popover ---- */
.dpop{background:var(--bg-2);border:1px solid var(--line);border-radius:14px;box-shadow:var(--sh-lg);width:268px;padding:12px;z-index:200;animation:notifIn .14s cubic-bezier(.16,1,.3,1)}
.dpop-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.dpop-title{font-family:var(--fd);font-weight:800;font-size:.95rem;color:var(--ink)}
.dpop-nav{width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:var(--bg-2);color:var(--t2);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}
.dpop-nav:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-bg)}
.dpop-nav svg{width:16px;height:16px}
.dpop-wds{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px}
.dpop-wds span{text-align:center;font-size:.62rem;font-weight:800;color:var(--t4);text-transform:uppercase;letter-spacing:.04em;padding:2px 0}
.dpop-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.dpop-day{height:32px;border:0;background:none;border-radius:8px;font:inherit;font-size:.82rem;font-weight:600;color:var(--t2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-variant-numeric:tabular-nums;padding:0}
.dpop-day.blank{visibility:hidden;cursor:default}
.dpop-day:hover:not(.sel){background:var(--teal-bg);color:var(--teal)}
.dpop-day.today{box-shadow:inset 0 0 0 1.5px var(--line-2)}
.dpop-day.inrange{background:var(--teal-bg);color:var(--teal-600);border-radius:0}
.dpop-day.sel{background:var(--teal);color:#fff;font-weight:800}
.dpop-day.sel.start{border-radius:8px 0 0 8px}
.dpop-day.sel.end{border-radius:0 8px 8px 0}
.dpop-day.sel.start.end{border-radius:8px}
.dpop-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid var(--line)}
.dpop-sel{font-size:.73rem;color:var(--t3);font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dpop-actions{display:flex;gap:6px;flex:0 0 auto}
.dpop-clear{font:inherit;font-size:.76rem;font-weight:700;border:0;background:none;color:var(--t3);padding:5px 8px;border-radius:7px;cursor:pointer}
.dpop-clear:hover{color:var(--red)}
.dpop-apply{font:inherit;font-size:.76rem;font-weight:700;border:0;border-radius:8px;padding:6px 14px;cursor:pointer;background:linear-gradient(180deg,var(--teal),var(--teal-600));color:#fff;box-shadow:0 2px 6px rgba(13,148,136,.28)}
.dpop-apply:hover{box-shadow:0 4px 12px rgba(13,148,136,.34)}
.notif-pop{position:absolute;right:0;top:52px;width:380px;max-width:90vw;background:var(--bg-2);border:1px solid var(--line);border-radius:16px;box-shadow:var(--sh-lg);z-index:40;overflow:hidden;transform-origin:top right;animation:notifIn .16s cubic-bezier(.16,1,.3,1)}
@keyframes notifIn{from{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:none}}
.notif-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 16px;border-bottom:1px solid var(--line)}
.notif-head .t{font-weight:800;font-size:.95rem;display:flex;align-items:center;gap:8px}
.notif-head .c{font-size:.68rem;font-weight:800;color:#fff;background:var(--teal);border-radius:20px;padding:1px 7px}
.notif-head .mark{font-size:.78rem;font-weight:700;color:var(--teal);cursor:pointer;background:none;border:0;padding:4px 6px;border-radius:7px}
.notif-head .mark:hover{background:var(--teal-bg)}
.notif-head .mark:disabled{color:var(--muted);cursor:default;background:none}
.notif-list{max-height:62vh;overflow-y:auto}
.notif-item{display:flex;gap:12px;padding:13px 16px;border-bottom:1px solid #F1F3F8;position:relative;transition:background .12s}
.notif-item:last-child{border-bottom:0}
.notif-item:hover{background:#FAFBFE}
.notif-item.unread{background:var(--teal-bg)}
.notif-item.unread::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--teal)}
.notif-ic{flex:0 0 34px;width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center}
.notif-ic svg{width:17px;height:17px}
.notif-ic.success{background:var(--green-bg);color:var(--green)}
.notif-ic.info{background:var(--teal-bg);color:var(--teal)}
.notif-ic.warn{background:#FDECEC;color:#E5484D}
.notif-bd{flex:1;min-width:0}
.notif-bd .nt{font-weight:700;font-size:.86rem;color:var(--ink)}
.notif-bd .nb{font-size:.81rem;color:var(--muted);line-height:1.4;margin-top:1px}
.notif-bd .na{font-size:.72rem;color:#94A3B8;margin-top:4px}
.notif-empty{padding:34px 18px;text-align:center;color:var(--muted)}
.notif-empty svg{width:34px;height:34px;color:#CBD5E1;margin-bottom:8px}
.notif-empty .et{font-weight:700;color:#475569;font-size:.9rem}
.notif-empty .es{font-size:.8rem;margin-top:2px}

/* ===== Reports (BI aggregated view) ===== */
.rep-lbl{font-size:.78rem;font-weight:700;color:var(--t3)}
.rep-table td.num,.rep-table th.num{text-align:right;font-variant-numeric:tabular-nums}
.rep-table tfoot .rep-total td{font-weight:800;color:var(--ink);border-top:2px solid var(--line);background:#FAFBFE}
.rep-kpis{display:flex;gap:12px;flex-wrap:wrap;padding:14px 18px}
.rep-kpi{flex:1;min-width:120px;background:var(--bg-2);border:1px solid var(--line);border-radius:12px;padding:11px 14px;box-shadow:var(--sh-sm)}
.rep-kpi .rk{font-size:.62rem;letter-spacing:.06em;text-transform:uppercase;color:var(--t3);font-weight:800;margin-bottom:5px}
.rep-kpi .rv{font-size:1.05rem;font-weight:800;color:var(--ink)}
.rep-chart{padding:2px 18px 14px;display:flex;flex-direction:column;gap:7px}
.rep-chart:empty{display:none}
.rep-barrow{display:flex;align-items:center;gap:10px;font-size:.82rem}
.rep-barl{flex:0 0 130px;color:var(--t2);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rep-bart{flex:1;height:14px;background:var(--sunken);border-radius:7px;overflow:hidden}
.rep-barf{display:block;height:100%;background:linear-gradient(90deg,var(--teal),var(--teal-600));border-radius:7px;min-width:2px}
.rep-barv{flex:0 0 auto;font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums;min-width:64px;text-align:right}
@media(max-width:640px){.rep-barl{flex-basis:90px}.rep-kpi{min-width:90px}}

/* ===== Reports: account structure tree ===== */
.rep-struct{margin-bottom:16px}
.rep-struct .rs-sub{font-size:.78rem;color:var(--t3);font-weight:600}
.rs-tree{padding:12px 18px 16px;display:flex;flex-direction:column;gap:2px}
.rs-row{display:flex;align-items:center;gap:9px;padding:6px 8px;border-radius:8px;font-size:.92rem;color:var(--ink)}
.rs-row svg{width:16px;height:16px;flex:none;color:var(--t3)}
.rs-l0{font-weight:800}
.rs-l0 svg{color:var(--teal)}
.rs-l1{margin-left:22px;color:var(--t2);font-weight:600}
.rs-l2{margin-left:44px;color:var(--t2)}
.rs-l2 svg{color:var(--teal)}
.rs-chan{font-family:var(--fm);font-size:.85rem}
