
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#1B3240;--navy-mid:#22404f;--navy-light:#2a4e60;
  --gold:#DAAA3A;--gold-light:#e8bf5a;--gold-pale:#fdf6e0;
  --cream:#f9f6f1;--white:#ffffff;
  --g50:#f7f7f5;--g100:#eeece8;--g200:#dddbd4;--g300:#c5c3bb;
  --g400:#9e9c94;--g600:#6b6960;--g800:#3a3830;
  --green:#2d7a4f;--green-light:#3da06a;--green-bg:#eaf4ee;
  --grey-dead:#7c8896;--grey-dead-bg:#eef1f5;
  --amber:#b8700a;--amber-bg:#fef5e4;
  --red:#c0392b;--red-bg:#fdf0ee;
  --blue:#1a56b0;--blue-bg:#eef4fd;
  --purple:#6b3fa0;--purple-bg:#f3eefb;
  --teal:#0e7490;--teal-bg:#e0f7fa;
  --sh-sm:0 1px 3px rgba(15,31,61,.08);
  --sh-md:0 4px 16px rgba(15,31,61,.10);
  --sh-lg:0 8px 32px rgba(15,31,61,.14);
  --r:10px;--rsm:6px
}
body{font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--g800);min-height:100vh;font-size:14px;line-height:1.6}

