:root{
  --accent:#C62828;--accent-dk:#B71C1C;--blue:#1565C0;
  --hd:#1C2833;--bg:#f7f8fa;
}
*{box-sizing:border-box}
body{font-family:"Segoe UI",Roboto,sans-serif;background:var(--bg);margin:0;color:#111}

.topbar{
  display:flex;align-items:center;gap:18px;
  background:var(--hd);color:#fff;padding:8px 18px;
}
.topbar .brand{font-weight:800;letter-spacing:.5px}
.topbar nav{display:flex;gap:6px}
.topbar nav a{
  color:#BDC3C7;text-decoration:none;padding:5px 12px;border-radius:6px;
  font-size:13px;font-weight:600
}
.topbar nav a:hover{background:#2E4053;color:#fff}
.topbar nav a.active{background:var(--accent);color:#fff}

/* Brand link (acts as app switcher: Books ↔ Smarthub) */
.topbar .brand.brand-link{
  color:#fff;text-decoration:none;
  display:inline-flex;align-items:center;gap:6px;
  padding:4px 10px;border-radius:6px;
  transition:background .12s;
}
.topbar .brand.brand-link:hover{background:rgba(255,255,255,.1)}
.topbar .brand.brand-link::after{
  content:"⇄";font-size:11px;opacity:.5;margin-left:6px;
}

/* Smarthub theme — distinct color scheme so it feels like a different app */
.smarthub-app .topbar.smarthub-bar{background:#0D47A1}
.smarthub-app .topbar.smarthub-bar nav a.active{background:#FFA000;color:#1C2833}
.smarthub-app .btn-primary{background:#1565C0!important;border-color:#1565C0!important}
.smarthub-app .btn-primary:hover{background:#0D47A1!important;border-color:#0D47A1!important}
.smarthub-app .bk-table th{background:#0D47A1;border-bottom:2px solid #FFA000}
.smarthub-app .firm{color:#0D47A1}
.smarthub-app .topbar nav a:hover{background:rgba(255,255,255,.1)}
.smarthub-app .topbar nav a{color:#BBDEFB}

/* POC pills + wrappable cells */
.poc-pill{
  display:inline-block;background:#E3F2FD;color:#0D47A1;
  padding:2px 8px;border-radius:10px;font-size:11px;font-weight:700;letter-spacing:.3px;
}
.bk-table .cell-wrap{white-space:normal;max-width:240px;font-size:11.5px;line-height:1.35}

/* Truncate-to-width with hover popover (FAILURE SOP, NOTES) */
.bk-table .cell-truncate{
  width:160px;max-width:160px;min-width:160px;
  position:relative;font-size:11.5px;cursor:help;
  vertical-align:middle;
}
.bk-table .cell-truncate .cell-text{
  display:block;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  width:100%;
}
.bk-table .cell-truncate:not([data-full=""]):hover{z-index:60}
.bk-table .cell-truncate:not([data-full=""]):hover::after{
  content: attr(data-full);
  position:absolute;left:0;top:calc(100% + 4px);
  background:#1C2833;color:#fff;
  padding:8px 12px;border-radius:6px;
  white-space:pre-wrap;width:340px;max-width:60vw;
  z-index:100;font-size:11.5px;line-height:1.45;font-weight:400;
  box-shadow:0 6px 18px rgba(0,0,0,.28);
  pointer-events:none;
  letter-spacing:.1px;
}
.bk-table .cell-truncate:not([data-full=""]):hover::before{
  content:""; position:absolute; left:14px; top:calc(100% + 0px);
  border:5px solid transparent;border-bottom-color:#1C2833;
  z-index:101;
}
.bk-table .mono{font-family:monospace;color:#666}
.bk-table .small{font-size:10.5px}

/* Smarthub — inactive rows fade out so active ones pop */
.bk-table tr.row-inactive td{opacity:.45;background:#f5f5f5}
.bk-table tr.row-inactive .firm{color:#999}
.bk-table .active-toggle{font-size:10.5px;font-weight:700;letter-spacing:.3px;padding:2px 10px;border-radius:14px;white-space:nowrap}

/* Smarthub row coloring — time-based warnings + status overrides */
/* SR ... BOX = first 6 columns (per-cell tint, not the whole row) */
#sellerTable tbody tr.row-warn-30 td:nth-child(-n+6){background:#FFE0B2!important}
#sellerTable tbody tr.row-warn-15 td:nth-child(-n+6){background:#FFCDD2!important}
/* Status: DONE → whole row green (overrides everything) */
#sellerTable tbody tr.row-status-done td{background:#C8E6C9!important}
#sellerTable tbody tr.row-status-done .firm{color:#1B5E20}
/* Status: ERROR → whole row red */
#sellerTable tbody tr.row-status-error td{background:#FFCDD2!important}
#sellerTable tbody tr.row-status-error .firm{color:#B71C1C}
/* Status: ONCE → LOC ID cell blue (combined with any time-based class on left cells) */
#sellerTable tbody tr.row-status-once .loc-cell{background:#BBDEFB!important}

/* Manual seller badge */
.manual-badge{
  display:inline-block;font-size:11px;
  background:#FFF8E1;border:1px solid #FFB74D;color:#E65100;
  border-radius:8px;padding:0 5px;margin-left:4px;font-weight:700;
}
.row-manual .firm{font-weight:700}

/* MY TIME save flash */
.my-time-input{transition:background .2s, border-color .2s}
.my-time-input.saved{background:#C8E6C9;border-color:#2E7D32}

/* Click-to-copy LOC ID */
.loc-copy{
  cursor:pointer;
  border:1px dashed transparent;border-radius:4px;padding:1px 5px;
  transition:all .12s;display:inline-block;
}
.loc-copy:hover{background:#FFF8E1;border-color:#FFB74D;color:#1C2833}
.loc-copy.copied{background:#C8E6C9;border-color:#2E7D32;color:#1B5E20;font-weight:700}

/* Chip active state for filter buttons */
#filterChips .chip.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.smarthub-app #filterChips .chip.active{background:#0D47A1;color:#fff;border-color:#0D47A1}
#filterChips .chip{transition:all .1s}
#filterChips .vr{display:inline-block;width:1px;background:#D5D8DC;align-self:stretch}

main{padding:14px 18px}

.btn-primary{background:var(--accent)!important;border-color:var(--accent)!important}
.btn-primary:hover{background:var(--accent-dk)!important;border-color:var(--accent-dk)!important}

/* Summary box */
.summary{
  display:flex;flex-wrap:wrap;gap:10px;
  background:#fff;border:1px solid #E0E0E0;border-radius:8px;
  padding:8px 10px;margin-bottom:10px;font-size:12.5px
}
.summary > div{flex:1;min-width:130px;padding:4px 8px;border-right:1px solid #eee}
.summary > div:last-child{border-right:none}
.summary span{display:block;color:#85929E;font-size:10px;text-transform:uppercase;letter-spacing:.5px;font-weight:700}
.summary b{color:var(--blue);font-weight:800;font-size:14px}
.summary .diff.bad b{color:var(--accent)}

/* Tables — auto width, left aligned, only as wide as content */
.wrap{
  display:inline-block;       /* shrink to fit table */
  background:#fff;border:1px solid #E0E0E0;border-radius:8px;
  overflow:auto;box-shadow:0 1px 6px rgba(0,0,0,.04);
  max-width:100%;
}
.bk-table{
  width:auto;                  /* auto-size to content */
  border-collapse:collapse;
  font-size:12.5px;
  white-space:nowrap;
  text-align:left;
}
.bk-table th, .bk-table td{text-align:left}
.bk-table th{
  background:var(--hd);color:#ECF0F1;font-weight:600;padding:6px 10px;
  font-size:10.5px;text-transform:uppercase;letter-spacing:.3px;
  border:1px solid #2E3F50;
  border-bottom:2px solid var(--accent)
}
.bk-table td{
  padding:4px 8px;color:#2C3E50;vertical-align:middle;
  border:1px solid #D0D5DB;
}
.bk-table tr:nth-child(even) td{background:#F7F8FA}
.bk-table tr:hover td{background:#FFF3E0}

.bk-table .firm{font-weight:700;color:var(--blue)}
.bk-table .firm small{color:#888;font-weight:400}
.bk-table .firm-cont{color:#bbb;font-weight:400}
.bk-table tr.row-internal td{background:#E8F4FD}
.bk-table tr.row-internal:nth-child(even) td{background:#DDEAF7}
.bk-table tr.row-rot td{background:#FFF8E1}
.bk-table tr.row-rot:nth-child(even) td{background:#FFECB3}
.bk-table .num{font-variant-numeric:tabular-nums}
.bk-table input.num{
  border:1px solid transparent;background:transparent;
  padding:2px 4px;border-radius:3px;font-size:12.5px;
  width:auto;min-width:80px;max-width:140px;
  text-align:left;
  -moz-appearance:textfield;
}
.bk-table input.num::-webkit-outer-spin-button,
.bk-table input.num::-webkit-inner-spin-button{
  -webkit-appearance:none;margin:0;
}
.bk-table input.num:focus,.bk-table input.num:hover{
  border-color:#D5D8DC;background:#fff
}
.bk-table input.num.opening{color:#555}
.bk-table input.num.closing{color:#1C2833;font-weight:700}

/* Read-only displays for opening / closing — protected from accidental edits */
.bk-table .num-display{
  display:inline-block;
  min-width:70px;
  font-variant-numeric:tabular-nums;
  font-weight:600;
  color:#1C2833;
}
.bk-table .num-display.opening{color:#555;font-weight:500}
.bk-table .num-display.os-pos{color:#2E7D32}    /* gained today (closing > opening) */
.bk-table .num-display.os-neg{color:#C62828}    /* paid today (closing < opening) */
.bk-table .edit-btn{
  border:none;background:transparent;padding:0 4px;
  font-size:11px;cursor:pointer;color:#999;
  opacity:0;transition:opacity .15s;
}
.bk-table tr:hover .edit-btn{opacity:1}
.bk-table .edit-btn:hover{color:var(--accent)}

/* Sortable headers */
.bk-table th[data-sort]{cursor:pointer;user-select:none}
.bk-table th[data-sort]:hover{background:#2E4053}
.bk-table th .si{font-size:9px;opacity:.7;margin-left:4px}
.bk-table th.no-sort{cursor:default}

/* Remarks input */
.bk-table .remarks-input{
  border:1px solid transparent;background:transparent;
  padding:2px 6px;font-size:12.5px;
  width:auto;min-width:120px;max-width:280px;
}
.bk-table .remarks-input:focus,.bk-table .remarks-input:hover{
  border-color:#D5D8DC;background:#fff
}

/* Ledger side panel (right side, shown on + OUT) */
.ledger-panel{
  position:fixed;
  right:14px;top:80px;bottom:14px;
  width:360px;max-width:40vw;
  background:#fff;border:1px solid #D5D8DC;border-radius:8px;
  box-shadow:0 6px 20px rgba(0,0,0,.15);
  display:flex;flex-direction:column;
  z-index:50;
}

/* When ledger panel is visible, reserve right-side space so it doesn't overlap content */
body.has-ledger main{padding-right:390px}
@media (max-width:1100px){
  body.has-ledger main{padding-right:0}   /* on narrow screens, panel uses 40vw — let content scroll under */
}
.ledger-panel .lp-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 12px;background:var(--hd);color:#ECF0F1;
  border-radius:8px 8px 0 0;
}
.ledger-panel .lp-close{
  background:transparent;border:none;color:#fff;font-size:20px;
  cursor:pointer;padding:0 8px;line-height:1;
}
.ledger-panel .lp-close:hover{color:#FFD180}
.ledger-panel .lp-body{flex:1;overflow:auto}
.ledger-panel .lp-table{width:100%;border-collapse:collapse;font-size:12px}
.ledger-panel .lp-table th{
  background:#F7F8FA;color:#1C2833;font-size:10.5px;
  text-transform:uppercase;letter-spacing:.3px;font-weight:700;
  padding:6px 8px;text-align:left;border-bottom:2px solid var(--accent);
  position:sticky;top:0;
}
.ledger-panel .lp-table td{
  padding:5px 8px;border-bottom:1px solid #EEE;
}
.ledger-panel .lp-table tr:hover td{background:#FFF3E0;cursor:pointer}

/* Today-touched party rows */
.ledger-panel .lp-table tr.lp-paid td{background:#E8F5E9}      /* paid → green */
.ledger-panel .lp-table tr.lp-paid:hover td{background:#C8E6C9}
.ledger-panel .lp-table tr.lp-recv td{background:#E3F2FD}      /* received → blue */
.ledger-panel .lp-table tr.lp-recv:hover td{background:#BBDEFB}
.ledger-panel .lp-table tr.lp-both td{background:#FFF8E1}      /* both → amber */
.ledger-panel .lp-table tr.lp-both:hover td{background:#FFECB3}
.ledger-panel .lp-table tr.lp-paid .lp-party{color:#2E7D32}
.ledger-panel .lp-table tr.lp-recv .lp-party{color:#1565C0}
.ledger-panel .lp-party{
  font-weight:600;color:var(--blue);
}
.ledger-panel .lp-table .num{
  text-align:right;font-variant-numeric:tabular-nums;
}

/* Inline transfer form */
.bk-table .actions-cell{min-width:240px}
.bk-table .action-buttons{display:flex;gap:4px;flex-wrap:nowrap}
.bk-table .inline-transfer{display:flex;gap:4px;align-items:center}
.bk-table .inline-transfer .dir-label{
  font-weight:800;font-size:14px;width:18px;text-align:center;
}
.bk-table .inline-transfer .dir-label.dir-out{color:#C62828}
.bk-table .inline-transfer .dir-label.dir-in{color:#2E7D32}
.bk-table .inline-transfer input{
  padding:3px 6px;font-size:12px;border:1px solid #D5D8DC;border-radius:4px;
}
.bk-table .inline-transfer .cp-input{width:140px}
.bk-table .inline-transfer .amt-input{width:90px}
.bk-table .inline-transfer .amt-input::-webkit-outer-spin-button,
.bk-table .inline-transfer .amt-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.bk-table .inline-transfer .amt-input{-moz-appearance:textfield}

.alert{padding:6px 10px;font-size:13px;margin-bottom:10px}

/* Shiv — hero summary + side-by-side tables */
.shiv-hero{display:flex;gap:14px;flex-wrap:wrap}
.shiv-hero .hero-card{
  flex:1 1 360px;min-width:300px;
  background:#fff;border:1px solid #E0E0E0;border-radius:10px;
  padding:14px 18px;
  box-shadow:0 2px 8px rgba(0,0,0,.05);
  position:relative;overflow:hidden;
}
.shiv-hero .hd{
  display:block;font-size:10.5px;font-weight:700;color:#85929E;
  letter-spacing:.6px;text-transform:uppercase;margin-bottom:6px;
}
.shiv-hero .big{
  font-size:30px;font-weight:800;letter-spacing:-.5px;
  font-variant-numeric:tabular-nums;
}
.shiv-hero .big-muted{
  font-size:18px;font-weight:600;color:#85929E;
  font-variant-numeric:tabular-nums;
}
.shiv-hero .of{color:#bbb;margin:0 6px;font-size:14px}
.shiv-hero .sub{
  display:flex;justify-content:space-between;gap:10px;
  font-size:11.5px;color:#566573;margin-top:6px;font-weight:600;letter-spacing:.3px;
}

/* Balance card — gradient based on sign */
.shiv-hero .hero-balance.pos{
  background:linear-gradient(135deg,#E8F5E9 0%,#fff 60%);
  border-left:4px solid #2E7D32;
}
.shiv-hero .hero-balance.pos .big{color:#1B5E20}
.shiv-hero .hero-balance.neg{
  background:linear-gradient(135deg,#FFEBEE 0%,#fff 60%);
  border-left:4px solid #C62828;
}
.shiv-hero .hero-balance.neg .big{color:#B71C1C}

/* EMI card */
.shiv-hero .hero-emi{
  background:linear-gradient(135deg,#E3F2FD 0%,#fff 60%);
  border-left:4px solid #1565C0;
}
.shiv-hero .hero-emi .big{color:#0D47A1}
.shiv-hero .emi-row{display:flex;align-items:baseline;margin-bottom:8px}
.shiv-hero .progress{border-radius:6px;background:#E0E0E0}
.shiv-hero .progress-bar{transition:width .4s ease}

/* Tables */
.shiv-cols{display:flex;gap:14px;flex-wrap:wrap;align-items:flex-start}
.shiv-col{flex:1 1 480px;min-width:380px}
.shiv-col .wrap{display:block;width:100%;border-radius:10px;overflow:hidden}
.shiv-col .bk-table{width:100%;font-size:12px}
.shiv-col .bk-table th{font-size:10px;letter-spacing:.4px}
.shiv-col .in-amt{color:#1B5E20;font-weight:700}
.shiv-col .out-amt{color:#B71C1C;font-weight:700}
.shiv-col .bal-cell{font-weight:700}
.shiv-col .emi-toggle{font-size:10.5px;letter-spacing:.4px;font-weight:700;padding:2px 10px;border-radius:14px}
.bk-table tr.row-done td{background:#E8F5E9}
.bk-table tr.row-done:nth-child(even) td{background:#DCEDC8}

/* Daily layout — bank table left, out-parties in the gap before ledger panel */
.daily-cols{
  display:flex;flex-wrap:wrap;align-items:flex-start;gap:14px;
}
.daily-cols > .wrap{flex:0 0 auto;max-width:none}
.op-side{
  flex:1 1 360px;min-width:340px;
}
.op-side .wrap{display:block;width:100%;overflow:visible}
.op-side .bk-table{width:100%;font-size:11.5px;white-space:normal}
.op-side .bk-table th{padding:4px 5px;font-size:9.5px;letter-spacing:0}
.op-side .bk-table td{padding:3px 5px}
.op-side .bk-table input.num,
.op-side .bk-table .num-display{min-width:50px;font-size:11.5px}
.op-side .actions-cell{min-width:0}
.op-side .actions-cell .action-buttons{display:inline-flex;gap:2px;flex-wrap:nowrap}
.op-side .actions-cell .btn{padding:1px 5px;font-size:10.5px;line-height:1.2}
.op-side .op-name{font-weight:700;color:var(--blue);font-size:12px}
.op-side .op-rename{margin-left:2px;font-size:10px}
.op-side tr.op-add-row td:first-child{color:#999;font-weight:700}
.op-side tr.op-add-row .form-control-sm{padding:2px 6px;font-size:11px;height:auto}
.op-side tr.op-add-row .btn{padding:2px 8px;font-size:11px}

/* All-ledgers duplicate-detection panel */
.dup-panel{
  background:#FFF8E1;border:1px solid #FFB74D;border-radius:8px;
  padding:10px 14px;font-size:12.5px;
}
.dup-panel .dup-head{
  font-weight:700;color:#E65100;letter-spacing:.3px;
  margin-bottom:6px;font-size:12px;text-transform:uppercase;
}
.dup-panel .dup-group{
  display:flex;flex-wrap:wrap;gap:6px;
  padding:6px 0;border-top:1px dashed #FFCC80;
}
.dup-panel .dup-group:first-of-type{border-top:none;padding-top:0}
.dup-panel .dup-name{
  background:#fff;border:1px solid #FFB74D;color:#1C2833;
  padding:3px 10px;border-radius:14px;font-size:12px;font-weight:600;
  cursor:pointer;transition:all .12s;
}
.dup-panel .dup-name:hover{background:#FFE0B2;border-color:#F57C00}
.dup-panel .dup-count{color:#888;font-weight:400;font-size:10.5px;margin-left:3px}

/* Ledger company-button grid */
.company-grid{
  display:flex;flex-wrap:wrap;gap:6px;
  background:#fff;border:1px solid #E0E0E0;border-radius:8px;
  padding:8px 10px;
}
.co-btn{
  display:inline-block;padding:5px 12px;border-radius:6px;
  background:#ECEFF1;color:#1C2833;border:1px solid #CFD8DC;
  font-size:12.5px;font-weight:600;text-decoration:none;
  letter-spacing:.2px;transition:all .12s;
}
.co-btn:hover{background:#FFE0B2;border-color:#FFB74D;color:#1C2833}
.co-btn.active{background:var(--accent);border-color:var(--accent-dk);color:#fff}
.co-btn.active:hover{background:var(--accent-dk);color:#fff}

/* Banks page — inline edit row */
.bank-edit-row{
  display:flex;gap:6px;padding:4px 8px;align-items:center;
}
.bank-edit-row input{font-size:12.5px}
