.table-section{display:flex;flex-direction:column;gap:10px;width:100%}
.sticky-panel{position:sticky;top:0;z-index:8;display:flex;flex-direction:column;gap:8px;padding-bottom:8px;background:linear-gradient(180deg,rgba(255,255,255,0.02),rgba(255,255,255,0));backdrop-filter:blur(12px)}
.sticky-panel .filter-bar{background:var(--bg-card);border:1px solid var(--border);box-shadow:0 6px 16px rgba(0,0,0,0.06);padding:8px 12px;margin-bottom:0;gap:8px}
.sticky-panel .filter-bar .form-control{padding:6px 10px}
.sticky-panel .quick-filters{background:var(--bg-card);border:1px solid var(--border);box-shadow:0 6px 16px rgba(0,0,0,0.06);padding:7px 12px;border-radius:12px;margin-bottom:0;gap:8px}
.sticky-panel .quick-filters .filter-chip{padding:5px 12px;font-size:12px}
.table-wrap{display:block;position:relative;overflow-x:auto;overflow-y:hidden;border-radius:18px;border:1px solid var(--border);background:var(--bg-card);box-shadow:0 10px 30px rgba(0,0,0,0.08);width:100%;max-width:100%;scrollbar-color:rgba(148,163,184,0.55) rgba(30,41,59,0.12);scrollbar-width:thin;-webkit-overflow-scrolling:touch;touch-action:pan-x;box-sizing:border-box;min-width:0}
.table-wrap.horizontal-scroll{overflow-x:auto;overflow-y:hidden;}
.table-scroller{position:relative;width:100%}
.table-scroll-btn{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border:none;border-radius:999px;background:rgba(15,23,42,0.85);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:12;box-shadow:0 10px 20px rgba(0,0,0,0.2);transition:transform 0.2s ease,background 0.2s ease,opacity 0.2s ease;}
.table-scroll-btn:hover{transform:translateY(-50%) scale(1.04);background:rgba(37,99,235,0.95);}
.table-scroll-btn.left{left:12px;}
.table-scroll-btn.right{right:12px;}
/* hide the directional button when there is nothing more to scroll that way */
.table-scroller:not(.scroll-start) .table-scroll-btn.left{opacity:0;pointer-events:none}
.table-scroller:not(.scroll-end) .table-scroll-btn.right{opacity:0;pointer-events:none}
.table-scroller::before,.table-scroller::after{content:'';position:absolute;top:0;bottom:0;width:44px;pointer-events:none;opacity:0;transition:opacity var(--transition);z-index:4;border-radius:18px}
.table-scroller::before{left:0;background:linear-gradient(to right, var(--bg-card), rgba(28,33,40,0));}
.table-scroller::after{right:0;background:linear-gradient(to left, var(--bg-card), rgba(28,33,40,0));}
.table-scroller.scroll-start::before{opacity:1}
.table-scroller.scroll-end::after{opacity:1}
.table-wrap::-webkit-scrollbar{height:12px}
.table-wrap::-webkit-scrollbar-track{background:rgba(148,163,184,0.12);border-radius:999px}
.table-wrap::-webkit-scrollbar-thumb{background:rgba(100,116,139,0.55);border-radius:999px}
.table-wrap::-webkit-scrollbar-thumb:hover{background:rgba(148,163,184,0.7)}
/* ---- Generic data table: fluid, fills narrow screens, scrolls when wide ---- */
.data-table{width:100%;min-width:100%;border-collapse:collapse;font-size:13px;table-layout:auto}
.data-table th{padding:14px 18px;background:var(--bg-secondary);color:var(--text-secondary);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;text-align:left;border-bottom:1px solid rgba(148,163,184,0.12);white-space:nowrap}
.data-table td{padding:13px 18px;border-bottom:1px solid rgba(148,163,184,0.08);color:var(--text-primary);white-space:nowrap;vertical-align:middle}
.data-table tbody tr{transition:background var(--transition)}
.data-table tbody tr:hover{background:rgba(148,163,184,0.06)}
.data-table tbody tr:nth-child(even){background:rgba(148,163,184,0.025)}
.data-table td:last-child{white-space:normal}
.total-row td{font-weight:700;background:var(--bg-tertiary)!important;color:var(--text-primary)}
.bal-pos{color:var(--success-light);font-weight:700}
.bal-neg{color:var(--danger-light);font-weight:700}