/* TOPBAR */
.topbar{background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:58px;position:sticky;top:0;z-index:100;box-shadow:var(--sh-md);gap:12px}
.topbar-centered-brand{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:1}
.topbar-centered-brand span{font-family:'DM Serif Display',serif;font-size:21px;font-weight:400;color:#fff;letter-spacing:.01em;white-space:nowrap;line-height:1}
@media(max-width:880px){.topbar-centered-brand{display:none}}
.topbar-brand{display:flex;align-items:center;gap:8px;flex-shrink:0}
.topbar-logo-img{height:46px;display:block;object-fit:contain;width:auto}
.topbar-fallback{display:none;align-items:baseline;gap:6px;font-family:'DM Serif Display',serif;font-size:20px;color:var(--gold-light);white-space:nowrap;line-height:1}
.topbar-fallback span{font-size:11px;color:rgba(255,255,255,.55);font-family:'DM Sans',sans-serif;letter-spacing:.04em;text-transform:uppercase}
.topbar-actions{display:flex;gap:8px;flex-shrink:0}
.btn-tb{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);color:rgba(255,255,255,.85);border-radius:var(--rsm);padding:5px 12px;font-size:13px;cursor:pointer;font-family:'DM Sans',sans-serif;transition:background .15s;white-space:nowrap}
.btn-tb:hover{background:rgba(255,255,255,.16)}
.btn-tb.gold{background:var(--gold);border-color:var(--gold);color:#fff;font-weight:500}
.btn-tb.gold:hover{background:var(--gold-light)}

/* VIEWS */
.view{display:none}.view.active{display:block}

/* DATA BAR */
.data-bar{background:var(--navy);border-bottom:1px solid rgba(255,255,255,.08);padding:0 24px;height:28px;display:flex;align-items:center;gap:8px;justify-content:flex-end;position:sticky;top:58px;z-index:95}
.data-bar-label{font-size:10px;color:rgba(255,255,255,.4);letter-spacing:.08em;text-transform:uppercase;margin-right:6px;white-space:nowrap}
.btn-data{background:none;border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.7);border-radius:99px;padding:2px 10px;font-size:10px;cursor:pointer;font-family:'DM Sans',sans-serif;font-weight:500;transition:all .15s;white-space:nowrap;display:flex;align-items:center;gap:4px;line-height:1}
.btn-data:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.35);color:#fff}
.btn-data.gold{background:rgba(218,170,58,.25);border-color:var(--gold);color:var(--gold-light);font-weight:600}
.btn-data.gold:hover{background:rgba(218,170,58,.4);color:#fff}
.btn-data-sep{width:1px;height:14px;background:rgba(255,255,255,.1);margin:0 2px}

/* KPI / ANALYTICS BAR */
.kpi-bar{background:var(--navy-mid);border-bottom:1px solid rgba(255,255,255,.07);padding:0 24px;display:flex;align-items:stretch;gap:0;overflow-x:auto;flex-wrap:nowrap;position:sticky;top:86px;z-index:90;box-shadow:0 2px 8px rgba(15,31,61,.18)}
.kpi-block{padding:9px 18px;border-right:1px solid rgba(255,255,255,.08);flex-shrink:0;cursor:pointer;transition:background .15s;position:relative}
.kpi-block:hover{background:rgba(255,255,255,.07)}
.kpi-block:last-child{border-right:none}
.kpi-sep{width:1px;background:rgba(255,255,255,.15);margin:8px 6px;flex-shrink:0}
.kpi-label{font-size:10px;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:4px}
.kpi-arrow{font-size:9px;color:var(--gold-light)}
.kpi-value{font-family:'DM Sans',sans-serif;font-size:17px;color:var(--gold-light);line-height:1.2;margin-top:2px;font-weight:600}
.kpi-sub{font-size:10px;color:rgba(255,255,255,.35);margin-top:1px}

/* ANALYTICS SORT BAR (blue) */
.analytics-sort-bar{background:#1B3240;border-bottom:1px solid rgba(255,255,255,.09);padding:8px 24px;display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;position:sticky;top:86px;z-index:89;box-shadow:0 2px 8px rgba(15,31,61,.15)}
.asb-label{font-size:11px;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}
.asb-select{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.9);border-radius:var(--rsm);padding:5px 10px;font-size:12px;font-family:'DM Sans',sans-serif;cursor:pointer;min-width:150px}
.asb-select:focus{outline:none;border-color:var(--gold)}
.asb-sep{width:1px;height:20px;background:rgba(255,255,255,.12);margin:0 2px}
.asb-tabs{display:flex;gap:0;margin-left:auto}
.asb-tab{padding:5px 12px;font-size:12px;color:rgba(255,255,255,.5);cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s;white-space:nowrap;border-radius:var(--rsm) var(--rsm) 0 0}
.asb-tab:hover{color:rgba(255,255,255,.8)}
.asb-tab.active{color:var(--gold-light);border-bottom-color:var(--gold)}

/* SORT DROPDOWN */
.sort-dd{position:relative;display:inline-block}
.sort-menu{position:absolute;top:calc(100% + 4px);left:0;background:#1B3240;border:1px solid rgba(255,255,255,.14);border-radius:var(--rsm);min-width:190px;box-shadow:var(--sh-lg);z-index:400;display:none;overflow:hidden}
.sort-menu.open{display:block}
.sort-item{padding:8px 14px;font-size:12px;color:rgba(255,255,255,.8);cursor:pointer;transition:background .1s}
.sort-item:hover{background:rgba(255,255,255,.08)}
.sort-item.active{color:var(--gold-light);background:rgba(200,151,58,.08)}

/* DASHBOARD */
.dash-wrap{max-width:1160px;margin:0 auto;padding:22px 20px}
.dash-heading{font-family:'DM Serif Display',serif;font-size:26px;color:var(--navy);font-weight:400}
.dash-sub{font-size:12px;color:var(--g600);margin-top:3px;margin-bottom:18px}
.filter-bar{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap;align-items:center}
.filter-chip{padding:5px 12px;border:1px solid var(--g200);border-radius:99px;font-size:12px;background:var(--white);color:var(--g600);cursor:pointer;transition:all .15s;white-space:nowrap}
.filter-chip:hover{border-color:var(--navy);color:var(--navy)}
.filter-chip.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.filter-sep{width:1px;height:20px;background:var(--g200);margin:0 4px}
.filter-sel{border:1px solid var(--g200);border-radius:var(--rsm);padding:5px 9px;font-size:12px;font-family:'DM Sans',sans-serif;color:var(--g600);background:var(--white);cursor:pointer}
.filter-sel:focus{outline:none;border-color:var(--navy)}

/* LOAN GRID */
.loan-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:14px}
.loan-card{background:var(--white);border:1px solid var(--g200);border-radius:var(--r);padding:16px 16px 14px 20px;cursor:pointer;transition:box-shadow .15s,transform .15s,border-color .15s;box-shadow:var(--sh-sm);position:relative;overflow:hidden}
.loan-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:8px;background:var(--heat-color, var(--g200));border-radius:var(--r) 0 0 var(--r);transition:background .3s}
.loan-card:hover{box-shadow:var(--sh-md);transform:translateY(-1px);border-color:var(--gold)}
.loan-card:hover::before{background:var(--gold)}
.lc-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:9px}
.lc-name{font-family:'DM Serif Display',serif;font-size:15px;color:var(--navy);font-weight:400;line-height:1.3}
.lc-num{font-size:10px;color:var(--g400);margin-top:2px;font-weight:500;letter-spacing:.04em}
.lc-lender{font-size:10px;color:var(--g600);margin-top:1px}
.lc-badges{display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.lc-card-btns{display:flex;gap:4px;opacity:0;transition:opacity .15s}
.loan-card:hover .lc-card-btns{opacity:1}
.lc-edit{background:none;border:1px solid var(--g200);border-radius:3px;cursor:pointer;color:var(--g600);font-size:11px;padding:2px 6px;font-family:'DM Sans',sans-serif;transition:all .15s}
.lc-edit:hover{background:var(--navy);color:#fff;border-color:var(--navy)}
.lc-del{background:none;border:none;cursor:pointer;color:var(--g400);font-size:13px;padding:2px 3px;border-radius:3px;transition:color .15s}
.lc-del:hover{color:var(--red)}
.lc-amount-row{display:flex;align-items:baseline;flex-wrap:wrap;gap:6px;margin-bottom:9px;padding:7px 10px;background:var(--g50);border-radius:var(--rsm);border:1px solid var(--g100);overflow:hidden}
.lc-amount-box{background:var(--g50);border:1px solid var(--g100);border-radius:var(--rsm);padding:8px 10px;margin-bottom:8px;display:flex;flex-direction:column;gap:4px;overflow:hidden}

/* Compact comp split breakdown inside loan card grey box */
.lc-comp-mini{margin-top:6px;padding-top:6px;border-top:1px dashed var(--g200);display:flex;flex-direction:column;gap:4px}
.lc-comp-mini-bar{display:flex;height:3px;border-radius:99px;overflow:hidden;background:var(--g100)}
.lc-comp-mini-bar-lo{background:var(--green)}
.lc-comp-mini-bar-pmc{background:var(--gold)}
.lc-comp-mini-bar-rs{background:#a78bfa}
.lc-comp-mini-rows{display:flex;flex-wrap:wrap;gap:8px 12px;font-size:10.5px;color:var(--g600);line-height:1.3}
.lc-comp-mini-item{display:inline-flex;align-items:center;gap:4px;font-variant-numeric:tabular-nums;white-space:nowrap}
.lc-comp-mini-item strong{color:var(--navy);font-weight:700}
.lc-comp-mini-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.lc-comp-mini-dot.lo{background:var(--green)}
.lc-comp-mini-dot.pmc{background:var(--gold)}
.lc-comp-mini-dot.rs{background:#a78bfa}
.lc-amount-line{display:flex;align-items:baseline;gap:8px;flex-wrap:nowrap;min-width:0}
.lc-amount-line:first-child{border-bottom:1px dashed var(--g200);padding-bottom:4px}
.lc-amount-extra{font-size:11px;color:var(--blue);font-weight:600;white-space:nowrap;margin-left:auto}
.lc-amount-sub{font-size:12px;color:var(--g600);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lc-amount-comp{font-size:11.5px;color:var(--g600);font-weight:500;white-space:nowrap;font-variant-numeric:tabular-nums}
.lc-amount-comp strong{color:var(--navy);font-weight:700}
.lc-amount-close{font-size:11px;font-weight:700;border-radius:99px;padding:2px 9px;display:inline-block;white-space:nowrap;flex-shrink:0}
.lc-address{font-size:11px;color:var(--g600);margin-bottom:8px;padding:0 2px;line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lc-amount-label{font-size:10px;color:var(--g400);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}
.lc-amount-val{font-family:'DM Serif Display',serif;font-size:16px;color:var(--navy);flex:1;text-align:right}
.lc-comp-val{font-size:11px;color:var(--green);font-weight:600;white-space:nowrap}
.lc-meta{display:flex;gap:12px;margin-bottom:10px;flex-wrap:wrap}
.lc-meta-item{font-size:11px;color:var(--g600)}
.lc-meta-item span{display:block;font-size:10px;color:var(--g400);text-transform:uppercase;letter-spacing:.05em;margin-bottom:1px}
.lc-prog-bar{height:4px;background:var(--g100);border-radius:99px;margin-bottom:4px}
.lc-prog-fill{height:4px;border-radius:99px;background:var(--gold);transition:width .4s}
.lc-prog-fill.full{background:var(--green)}
.lc-prog-label{display:flex;justify-content:space-between;font-size:10px;color:var(--g400)}
.new-card{background:transparent;border:1.5px dashed var(--g200);border-radius:var(--r);padding:20px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-height:180px;transition:border-color .15s,background .15s;color:var(--g400)}
.new-card:hover{border-color:var(--gold);background:var(--gold-pale);color:var(--gold)}

/* BADGES */
.sbadge{font-size:10px;font-weight:600;padding:3px 8px;border-radius:99px;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}
.sb-new{background:var(--g100);color:var(--g600)}
.sb-active{background:var(--amber-bg);color:var(--amber)}
.sb-complete{background:var(--green-bg);color:var(--green)}
.sb-pending{background:var(--blue-bg);color:var(--blue)}
.sb-dead{background:var(--grey-dead-bg);color:var(--grey-dead);text-decoration:line-through;text-decoration-thickness:1px;text-decoration-color:rgba(124,136,150,.5)}
.tbadge{font-size:10px;padding:2px 7px;border-radius:99px;font-weight:500;white-space:nowrap}
.tb-conv{background:#eef4fd;color:#1a56b0}.tb-fha{background:#f3eefb;color:#6b3fa0}
.tb-va{background:#e0f7fa;color:#0e7490}.tb-jumbo{background:#fdf3e0;color:#b8700a}
.tb-dscr{background:#fdf0ee;color:#c0392b}.tb-refi{background:#eaf4ee;color:#2d7a4f}
.tb-usda{background:#f0f7ee;color:#3a6b2f}.tb-heloc{background:#f9f0fb;color:#8b2fa8}
.tb-reverse{background:#eef0fd;color:#3b4a9e}.tb-bridge{background:#e6f4f1;color:#0f766e}.tb-other{background:var(--g100);color:var(--g600)}

/* MODAL */
.overlay{display:none;position:fixed;inset:0;background:rgba(15,31,61,.48);z-index:300;align-items:center;justify-content:center}
.overlay.open{display:flex}
.modal{background:var(--white);border-radius:var(--r);padding:26px;width:520px;max-width:95vw;box-shadow:var(--sh-lg);max-height:92vh;overflow-y:auto}
.modal-title{font-family:'DM Serif Display',serif;font-size:20px;color:var(--navy);margin-bottom:16px}
.mfield{margin-bottom:11px}
.mlabel{font-size:11px;font-weight:600;color:var(--g600);letter-spacing:.05em;text-transform:uppercase;margin-bottom:4px;display:block}
.minput{width:100%;border:1px solid var(--g200);border-radius:var(--rsm);padding:8px 10px;font-size:13px;font-family:'DM Sans',sans-serif;color:var(--g800);background:var(--g50);transition:border-color .15s,background .15s}
.minput:focus{outline:none;border-color:var(--navy-light);background:var(--white)}
.mrow{display:flex;gap:10px}
.mrow .mfield{flex:1}
.mactions{display:flex;gap:10px;justify-content:flex-end;margin-top:18px}
.btn-cancel{background:none;border:1px solid var(--g200);border-radius:var(--rsm);padding:7px 16px;font-size:13px;cursor:pointer;color:var(--g600);font-family:'DM Sans',sans-serif}
.btn-cancel:hover{background:var(--g50)}
.btn-primary{background:var(--navy);border:none;border-radius:var(--rsm);padding:7px 18px;font-size:13px;cursor:pointer;color:#fff;font-family:'DM Sans',sans-serif;font-weight:500;transition:background .15s}
.btn-primary:hover{background:var(--navy-mid)}
.btn-danger{background:var(--red);border:none;border-radius:var(--rsm);padding:7px 16px;font-size:13px;cursor:pointer;color:#fff;font-family:'DM Sans',sans-serif;font-weight:500}
.btn-danger:hover{opacity:.9}
.confirm-msg{font-size:13px;color:var(--g600);margin-bottom:18px;line-height:1.6}

/* CHECKLIST */
.cl-wrap{max-width:880px;margin:0 auto;padding:22px 20px 60px}
.cl-back{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--g600);cursor:pointer;background:none;border:none;font-family:'DM Sans',sans-serif;margin-bottom:16px;padding:0;transition:color .15s}
.cl-back:hover{color:var(--navy)}
.cl-hdr{background:var(--navy);color:#fff;border-radius:var(--r);padding:20px 22px;margin-bottom:16px;display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap;box-shadow:var(--sh-md)}
.cl-hdr-left{flex:1;min-width:220px}
.cl-hdr-name{font-family:'DM Serif Display',serif;font-size:21px;color:var(--gold-light);font-weight:400}
.cl-hdr-lender{font-size:12px;color:rgba(255,255,255,.5);margin-top:2px}
.cl-hdr-meta{display:flex;gap:14px;margin-top:8px;flex-wrap:wrap}
.cl-hdr-mi{font-size:11px;color:rgba(255,255,255,.5)}
.cl-hdr-mi strong{color:rgba(255,255,255,.88);display:block;font-size:12px;font-weight:500}
.cl-hdr-controls{display:flex;gap:8px;align-items:center;margin-top:12px;flex-wrap:wrap}
.cl-ctrl-sel{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.9);border-radius:var(--rsm);padding:5px 9px;font-size:12px;font-family:'DM Sans',sans-serif;cursor:pointer}
.cl-ctrl-sel:focus{outline:none;border-color:var(--gold)}
.cl-ctrl-label{font-size:10px;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.06em}
.cl-edit-btn{background:rgba(200,151,58,.2);border:1px solid rgba(200,151,58,.4);color:var(--gold-light);border-radius:var(--rsm);padding:5px 11px;font-size:12px;cursor:pointer;font-family:'DM Sans',sans-serif;font-weight:500;transition:background .15s}
.cl-edit-btn:hover{background:rgba(200,151,58,.35)}
.cl-hdr-right{display:flex;flex-direction:column;align-items:flex-end;gap:5px}
.cl-prog-pct{font-family:'DM Serif Display',serif;font-size:28px;color:var(--gold-light);line-height:1}
.cl-prog-lbl{font-size:10px;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.05em}
.cl-prog-bar{width:150px;height:4px;background:rgba(255,255,255,.15);border-radius:99px}
.cl-prog-fill{height:4px;background:var(--gold);border-radius:99px;transition:width .4s}
.cl-prog-fill.full{background:var(--green-light)}
.cl-comp-display{font-size:11px;color:rgba(255,255,255,.65);text-align:right;margin-top:2px}
.cl-comp-amt{font-family:'DM Sans',sans-serif;font-size:15px;font-weight:700;color:var(--gold-light)}

/* COMP SPLIT BREAKDOWN CARD (loan file top-right) */
.cl-comp-split{margin-top:10px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:10px 12px;width:240px;box-sizing:border-box}
.cl-comp-split-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px;gap:6px}
.cl-comp-split-title{font-size:9px;color:rgba(255,255,255,.55);text-transform:uppercase;letter-spacing:.07em;font-weight:700;white-space:nowrap}
.cl-comp-split-mode{font-size:9px;color:rgba(255,255,255,.45);font-weight:500;font-style:italic;text-align:right}
.cl-comp-split-mode.ff{color:#fde68a;font-weight:700;font-style:normal;background:rgba(253,224,71,.15);border:1px solid rgba(253,224,71,.3);padding:1px 6px;border-radius:99px}
.cl-comp-split-total{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.cl-comp-split-pct{font-family:'DM Serif Display',serif;font-size:18px;color:var(--gold-light);font-weight:400}
.cl-comp-split-dollars{font-size:11px;color:rgba(255,255,255,.7);font-weight:600}
.cl-comp-split-bar{display:flex;height:5px;border-radius:99px;overflow:hidden;margin-bottom:8px;background:rgba(255,255,255,.1)}
.cl-comp-split-bar-pmc{background:var(--gold-light)}
.cl-comp-split-bar-lo{background:var(--green)}
.cl-comp-split-bar-rs{background:#a78bfa}
.cl-comp-split-rows{display:flex;flex-direction:column;gap:3px}
.cl-comp-split-row{display:grid;grid-template-columns:8px 1fr auto auto;gap:6px;align-items:center;font-size:10px}
.cl-comp-split-dot{width:7px;height:7px;border-radius:50%}
.cl-comp-split-dot.pmc{background:var(--gold-light)}
.cl-comp-split-dot.lo{background:var(--green)}
.cl-comp-split-dot.rs{background:#a78bfa}
.cl-comp-split-label{color:rgba(255,255,255,.7);font-weight:500;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cl-comp-split-val{color:rgba(255,255,255,.9);font-weight:600;font-variant-numeric:tabular-nums}
.cl-comp-split-amt{color:rgba(255,255,255,.6);font-weight:500;font-variant-numeric:tabular-nums;min-width:60px;text-align:right}
@media print{.cl-comp-split{background:#fff;border-color:#ccc}.cl-comp-split-title,.cl-comp-split-mode,.cl-comp-split-label{color:#666}.cl-comp-split-pct{color:var(--navy)}.cl-comp-split-dollars,.cl-comp-split-val{color:#333}}
@media(max-width:640px){.cl-comp-split{width:100%}}

/* SECTIONS */
.sec-card{background:var(--white);border:1px solid var(--g200);border-radius:var(--r);margin-bottom:10px;box-shadow:var(--sh-sm);overflow:hidden}
.sec-hdr{display:flex;align-items:center;justify-content:space-between;padding:11px 16px;cursor:pointer;transition:background .12s;user-select:none}
.sec-hdr:hover{background:var(--g50)}
.sec-hdr-l{display:flex;align-items:center;gap:9px}
.sec-icon{font-size:15px;width:20px;text-align:center}
.sec-name{font-size:13px;font-weight:600;color:var(--navy)}
.sec-cbadge{font-size:10px;padding:2px 8px;border-radius:99px;font-weight:600}
.scb-todo{background:var(--g100);color:var(--g600)}
.scb-partial{background:var(--amber-bg);color:var(--amber)}
.scb-done{background:var(--green-bg);color:var(--green)}
.sec-chev{color:var(--g400);font-size:10px;transition:transform .2s}
.sec-chev.open{transform:rotate(90deg)}
.sec-edit-btn{background:none;border:none;cursor:pointer;color:var(--g400);font-size:13px;padding:2px 5px;border-radius:3px;opacity:0;transition:opacity .15s,color .15s;line-height:1}
.sec-hdr:hover .sec-edit-btn{opacity:1}
.sec-edit-btn:hover{color:var(--navy);background:var(--g100)}
.sec-body{display:none;border-top:1px solid var(--g100)}
.sec-body.open{display:block}
.item-row{display:flex;align-items:flex-start;gap:10px;padding:8px 16px;border-bottom:1px solid var(--g50);transition:background .1s}
.item-row:last-of-type{border-bottom:none}
.item-row:hover{background:var(--g50)}
.item-row:hover .item-del{opacity:1}
.item-cb{margin-top:2px;width:15px;height:15px;flex-shrink:0;accent-color:var(--green);cursor:pointer}
.item-body{flex:1;min-width:0}
.item-lbl{font-size:12px;color:var(--g800);cursor:pointer;display:block;line-height:1.4}
.item-lbl.done{text-decoration:line-through;color:var(--g400)}
.item-note-txt{font-size:11px;color:var(--g400);margin-top:2px;font-style:italic}
.item-note-inp{width:100%;margin-top:5px;border:1px solid var(--g200);border-radius:var(--rsm);padding:5px 9px;font-size:11px;font-family:'DM Sans',sans-serif;color:var(--g800);background:var(--g50);resize:none;height:50px;display:none}
.item-note-inp:focus{outline:none;border-color:var(--navy-light);background:var(--white)}
.item-note-inp.open{display:block}
.item-acts{display:flex;gap:3px;align-items:flex-start;flex-shrink:0}
.item-note-btn{background:none;border:none;cursor:pointer;color:var(--g400);font-size:12px;padding:2px 3px;border-radius:3px;transition:color .1s,background .1s}
.item-note-btn:hover{color:var(--navy);background:var(--g100)}
.item-note-btn.active{color:var(--gold)}
.item-del{background:none;border:none;cursor:pointer;color:var(--g400);font-size:12px;padding:2px 3px;border-radius:3px;opacity:0;transition:opacity .15s,color .1s}
.item-del:hover{color:var(--red)}
.add-item-row{display:flex;gap:7px;padding:8px 16px;border-top:1px solid var(--g100);background:var(--g50)}
.add-item-inp{flex:1;border:1px solid var(--g200);border-radius:var(--rsm);padding:6px 9px;font-size:12px;font-family:'DM Sans',sans-serif;color:var(--g800);background:var(--white)}
.add-item-inp:focus{outline:none;border-color:var(--navy-light)}
.add-item-btn{background:var(--navy);border:none;border-radius:var(--rsm);padding:6px 12px;color:#fff;font-size:12px;cursor:pointer;font-family:'DM Sans',sans-serif;font-weight:500;transition:background .15s;white-space:nowrap}
.add-item-btn:hover{background:var(--navy-mid)}
.add-sec-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:14px;padding:12px 16px;background:var(--white);border:1.5px dashed var(--g200);border-radius:var(--r)}
.add-sec-row input,.add-sec-row select{border:1px solid var(--g200);border-radius:var(--rsm);padding:6px 9px;font-size:12px;font-family:'DM Sans',sans-serif;color:var(--g800);background:var(--g50)}
.add-sec-row input{flex:1;min-width:150px}
.add-sec-row input:focus,.add-sec-row select:focus{outline:none;border-color:var(--navy-light)}
.add-sec-btn{background:none;border:1px solid var(--g200);border-radius:var(--rsm);padding:6px 12px;font-size:12px;cursor:pointer;color:var(--navy);font-family:'DM Sans',sans-serif;font-weight:500;transition:background .15s}
.add-sec-btn:hover{background:var(--g100)}

/* ANALYTICS */
.analytics-wrap{max-width:1160px;margin:0 auto;padding:24px 20px}
.analytics-heading{font-family:'DM Serif Display',serif;font-size:22px;color:var(--navy);margin-bottom:18px}
.analytics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;margin-bottom:20px}
.a-card{background:var(--white);border:1px solid var(--g200);border-radius:var(--r);padding:18px;box-shadow:var(--sh-sm)}
.a-card-title{font-size:11px;font-weight:600;color:var(--g600);letter-spacing:.05em;text-transform:uppercase;margin-bottom:12px;font-family:'DM Sans',sans-serif}
.a-table{width:100%;border-collapse:collapse;font-family:'DM Sans',sans-serif}
.a-table th{font-size:10px;color:var(--g400);text-transform:uppercase;letter-spacing:.05em;padding:0 8px 6px 0;text-align:left;border-bottom:1px solid var(--g100);font-family:'DM Sans',sans-serif;font-weight:600}
.a-table th:not(:first-child){text-align:right}
.a-table td{padding:6px 8px 6px 0;font-size:12px;color:var(--g800);border-bottom:1px solid var(--g50);font-family:'DM Sans',sans-serif}
.a-table td:not(:first-child){text-align:right}
.a-table tr:last-child td{border-bottom:none}
.a-table .a-total td{font-weight:700;color:var(--navy);border-top:2px solid var(--g200);padding-top:9px;font-size:12px;font-family:'DM Sans',sans-serif}
.a-amount{font-size:12px;color:var(--navy);font-family:'DM Sans',sans-serif;text-align:right}
.a-amount.bold{font-weight:700}
.a-comp{color:var(--green);font-weight:600;font-family:'DM Sans',sans-serif;text-align:right}
.a-comp.bold{font-weight:700}
.a-empty{text-align:center;padding:24px;color:var(--g400);font-size:12px;font-family:'DM Sans',sans-serif}
.a-sortable{cursor:pointer;user-select:none}
.a-sortable:hover{color:var(--navy)}
.a-sort-ind{font-size:9px;margin-left:3px}

/* PRINT */
@media print{
  .topbar,.kpi-bar,.analytics-sort-bar,.cl-back,.cl-hdr-controls,.item-acts,.add-item-row,.add-sec-row,.overlay,.filter-bar,.lc-del,.lc-card-btns,.sort-dd{display:none!important}
  body{background:#fff;font-size:11px}
  .cl-wrap{padding:0;max-width:100%}
  .cl-hdr{background:var(--navy)!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .sec-body{display:block!important}
  .sec-card{box-shadow:none;border:1px solid #ccc;break-inside:avoid}
}

/* MOBILE */
@media(max-width:640px){
  /* ── Topbar ── */
  .topbar{padding:0 10px;height:50px;gap:6px}
  .topbar-brand img{height:28px;margin-left:0}
  .topbar-brand > div{display:none}
  .topbar-fallback{font-size:14px}
  .topbar-fallback span{display:none}
  .topbar-actions{gap:5px;flex-shrink:0}
  .btn-tb{padding:5px 10px;font-size:12px;white-space:nowrap}

  /* ── Backup bar ── */
  .data-bar{padding:0 10px;height:26px;gap:4px;top:50px}
  .data-bar-label{display:none}
  .btn-data{padding:2px 8px;font-size:10px}

  /* ── KPI bar ── */
  .kpi-bar{top:76px;padding:0 8px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .kpi-bar::-webkit-scrollbar{display:none}
  .kpi-block{padding:6px 10px;flex-shrink:0}
  .kpi-value{font-size:13px}
  .kpi-label{font-size:9px}
  .kpi-sub{font-size:9px}

  /* ── Analytics sort bar ── */
  .analytics-sort-bar{top:76px;padding:6px 10px;gap:6px}
  .asb-select{min-width:110px;padding:4px 6px;font-size:11px}
  .asb-label{font-size:10px}
  .asb-tabs{display:none}

  /* ── Dashboard ── */
  .dash-wrap{padding:12px 10px}
  .dash-heading{font-size:18px}
  .dash-sub{font-size:11px;margin-bottom:12px}
  .filter-bar{gap:5px;flex-wrap:wrap}
  .filter-chip{padding:4px 10px;font-size:11px}
  .filter-sel{font-size:11px;padding:4px 7px}
  .loan-grid{grid-template-columns:1fr;gap:10px}

  /* ── Loan cards ── */
  .loan-card{padding:13px 13px 12px;touch-action:manipulation}
  .lc-card-btns{opacity:1!important}
  .lc-edit,.lc-del{opacity:1!important;padding:5px 10px;font-size:11px;min-height:30px}
  .lc-name{font-size:15px}
  .lc-num,.lc-lender{font-size:11px}
  .lc-top{align-items:flex-start;gap:6px}
  .lc-badges{gap:3px;flex-wrap:wrap;justify-content:flex-end;max-width:140px}
  .lc-amount-row{flex-wrap:wrap;gap:4px;row-gap:3px}
  .lc-amount-label{font-size:9px}
  .lc-amount-val{font-size:14px;flex:none}
  .lc-comp-val{font-size:10px;white-space:nowrap}
  .lc-amount-box{padding:7px 9px}
  .lc-amount-line{flex-wrap:wrap;gap:5px}
  .lc-amount-extra{font-size:10px}
  .lc-amount-sub{font-size:11px}
  .lc-amount-comp{font-size:10.5px}
  .lc-amount-close{font-size:10px;padding:2px 7px}
  .lc-address{font-size:10px;white-space:normal}
  .lc-meta{gap:8px;flex-wrap:wrap}
  .lc-meta-item{font-size:11px}

  /* ── Modals ── */
  .modal{padding:20px 14px;width:96vw;max-height:88vh;overflow-y:auto;border-radius:14px}
  .modal-title{font-size:16px;margin-bottom:14px}
  .mrow{flex-direction:column;gap:0}
  .minput,.mselect{font-size:16px!important;padding:11px 12px}
  .btn-primary,.btn-cancel{padding:12px 16px;font-size:14px}

  /* ── Checklist ── */
  .cl-wrap{padding:10px 10px 60px}
  .cl-back{font-size:13px;padding:6px 0;margin-bottom:8px;display:block}
  .cl-hdr{padding:12px;flex-direction:column;gap:10px;border-radius:10px}
  .cl-hdr-left,.cl-hdr-right{width:100%}
  .cl-hdr-right{flex-direction:row;align-items:center;justify-content:space-between;gap:8px}
  .cl-prog-bar{flex:1}
  .cl-prog-pct{font-size:22px}
  .cl-hdr-name{font-size:18px}
  .cl-hdr-meta{gap:8px;flex-wrap:wrap}
  .cl-hdr-mi{font-size:12px}
  .cl-hdr-controls{flex-wrap:wrap;gap:6px}
  .cl-ctrl-label{font-size:11px}
  .cl-ctrl-sel{font-size:13px;padding:6px 8px}
  .cl-edit-btn{padding:7px 10px;font-size:12px;min-height:34px}

  /* ── Sections & items ── */
  .sec-hdr{padding:12px 14px;min-height:44px}
  .sec-edit-btn{opacity:1!important;padding:5px 8px;font-size:12px;min-height:32px}
  .item-row{padding:11px 12px;min-height:44px;align-items:flex-start}
  .item-cb{width:20px;height:20px;flex-shrink:0;margin-top:1px}
  .item-label{font-size:13px;line-height:1.4}
  .item-acts button{padding:5px 9px;font-size:11px;min-height:32px}
  .note-ta{font-size:14px;padding:8px 10px}
  .add-item-row{padding:8px 12px;gap:6px}
  .add-item-row input{font-size:15px;padding:9px 10px}
  .add-item-row button{padding:9px 12px;font-size:12px;white-space:nowrap;min-height:38px}
  .add-sec-row{padding:10px 12px;gap:6px;flex-wrap:wrap}
  .add-sec-row input{font-size:14px;flex:1;min-width:130px;padding:9px 10px}
  .add-sec-row button{padding:9px 14px;font-size:12px;min-height:38px}

  /* ── Analytics ── */
  .analytics-wrap{padding:12px 10px}
  .analytics-grid{grid-template-columns:1fr}
  div[style*="repeat(2,minmax(0,1fr))"]{grid-template-columns:1fr!important}
  div[style*="grid-row:1 / span 2"]{grid-row:auto!important}
  .a-stat-card{padding:10px 12px}
  .a-stat-val{font-size:16px}
  .a-table{font-size:11px}
  .a-table th{font-size:9px;padding:4px 0}
  .a-table td{font-size:11px;padding:5px 0}
  .analytics-heading{font-size:18px}
  div[style*="repeat(6,1fr)"]{grid-template-columns:repeat(2,1fr)!important}

  /* ── Password / setup overlay ── */
  #wlp-overlay > div{padding:28px 18px!important;margin:10px!important;width:calc(100vw - 20px)!important;max-width:380px!important}
}

@media(max-width:400px){
  .btn-tb{padding:5px 8px;font-size:11px}
  .lc-badges{max-width:120px}
  div[style*="repeat(6,1fr)"]{grid-template-columns:repeat(2,1fr)!important}
  .modal{width:99vw;padding:16px 12px}
  .cl-hdr-name{font-size:16px}
}


/* Mobile-specific overrides — must come after all other rules */
@media(max-width:640px){
  .topbar-brand > div,
  .topbar-brand div[style*="margin-left"]{display:none!important}
  .topbar{overflow:hidden}
  .lc-amount-row{overflow:hidden;min-width:0}
  .lc-amount-row > *{min-width:0;overflow:hidden;text-overflow:ellipsis}
}
.empty-dash{grid-column:1/-1;text-align:center;padding:50px 20px;color:var(--g400)}

/* ── GLOBAL FOOTER ── */
.wlp-footer{margin-top:60px;padding:24px 20px 32px;background:linear-gradient(180deg,transparent 0%,rgba(27,50,64,.04) 50%,rgba(27,50,64,.08) 100%);border-top:1px solid rgba(27,50,64,.1);text-align:center}
.wlp-footer-inner{display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:center}
.wlp-footer-brand{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--g600);font-weight:500;letter-spacing:.04em;text-transform:uppercase}
.wlp-footer-sep{color:var(--gold);font-size:14px;font-weight:700}
.wlp-footer-copy{font-family:'DM Sans',sans-serif;font-size:12px;color:var(--g600);font-weight:500;letter-spacing:.04em;text-transform:uppercase}
@media print{.wlp-footer{display:none}}
@media(max-width:640px){
  .wlp-footer{margin-top:40px;padding:20px 16px 28px}
  .wlp-footer-brand{font-size:10px}
  .wlp-footer-copy{font-size:10px}
}
.empty-icon{font-size:40px;margin-bottom:12px}
.empty-text{font-size:15px;color:var(--g600);margin-bottom:6px}
.storage-info{background:var(--g50);border:1px solid var(--g200);border-radius:var(--r);padding:16px 20px;margin:0 0 18px;font-size:12px;color:var(--g600);line-height:1.7}
.storage-info strong{color:var(--navy);font-weight:600}
.storage-info code{background:var(--g100);padding:1px 5px;border-radius:3px;font-family:monospace;font-size:11px;color:var(--navy)}
.a-stat-card{background:var(--white);border:1px solid var(--g200);border-radius:var(--r);padding:14px 16px;box-shadow:var(--sh-sm)}
.a-stat-card.a-stat-green{border-left:3px solid var(--green)}
.a-stat-card.a-stat-amber{border-left:3px solid var(--amber)}
.a-stat-label{font-size:10px;font-weight:600;color:var(--g400);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px;font-family:'DM Sans',sans-serif}
.a-stat-val{font-family:'DM Sans',sans-serif;font-size:18px;font-weight:700;color:var(--navy);line-height:1.1}
.a-stat-val.a-stat-sm{font-size:18px;font-weight:700}
.a-stat-sub{font-size:11px;color:var(--g400);margin-top:3px;font-family:'DM Sans',sans-serif}
