
  :root{
    --blue:#0b2541; --lift:#16335a; --pink:#ec7c82; --rose:#c85a61;
    --bg:#eef1f6; --card:#fff; --line:#d7dee8; --ink:#1a2433; --mut:#64748b;
    --green:#1e7f4f; --amber:#b5791f; --red:#b23a3a;
    --radius:10px; --shadow:0 1px 3px rgba(11,37,65,.08),0 4px 16px rgba(11,37,65,.06);
  }
  *{box-sizing:border-box;margin:0;padding:0}
  body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:14px;line-height:1.45}
  header{background:var(--blue);color:#fff;padding:0 24px;height:60px;display:flex;align-items:center;gap:20px;position:sticky;top:0;z-index:30;box-shadow:0 2px 10px rgba(11,37,65,.18)}
  .wordmark{font-weight:800;letter-spacing:.5px;font-size:20px;color:var(--pink)}
  .wordmark span{color:#fff;font-weight:500;font-size:13px;margin-left:8px;opacity:.85}
  header nav{margin-left:auto;display:flex;gap:4px}
  header nav button{background:transparent;border:0;color:#cdd8e6;padding:8px 14px;border-radius:7px;cursor:pointer;font-size:13px;font-weight:600}
  header nav button.on{background:var(--lift);color:#fff}
  header nav button:hover{color:#fff}
  main{max-width:1300px;margin:0 auto;padding:24px}
  .view{display:none}.view.on{display:block}
  h1{font-size:22px;font-weight:700;color:var(--blue)}
  .sub{color:var(--mut);font-size:13px;margin-top:2px}
  .crumb{font-size:12px;color:var(--mut);margin-bottom:6px}
  .crumb b{color:var(--blue)}
  .row{display:flex;gap:16px;flex-wrap:wrap}
  .between{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
  .card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
  /* date range bar */
  .ranger{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px 18px;display:flex;align-items:flex-end;gap:16px;flex-wrap:wrap;margin:16px 0}
  .ranger .fld{display:flex;flex-direction:column;gap:4px}
  .ranger label{font-size:10.5px;text-transform:uppercase;letter-spacing:.5px;color:var(--mut);font-weight:700}
  .ranger input[type=date]{padding:8px 11px;border:1px solid var(--line);border-radius:8px;font-size:14px;font-family:inherit}
  .ranger .quick{display:flex;gap:6px;margin-left:auto;align-items:center}
  /* kpi */
  .kpi{flex:1;min-width:165px;padding:15px 17px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);position:relative;overflow:hidden}
  .kpi:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--pink)}
  .kpi.b:before{background:var(--blue)}.kpi.r:before{background:var(--rose)}.kpi.g:before{background:var(--green)}.kpi.a:before{background:var(--amber)}
  .kpi .lab{font-size:10px;text-transform:uppercase;letter-spacing:.6px;color:var(--mut);font-weight:700}
  .kpi .val{font-size:24px;font-weight:800;color:var(--blue);margin-top:4px;font-variant-numeric:tabular-nums}
  .kpi .val.red{color:var(--red)}
  .kpi .note{font-size:11px;color:var(--mut);margin-top:2px}
  .btn{display:inline-flex;align-items:center;gap:7px;border:0;border-radius:8px;padding:9px 16px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;transition:.12s}
  .btn.primary{background:var(--pink);color:#fff}.btn.primary:hover{background:var(--rose)}
  .btn.dark{background:var(--blue);color:#fff}.btn.dark:hover{background:var(--lift)}
  .btn.ghost{background:#fff;color:var(--blue);border:1px solid var(--line)}.btn.ghost:hover{border-color:var(--pink);color:var(--rose)}
  .btn.sm{padding:6px 11px;font-size:12px}
  .btn:disabled{opacity:.45;cursor:not-allowed}
  table{width:100%;border-collapse:collapse;font-size:13px}
  thead th{background:var(--blue);color:#fff;text-align:left;padding:10px 11px;font-size:10.5px;text-transform:uppercase;letter-spacing:.4px;font-weight:700}
  thead th.r{text-align:right}
  tbody td{padding:9px 11px;border-bottom:1px solid var(--line);vertical-align:middle}
  tbody td.r{text-align:right;font-variant-numeric:tabular-nums}
  tbody tr:hover{background:#f7f9fc}
  tbody tr.sel{background:#fdeef0}tbody tr.sel:hover{background:#fbe4e7}
  tbody tr.paidrow{background:#f3faf6}
  tbody tr.forecast td{color:#7a8699}
  .muted{color:var(--mut)}
  .tag{display:inline-block;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:700;white-space:nowrap}
  .t-dd{background:#e7eefc;color:#2a4a8f}.t-man{background:#e3f3ec;color:#1e7f4f}
  .t-pyrl{background:#fde7ec;color:#b23a3a}.t-ni{background:#f3e8fb;color:#7a3da8}
  .t-agent{background:#fdeee0;color:#b5791f}
  .kind{font-size:10px;font-weight:700;padding:1px 7px;border-radius:5px;border:1px solid var(--line);color:var(--mut);margin-left:6px}
  .st{font-size:11px;font-weight:700;padding:2px 9px;border-radius:20px;white-space:nowrap}
  .st-due{background:#fdf4e3;color:var(--amber)}
  .st-paid{background:#e3f3ec;color:var(--green)}
  .st-fc{background:#eef1f6;color:var(--mut)}
  .st-over{background:#fde7ec;color:var(--red)}
  .st-conf{background:#e7f0fb;color:#2a4a8f}
  tbody tr.confrow{background:#f6f9fe}tbody tr.confrow:hover{background:#eef4fc}
  .invno{font-size:10px;color:var(--mut);font-weight:600;margin-top:1px}
  .overdue-card{border:1px solid #f3b8be;box-shadow:0 1px 3px rgba(178,58,58,.1)}
  .overdue-head{background:#fdeef0;color:var(--red);font-weight:800;font-size:12px;padding:9px 14px;border-bottom:1px solid #f3b8be}
  tbody tr.overrow{background:#fffafb}tbody tr.overrow:hover{background:#fdf2f4}
  tbody tr.overrow.sel{background:#fbe4e7}
  .unsched-card{border:1px solid #cdd8e6}
  .unsched-head{background:#eef3fa;color:var(--lift);font-weight:800;font-size:12px;padding:9px 14px;border-bottom:1px solid #cdd8e6}
  tbody tr.unschedrow{background:#fbfcfe}tbody tr.unschedrow:hover{background:#f4f8fc}
  tbody tr.unschedrow.sel{background:#fdeef0}
  .offcash{display:inline-block;margin-left:7px;font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--mut);background:#eef1f6;border:1px solid var(--line);padding:1px 6px;border-radius:5px}
  input[type=checkbox]{width:17px;height:17px;accent-color:var(--pink);cursor:pointer}
  .chk{font-size:12px;color:var(--mut);display:inline-flex;align-items:center;gap:6px;cursor:pointer;user-select:none}
  .selbar{position:sticky;bottom:0;background:var(--blue);color:#fff;border-radius:var(--radius);padding:13px 18px;display:flex;align-items:center;gap:16px;box-shadow:0 -2px 18px rgba(11,37,65,.25);margin-top:14px;flex-wrap:wrap}
  .selbar .n{font-weight:800;font-size:15px}
  .selbar .amt{font-size:17px;font-weight:800;color:var(--pink);font-variant-numeric:tabular-nums}
  .selbar .sp{margin-left:auto;display:flex;gap:10px;flex-wrap:wrap}
  .selbar input[type=date]{padding:7px 10px;border-radius:7px;border:0;font-family:inherit;font-size:13px}
  .scrim{position:fixed;inset:0;background:rgba(11,37,65,.55);display:none;align-items:flex-start;justify-content:center;z-index:50;padding:36px 16px;overflow:auto}
  .scrim.on{display:flex}
  .modal{background:#fff;border-radius:12px;width:100%;max-width:600px;box-shadow:0 20px 60px rgba(0,0,0,.3);overflow:hidden}
  .modal h3{background:var(--blue);color:#fff;padding:16px 20px;font-size:16px;display:flex;justify-content:space-between;align-items:center}
  .modal h3 .x{cursor:pointer;opacity:.7;font-weight:400}.modal h3 .x:hover{opacity:1}
  .modal .body{padding:20px}
  .modal .foot{padding:14px 20px;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:10px;background:#fafbfd;align-items:center}
  .fld2{margin-bottom:13px}
  .fld2 label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--mut);font-weight:700;margin-bottom:4px}
  .fld2 input,.fld2 select{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:8px;font-size:14px;font-family:inherit}
  .fld2 input:focus,.fld2 select:focus{outline:0;border-color:var(--pink)}
  .grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  .grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
  .seg{display:flex;border:1px solid var(--line);border-radius:8px;overflow:hidden}
  .seg button{flex:1;border:0;background:#fff;padding:9px;font-size:13px;font-weight:700;cursor:pointer;color:var(--mut);font-family:inherit}
  .seg button.on{background:var(--blue);color:#fff}
  pre.csv{background:var(--blue);color:#d7e3f4;padding:16px;border-radius:8px;font-size:12px;overflow:auto;font-family:"SF Mono",Menlo,monospace;line-height:1.65;white-space:pre;max-height:300px}
  pre.csv .hl{color:var(--pink)}
  .toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(100px);background:var(--green);color:#fff;padding:13px 22px;border-radius:10px;font-weight:700;font-size:14px;box-shadow:0 8px 30px rgba(0,0,0,.25);z-index:80;transition:.3s;opacity:0;max-width:90vw;text-align:center}
  .toast.on{transform:translateX(-50%) translateY(0);opacity:1}
  .help{background:#f7f9fc;border:1px solid var(--line);border-left:3px solid var(--pink);border-radius:8px;padding:11px 14px;font-size:12.5px;color:var(--mut);margin-bottom:14px}
  .help b{color:var(--blue)}
  .empty{padding:38px;text-align:center;color:var(--mut)}
  .pills{display:flex;gap:6px;flex-wrap:wrap}
  .pill{padding:6px 13px;border-radius:20px;font-size:12px;font-weight:700;border:1px solid var(--line);background:#fff;color:var(--mut);cursor:pointer}
  .pill.on{background:var(--blue);color:#fff;border-color:var(--blue)}
  .lockico{font-size:11px;color:var(--mut);margin-left:5px}
  .foot-note{font-size:11.5px;color:var(--mut)}
  @media(max-width:760px){thead th{font-size:9.5px;padding:8px 6px}tbody td{padding:8px 6px}}