/* ---- Register table: sticky header + 5 frozen columns (incl. Route) ----
   width:max-content sizes columns to their content; a lower min-width floor
   keeps horizontal scroll on narrow screens WITHOUT stretching columns to fill
   on wide screens (the old 1800px floor padded every column with dead space). */
.data-table--register{min-width:1200px;width:max-content}
.table-wrap--register{overflow:auto;overflow-y:auto;max-height:calc(100vh - 240px);touch-action:pan-x pan-y}
.data-table--register th{position:sticky;top:0;z-index:6}
.data-table--register th:nth-child(-n+5){z-index:8}
.data-table--register tbody td:nth-child(-n+5){position:sticky;background:var(--bg-secondary);z-index:5;border-right:1px solid rgba(148,163,184,0.12)}
.data-table--register tbody tr:nth-child(even) td:nth-child(-n+5){background:var(--bg-tertiary)}
/* Content-fit frozen columns. The `left` offsets must chain: each column's
   left = previous left + previous width (38, 104, 196, then 196+112=308). */
.data-table--register th:nth-child(1),.data-table--register td:nth-child(1){left:0;width:38px;min-width:38px;max-width:38px}        /* checkbox */
.data-table--register th:nth-child(2),.data-table--register td:nth-child(2){left:38px;width:66px;min-width:66px;max-width:66px}     /* Trip No (≤4 digits) */
.data-table--register th:nth-child(3),.data-table--register td:nth-child(3){left:104px;width:92px;min-width:92px;max-width:92px}    /* Paid Date */
.data-table--register th:nth-child(4),.data-table--register td:nth-child(4){left:196px;width:112px;min-width:112px;max-width:112px} /* Vehicle */
.data-table--register th:nth-child(5),.data-table--register td:nth-child(5){left:308px;width:104px;min-width:104px;max-width:104px} /* Route (frozen) */
/* Keep tightened frozen cells from bleeding into neighbours if a value is long */
.data-table--register th:nth-child(-n+5),.data-table--register td:nth-child(-n+5){overflow:hidden;text-overflow:ellipsis}
.data-table--register tfoot td{position:relative}

/* ---- Compact, data-dense register grid (Zoho/ERPNext style) ---- */
.data-table--register{font-size:12.5px}
.data-table--register th{padding:6px 8px;font-size:10.5px;letter-spacing:0.02em}      /* denser header */
.data-table--register td{padding:4px 8px;line-height:1.3}                             /* ~38-40px rows */
.data-table--register td:nth-child(2){font-weight:600}                                 /* Trip No emphasis */
.data-table--register .badge{padding:2px 7px;font-size:10px}
.data-table--register .settle-done,.data-table--register .settle-pending{padding:2px 8px;font-size:10px;gap:4px}
.data-table--register .btn-icon{padding:5px;font-size:11px;width:26px;height:26px;justify-content:center}
.data-table--register tbody tr:hover{background:rgba(59,130,246,0.08)}
.data-table--register tbody tr:hover td:nth-child(-n+5){background:var(--bg-hover)}
.cell-id{font-size:11px;color:var(--text-secondary)}
.cell-zero{color:var(--text-muted)}
/* Accounts colour UX: income (money in) green · deductions (expenses) red */
.val-in{color:var(--success-light);font-weight:600;font-variant-numeric:tabular-nums}
.val-out{color:var(--danger-light);font-variant-numeric:tabular-nums}
.tabular-nums,.data-table--register .text-right{font-variant-numeric:tabular-nums}

/* Frozen action column on the right */
.data-table--register th:last-child,.data-table--register td:last-child{position:sticky;right:0;z-index:5;background:var(--bg-secondary);border-left:1px solid rgba(148,163,184,0.12);width:auto;white-space:nowrap}
.data-table--register th:last-child{z-index:8}
.data-table--register tbody tr:nth-child(even) td:last-child{background:var(--bg-tertiary)}
.data-table--register tbody tr:hover td:last-child{background:var(--bg-hover)}
.actions-cell{padding:4px 10px!important}

/* Inline (Excel-like) cell editing */
.data-table--register td.editable{cursor:cell}
.data-table--register td.editable:hover{box-shadow:inset 0 0 0 1px rgba(59,130,246,0.4)}
.data-table--register td.editing{padding:2px 4px;background:#fde68a !important}        /* yellow while editing */
.cell-input{width:100%;border:1px solid var(--accent);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);padding:4px 6px;font-size:12.5px;font-family:inherit;text-align:inherit;outline:none}
.data-table--register td.editing .cell-input{background:#fffbeb;color:#1f2937;border-color:#f59e0b}  /* yellow editor */
.data-table--register td.cell-saved{animation:cellSavedFlash .9s ease}                  /* green flash on save */
@keyframes cellSavedFlash{0%{background:#86efac}60%{background:#bbf7d0}100%{background:transparent}}
.cell-input::-webkit-outer-spin-button,.cell-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}

/* ---- Mobile card / list view ---- */
.trip-cards{display:none;flex-direction:column;gap:10px}
.trip-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:14px}
.trip-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--border-light)}
.trip-card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px 12px}
.trip-card-grid>div{display:flex;flex-direction:column;gap:2px;min-width:0}
.tc-label{font-size:10px;text-transform:uppercase;letter-spacing:0.04em;color:var(--text-muted);font-weight:600}
.tc-val{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.trip-card-actions{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}
.trip-card-actions .btn{flex:0 0 auto}
.actions-col{display:flex;align-items:center;gap:4px;flex-wrap:nowrap}
.settle-done{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:rgba(16,185,129,0.16);color:var(--success-light);font-size:12px;font-weight:600}
.settle-pending{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:rgba(234,179,8,0.16);color:var(--warning-light);font-size:12px;font-weight:600}
.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}
.empty-state i{font-size:48px;margin-bottom:16px;display:block;opacity:0.4}
.empty-state p{font-size:14px}
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600}
.badge-success{background:rgba(22,163,74,0.15);color:var(--success-light)}
.badge-danger{background:rgba(220,38,38,0.15);color:var(--danger-light)}
.badge-warning{background:rgba(217,119,6,0.15);color:var(--warning-light)}
.badge-info{background:rgba(8,145,178,0.15);color:var(--cyan-light)}
.badge-secondary{background:var(--bg-hover);color:var(--text-secondary)}
@media(max-width:1024px){.data-table--register{min-width:1500px}}
@media(max-width:768px){.table-wrap{border-radius:14px}.data-table th,.data-table td{padding:12px 14px}}
.pagination-footer{display:flex;flex-direction:column;gap:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:16px;box-shadow:0 14px 32px rgba(0,0,0,0.08);position:sticky;bottom:0;z-index:3}
.pagination-summary{color:var(--text-secondary);font-size:13px;font-weight:600}
.pagination-panel{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.pagination-nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.page-buttons{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.page-ellipsis{color:var(--text-muted);font-size:13px;padding:0 6px}
.btn.btn-secondary.btn-sm.active-page{background:var(--accent);color:#fff;border-color:var(--accent)}
.pagination-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.pagination-actions label{font-size:12px;color:var(--text-secondary);font-weight:600}
.pagination-actions .form-control{min-width:72px;max-width:110px}
.pagination-actions input.form-control{width:90px}
.fab{bottom:100px}

/* ===== KPI stats bar (above the register grid) ===== */
.stats-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}
.stat-card{flex:1 1 120px;min-width:110px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:8px 12px;display:flex;flex-direction:column;gap:2px}
.stat-card .stat-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.05em;color:var(--text-muted)}
.stat-card .stat-val{font-size:16px;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums;line-height:1.1}
@media(max-width:640px){.stat-card{flex:1 1 calc(50% - 8px)}}

/* ===== Row actions: ⋮ dropdown menu (fixed-position, body-appended) ===== */
.row-menu{position:fixed;z-index:300;min-width:170px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px;box-shadow:0 14px 40px rgba(0,0,0,0.35);padding:5px;display:flex;flex-direction:column;gap:2px;animation:fadeIn .12s ease}
.row-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;background:none;border:none;border-radius:7px;color:var(--text-primary);font-size:13px;font-weight:500;text-align:left;transition:background var(--transition)}
.row-menu-item i{width:16px;text-align:center;color:var(--text-secondary)}
.row-menu-item:hover{background:var(--bg-hover)}
.row-menu-item.danger{color:var(--danger-light)}
.row-menu-item.danger i{color:var(--danger-light)}
.row-menu-item.danger:hover{background:var(--danger);color:#fff}
.row-menu-item.danger:hover i{color:#fff}

/* ===== Compact mode (toggle): squeeze rows further for max density ===== */
body.compact .data-table--register th{padding:4px 8px}
body.compact .data-table--register td{padding:2px 8px;line-height:1.2}
body.compact .data-table--register{font-size:12px}
body.compact .content{padding:12px}
body.compact .stat-card{padding:6px 10px}
body.compact .stat-card .stat-val{font-size:14px}
.compact-toggle.active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ===== Per-vehicle day lock (multi-select close) ===== */
.data-table--register tr.row-locked td{background:rgba(245,158,11,0.07)}
.data-table--register tr.row-locked td:nth-child(-n+5){background:rgba(245,158,11,0.12)}
.data-table--register tr.row-locked td:nth-child(2){box-shadow:inset 4px 0 0 var(--warning-light)}  /* lock accent bar */
.data-table--register tr.row-locked:hover td{background:rgba(245,158,11,0.13)}
.lock-ic{color:var(--warning-light);font-size:10px;margin-left:5px}
/* Close Day modal: vehicle multi-select */
.cd-allrow{display:flex;align-items:center;gap:8px;font-size:13px;padding:9px 11px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;cursor:pointer}
.cd-allrow input{width:15px;height:15px;accent-color:var(--accent);cursor:pointer}
.cd-sub{font-size:12px;color:var(--text-muted);margin:14px 0 8px}
.cd-toolbar{display:flex;gap:8px;margin-bottom:8px}
.cd-toolbar .form-control{flex:1;min-width:0}
.cd-list{max-height:300px;overflow-y:auto;border:1px solid var(--border);border-radius:8px;padding:4px}
.cd-veh{display:flex;align-items:center;gap:9px;padding:7px 10px;font-size:13px;border-radius:6px;cursor:pointer}
.cd-veh:hover{background:var(--bg-hover)}
.cd-veh input{width:15px;height:15px;accent-color:var(--accent);cursor:pointer}

/* ===== Privilege Management tree ===== */
.pv-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;margin-bottom:10px;overflow:hidden}
.pv-card-head{display:flex;align-items:center;gap:10px;padding:11px 14px;cursor:pointer;user-select:none}
.pv-card-head:hover{background:var(--bg-hover)}
.pv-mic{color:var(--accent-light);width:18px;text-align:center}
.pv-mname{font-weight:600;font-size:14px}
.pv-mcount{margin-left:4px;font-size:10px}
.pv-mall{margin-left:auto;display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary);cursor:pointer}
.pv-mall input{width:15px;height:15px;accent-color:var(--accent);cursor:pointer}
.pv-chev{transition:transform .2s;color:var(--text-muted);font-size:12px}
.pv-card.collapsed .pv-chev{transform:rotate(-90deg)}
.pv-card-body{display:flex;flex-wrap:wrap;gap:8px 20px;padding:8px 16px 14px 42px;border-top:1px solid var(--border-light)}
.pv-act{display:flex;align-items:center;gap:7px;font-size:13px;cursor:pointer;min-width:120px}
.pv-act input{width:15px;height:15px;accent-color:var(--accent);cursor:pointer}
