/* ============================================================
   AI4Colegios UI Kit — kit.css
   Component styles for the Libro de Pago recreation.
   Tokens come from ../../colors_and_type.css (linked first).
   ============================================================ */
*{box-sizing:border-box}
html{color-scheme:light}
html[data-theme="dark"]{color-scheme:dark}
body{margin:0;font-family:var(--font-sans);font-size:var(--fs-body);line-height:var(--lh-body);
  background:var(--warm);color:var(--text);font-variant-numeric:lining-nums;-webkit-font-smoothing:antialiased}
@media (prefers-reduced-motion: reduce){*,*::before,*::after{transition-duration:.01ms!important;animation-duration:.01ms!important}}
:focus-visible{outline:none;box-shadow:var(--focus-ring);border-radius:4px}
button{font-family:inherit}

/* ---------- CREST (CSS-drawn) ---------- */
.ds-shield{background:radial-gradient(circle at 30% 30%, #F4D03F 0%, var(--gold) 55%, var(--gold-dark) 100%);
  border-radius:50% 50% 50% 0;transform:rotate(-45deg);border:2px solid #fff;display:grid;place-items:center;flex:none}
.ds-shield-inner{transform:rotate(45deg);color:#7C2D12;font-weight:700;font-size:12px;font-family:var(--font-serif)}

/* ---------- DEV TOGGLES ---------- */
.dev-toggles{position:fixed;top:14px;right:14px;z-index:9999;display:flex;align-items:center;gap:4px;
  background:rgba(15,20,30,0.86);backdrop-filter:blur(8px);border-radius:9px;padding:4px;
  box-shadow:0 4px 16px rgba(0,0,0,0.25), 0 0 0 1px rgba(255,255,255,0.06) inset}
.dev-toggles .toggle-group{display:flex;gap:2px}
.toggle-divider{width:1px;height:20px;background:rgba(255,255,255,0.16);margin:0 4px}
.dev-toggles button{background:transparent;border:0;color:rgba(255,255,255,0.55);font-family:inherit;font-size:11px;
  font-weight:700;letter-spacing:0.08em;cursor:pointer;padding:6px 10px;border-radius:5px;min-height:28px;
  display:flex;align-items:center;justify-content:center;line-height:1;transition:color .12s,background-color .12s}
.dev-toggles button:hover{color:rgba(255,255,255,0.85)}
.dev-toggles button[aria-pressed="true"]{background:var(--accent);color:#fff;box-shadow:0 1px 2px rgba(0,0,0,0.2)}
.dev-toggles button svg{width:14px;height:14px}
.dev-toggles .toggle-label{font-size:11px;font-weight:700;letter-spacing:0.1em;color:rgba(255,255,255,0.35);
  text-transform:uppercase;margin:0 6px;align-self:center}

/* ---------- HEADER ---------- */
header.app{background:var(--header-bg);color:#fff;padding:12px 24px;display:flex;justify-content:space-between;align-items:center}
header.app .brand-row-btn{background:transparent;border:0;padding:6px 10px;margin:-6px -10px;cursor:pointer;color:inherit;
  font-family:inherit;text-align:left;border-radius:10px;transition:background-color .12s,transform .08s}
header.app .brand-row-btn:hover{background:rgba(255,255,255,0.06)}
header.app .brand-row-btn:active{transform:scale(0.98)}
header.app .brand-row{display:flex;align-items:center;gap:12px}
header.app .brand{font-weight:600;font-size:16px;font-family:var(--font-serif);letter-spacing:-0.01em;display:block;color:#fff}
header.app .brand small{opacity:.7;font-weight:400;margin-left:6px;font-family:inherit;font-size:13px}
header.app .motto{display:block;font-size:11px;color:#A8B5D6;font-weight:400;font-style:italic;margin-top:2px;font-family:var(--font-serif)}
header.app .me{font-size:13px;display:flex;gap:10px;align-items:center;margin-right:172px}
header.app .me .avatar{background:var(--accent);color:#fff;border-radius:50%;width:28px;height:28px;display:grid;place-items:center;font-weight:600;font-size:12px}
header.app .saved-indicator{font-size:11.5px;color:#A8B5D6;display:flex;align-items:center;gap:6px;margin-right:8px}
header.app .saved-indicator .check{background:var(--status-good);color:#fff;border-radius:50%;width:14px;height:14px;display:inline-grid;place-items:center;font-size:9px;font-weight:700}

/* ---------- APP SHELL ---------- */
.app-shell{display:flex;align-items:stretch;height:calc(100vh - 59px)}
.main-col{flex:1;min-width:0;overflow-y:auto;overflow-x:hidden}

/* ---------- LEFT NAV ---------- */
.leftnav{width:var(--rail-left);flex:0 0 var(--rail-left);background:var(--sidebar-bg);color:#fff;padding:14px 0;
  display:flex;flex-direction:column;position:relative;transition:width .18s,flex-basis .18s}
body.nav-collapsed .leftnav{width:var(--rail-collapsed);flex:0 0 var(--rail-collapsed)}
.nav-toggle{position:absolute;top:14px;right:-13px;z-index:61;width:26px;height:26px;border-radius:50%;
  border:1px solid var(--grid);background:var(--paper);color:var(--text);cursor:pointer;font-size:13px;display:grid;place-items:center}
.nav-main{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column}
.nav-foot{flex-shrink:0;border-top:1px solid var(--sidebar-border);padding-top:6px;margin-top:4px}
.nav-section-label{font-size:10px;text-transform:uppercase;letter-spacing:0.08em;color:#7B8AB8;padding:8px 16px 4px;font-weight:700;margin-top:6px}
body.nav-collapsed .nav-section-label{height:1px;padding:6px 0;overflow:hidden;color:transparent}
.leftnav a.nav-item{display:flex;align-items:center;gap:10px;padding:9px 16px;font-size:12.5px;color:#D3DAE8;
  text-decoration:none;border-left:3px solid transparent;transition:background-color .12s}
.leftnav a.nav-item:hover{background:var(--sidebar-hover)}
.leftnav a.nav-item[aria-current="page"]{background:var(--sidebar-hover);border-left-color:var(--accent);color:#fff}
.leftnav a.nav-item .nav-ico{flex:0 0 20px;width:20px;height:20px;display:grid;place-items:center;color:#9FB0D6;font-size:18px}
.leftnav a.nav-item[aria-current="page"] .nav-ico{color:#fff}
.leftnav a.nav-item .lbl{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:6px}
.leftnav a.menu-link{color:#9FB0D6;font-size:11.5px}
.menu-arrow{margin-left:auto;opacity:.6}
.nav-dot{width:7px;height:7px;border-radius:50%;background:var(--status-good)}
body.nav-collapsed .leftnav .lbl,body.nav-collapsed .menu-arrow{display:none}
body.nav-collapsed .leftnav a.nav-item{justify-content:center;gap:0;padding:9px 0;border-left-color:transparent}
body.nav-collapsed .leftnav a.nav-item[aria-current="page"]{box-shadow:inset 3px 0 0 var(--accent)}

/* today payments */
.nav-today{padding:2px 10px}
body.nav-collapsed .nav-today{padding:2px 4px}
.today-payment{display:flex;flex-direction:column;gap:2px;width:100%;text-align:left;background:transparent;border:0;
  padding:7px 8px;border-radius:7px;cursor:pointer;color:#D3DAE8;transition:transform .1s,background-color .12s;margin-bottom:2px}
.today-payment:hover{background:var(--sidebar-hover);transform:translateY(-1px)}
.today-payment .who{font-size:11.5px;font-weight:600;color:#E5E7EB;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}
.today-payment .amt{font-family:var(--font-mono);font-size:12px;font-weight:700;color:#86EFAC}
.today-payment .meta{display:flex;align-items:center;gap:8px;font-size:10px;color:#7B8AB8}
.today-payment .method-pill{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:1px 6px;border-radius:999px}
.today-payment .method-pill.cash{background:rgba(21,128,61,0.22);color:#86EFAC}
.today-payment .method-pill.transfer{background:rgba(124,58,237,0.22);color:#C4B5FD}
.today-payment .method-pill.card{background:rgba(30,64,175,0.22);color:#93C5FD}
.today-mini{display:flex;flex-direction:column;align-items:center;font-size:8px;color:#9FB0D6;padding:4px 0;border-radius:5px}
.today-mini .amt{font-family:var(--font-mono);font-weight:700;color:#86EFAC;font-size:9px}

/* ---------- PAGE TITLE ---------- */
.page-title-row{background:var(--paper);border-bottom:1px solid var(--grid-strong);padding:16px 24px 12px;
  display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex:none}
.page-title{font-family:var(--font-serif);font-size:var(--fs-page-title);font-weight:600;color:var(--text);margin:0;letter-spacing:-0.01em}
.page-title small{font-weight:400;color:var(--text-muted);font-size:13px;display:block;margin-top:3px;font-family:inherit;letter-spacing:0}
.title-actions{display:flex;gap:10px;flex:none}
.btn-primary,.btn-secondary{display:inline-flex;align-items:center;gap:8px;border-radius:var(--radius-ctrl);padding:9px 16px;
  font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;min-height:38px;transition:background-color .12s,transform .08s}
.btn-primary:active,.btn-secondary:active{transform:scale(0.98)}
.btn-primary{background:var(--accent);color:#fff;border:0;box-shadow:0 2px 6px rgba(44,140,153,.3)}
.btn-primary:hover{background:var(--accent-dark)}
.btn-secondary{background:var(--paper);color:var(--text);border:1px solid var(--grid-strong)}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}
.btn-primary svg,.btn-secondary svg{font-size:15px}

/* ---------- STATS ---------- */
.stats{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--grid);border-bottom:1px solid var(--grid-strong);flex:none}
.stat{background:var(--paper);padding:12px 18px}
.stat .lbl{font-size:11px;text-transform:uppercase;letter-spacing:0.08em;color:var(--text-muted);font-weight:600}
.stat .val{font-size:var(--fs-stat);font-weight:600;margin-top:4px;color:var(--text);font-family:var(--font-mono);
  font-variant-numeric:tabular-nums lining-nums;line-height:1.1}
.stat.good .val{color:var(--status-good)}
.stat.warn .val{color:var(--status-mora2)}
.stat .currency-tag{display:inline-block;font-size:11px;color:var(--text-muted);font-weight:600;margin-left:6px;
  vertical-align:3px;letter-spacing:0.08em;background:var(--warm-2);padding:1px 6px;border-radius:3px;font-family:var(--font-sans)}

/* ---------- TOOLBAR ---------- */
.toolbar{background:var(--paper);padding:12px 16px;display:flex;gap:10px;align-items:center;flex-wrap:wrap;border-bottom:1px solid var(--grid-strong);flex:none}
.search-wrap{position:relative;display:flex;align-items:center}
.search-wrap .search-ico{position:absolute;left:10px;color:var(--text-muted);font-size:15px;pointer-events:none}
.toolbar input{border:1px solid var(--grid-strong);border-radius:var(--radius-input);padding:8px 10px 8px 32px;font-size:13px;
  background:var(--paper);color:var(--text);font-family:inherit;min-height:34px;min-width:240px}
.toolbar select{border:1px solid var(--grid-strong);border-radius:var(--radius-input);padding:8px 10px;font-size:13px;
  background:var(--paper);color:var(--text);font-family:inherit;min-height:34px}
.qv-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:700}
.qv-chip{background:var(--paper);color:var(--text-soft);border:1px solid var(--grid-strong);padding:7px 14px;
  border-radius:var(--radius-pill);font-size:12.5px;font-weight:600;cursor:pointer;font-family:inherit;min-height:34px}
.qv-chip:hover{border-color:var(--accent);color:var(--accent)}
.qv-chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.fam-chip{border-style:solid}
.spacer{flex:1}
.btn-ghost-mini{background:transparent;color:var(--text-muted);border:1px solid var(--grid);padding:8px 12px;
  border-radius:var(--radius-input);font-size:12px;font-weight:500;cursor:pointer;font-family:inherit;min-height:34px}
.btn-ghost-mini:hover{color:var(--accent);border-color:var(--accent)}
.vista-count{color:var(--text-muted);font-weight:400}

/* ---------- CONTEXT STRIP ---------- */
.ctx-strip{background:var(--warm-2);padding:8px 16px;display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  border-bottom:1px solid var(--grid);font-size:12.5px;color:var(--text-soft);flex:none}
.ctx-strip b{color:var(--text);font-family:var(--font-mono)}
.ctx-strip .pager{display:flex;align-items:center;gap:10px;margin-left:auto}
.ctx-strip .pager button{background:transparent;border:1px solid var(--grid-strong);border-radius:6px;padding:5px 12px;
  font-size:12px;cursor:pointer;color:var(--text-soft);font-family:inherit;min-height:32px}
.ctx-strip .pager button:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}
.ctx-strip .pager button:disabled{opacity:.4;cursor:default}
.legend{padding:7px 16px;display:flex;align-items:center;gap:16px;flex-wrap:wrap;font-size:11px;color:var(--text-muted);
  background:var(--paper);border-bottom:1px solid var(--grid);flex:none}
.legend .li{display:inline-flex;align-items:center;gap:6px}
.legend .swatch{width:13px;height:13px;border-radius:3px;border:1px solid var(--grid-strong)}
.legend .swatch.paid{background:var(--money-cell-paid);border-color:var(--status-good)}
.legend .swatch.mora{background:var(--money-cell-mora);border-color:var(--status-mora2)}
.legend .swatch.cur{background:rgba(251,191,36,0.18);border-color:#B45309}
.legend .swatch.future{background:var(--warm-2)}

/* ---------- THE LEDGER TABLE ---------- */
.sheet{margin:0;background:var(--paper);overflow-x:auto;overflow-y:visible}
table.libro{border-collapse:separate;border-spacing:0;width:max-content;min-width:100%;font-size:var(--fs-cell)}
table.libro caption.fee-cap{caption-side:top;padding:0;text-align:left}
.fee-inner{background:var(--warm-2);border-bottom:1px solid var(--grid-strong);padding:8px 16px;font-size:12px;
  color:var(--text-soft);display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.fee-cap .fee-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:700}
.fee-cap .fee-item strong{color:var(--text);font-weight:600;font-family:var(--font-mono);font-variant-numeric:tabular-nums}
.fee-cap .fee-note{color:var(--text-muted);font-size:11px}
table.libro th,table.libro td{border-right:1px solid var(--grid);border-bottom:1px solid var(--grid);padding:8px 10px;text-align:left;white-space:nowrap}
table.libro thead th{position:sticky;background:var(--thead-bg);font-weight:700;font-size:11px;color:var(--text-soft);z-index:3}
table.libro thead tr.band-row th{top:0;will-change:transform;text-transform:uppercase;letter-spacing:.06em;text-align:center;font-size:10.5px;
  color:var(--text-muted);background:var(--warm-2);border-bottom:2px solid var(--grid-strong);z-index:4}
table.libro thead tr.band-row .band-pay{background:#EEF4F5}
table.libro thead tr.band-row .band-paid{background:#F0F7F1}
table.libro thead tr.band-row .band-saldo{background:#FBF1EE}
table.libro thead tr.head-row th{top:31px}
table.libro th.money,table.libro td.money{text-align:right;font-family:var(--font-mono);font-variant-numeric:tabular-nums lining-nums}
table.libro thead th.money{text-align:right}
table.libro tbody tr:nth-child(even) td{background:var(--row-even)}
table.libro tbody tr:hover td{background:var(--warm-2)}
table.libro tbody tr.row-selected td{background:var(--status-good-bg)!important}

/* sticky columns */
.selcol{width:34px;text-align:center!important;padding:8px 6px!important}
table.libro th.sticky-0,table.libro td.sticky-0{position:sticky;left:0;z-index:2}
table.libro th.sticky-1,table.libro td.sticky-1{position:sticky;left:34px;z-index:2}
table.libro th.sticky-2,table.libro td.sticky-2{position:sticky;left:74px;z-index:2;min-width:210px}
table.libro th.sticky-3,table.libro td.sticky-3{position:sticky;left:284px;z-index:2;text-align:center}
table.libro thead th.sticky-0,table.libro thead th.sticky-1,table.libro thead th.sticky-2,table.libro thead th.sticky-3{z-index:5}
table.libro tbody td.sticky-0,table.libro tbody td.sticky-1,table.libro tbody td.sticky-2,table.libro tbody td.sticky-3{background:var(--paper)}
table.libro tbody tr:nth-child(even) td.sticky-0,table.libro tbody tr:nth-child(even) td.sticky-1,
table.libro tbody tr:nth-child(even) td.sticky-2,table.libro tbody tr:nth-child(even) td.sticky-3{background:var(--row-even)}
table.libro tbody tr.row-selected td.sticky-0,table.libro tbody tr.row-selected td.sticky-1,
table.libro tbody tr.row-selected td.sticky-2,table.libro tbody tr.row-selected td.sticky-3{background:var(--status-good-bg)!important}
.col-no{text-align:center;color:var(--text-muted)}
.col-gr{text-align:center;font-weight:600}
.name-link{background:transparent;border:0;padding:0;font-family:inherit;font-size:var(--fs-cell);font-weight:600;
  color:var(--text);cursor:pointer;text-align:left}
.name-link:hover{color:var(--accent);text-decoration:underline}
.fam-count{font-size:10px;color:var(--text-muted);margin-left:6px;background:var(--warm-2);border-radius:4px;padding:1px 5px}

/* pills */
.pill{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:700;letter-spacing:0.04em;text-transform:uppercase}
.pill.good{background:var(--status-good-bg);color:var(--status-good)}
.pill.mora1{background:var(--status-mora1-bg);color:var(--status-mora1)}
.pill.mora2{background:var(--status-mora2-bg);color:var(--status-mora2)}
.pill.pagado{background:var(--status-pagado-bg);color:var(--status-pagado)}

/* money cells */
td.money.auto{color:var(--text-muted);background:var(--money-cell)}
td.money.strong{color:var(--text);font-weight:700}
td.money.paid{background:var(--money-cell-paid);color:var(--status-good);text-align:center;font-weight:700}
td.money.mora{background:var(--money-cell-mora);color:var(--status-mora2);text-align:center;font-weight:700}
td.money.future{color:var(--text-muted);text-align:center}
td.cell[role="button"]{cursor:pointer}
td.cell[role="button"]:hover{outline:2px solid var(--accent);outline-offset:-2px}
th.mcol,td.mcol{text-align:center;min-width:42px}
th.current-month{background:#FEF3C7;color:#92400E}
td.current-month-col{background:rgba(251,191,36,0.10)}
td.current-month-col.paid{background:rgba(21,128,61,0.14)}
td.current-month-col.mora{background:rgba(185,28,28,0.12)}
.col-saldo.mora{color:var(--status-mora2);font-weight:700}
.col-acc{text-align:center}
.col-acc .action-wa{background:transparent;border:0;color:#15803D;cursor:pointer;font-size:16px;vertical-align:middle;padding:2px}
.col-acc .action-wa:hover{color:#25D366}
.concil-dot{display:inline-block;width:16px;font-weight:700;margin-right:6px}
.concil-dot.done{color:var(--status-good)}
.concil-dot.pending{color:var(--status-mora1)}
.concil-dot.na{color:var(--text-muted)}

/* ---------- WHATSAPP RAIL ---------- */
.msgrail{flex:0 0 var(--rail-right);width:var(--rail-right);background:var(--paper);border-left:1px solid var(--grid-strong);
  display:flex;flex-direction:column;min-height:0;position:relative;transition:width .18s,flex-basis .18s}
body.msgrail-collapsed .msgrail{flex-basis:var(--rail-collapsed);width:var(--rail-collapsed)}
.msgrail-toggle{position:absolute;top:14px;left:-13px;z-index:61;width:26px;height:26px;border-radius:50%;
  border:1px solid var(--grid);background:var(--paper);color:var(--text);cursor:pointer;font-size:13px;display:grid;place-items:center}
.mr-icons{display:flex;flex-direction:column;align-items:center;gap:7px;padding:50px 0 12px}
.mr-ico{position:relative;width:38px;height:38px;border-radius:9px;border:1px solid var(--grid);background:var(--warm-2);
  color:var(--text-soft);display:grid;place-items:center;cursor:pointer;font-size:18px}
.mr-ico:hover{border-color:var(--accent);color:var(--accent)}
.mr-ico.mr-ico-head{background:#25D366;color:#08210F;border-color:#25D366;cursor:default}
.mr-ico.mr-ico-send{background:#25D366;color:#08210F;border-color:#25D366}
.mr-badge{position:absolute;top:-5px;right:-5px;background:var(--accent);color:#fff;font-size:9.5px;font-weight:700;
  border-radius:999px;min-width:16px;height:16px;display:grid;place-items:center;padding:0 4px}
.mr-panel{display:flex;flex-direction:column;min-height:0;flex:1}
.mr-head{padding:14px 16px 10px;border-bottom:1px solid var(--grid)}
.mr-head h2{font-family:var(--font-serif);font-size:17px;margin:0;display:flex;align-items:center;gap:7px}
.mr-head h2::before{content:"";width:9px;height:9px;border-radius:50%;background:#25D366}
.mr-sub{font-size:12px;color:var(--text-muted);margin-top:2px}
.mr-body{flex:1;overflow-y:auto;padding:12px 14px}
.mr-card{border:1px solid var(--grid);border-radius:10px;padding:10px 11px;margin-bottom:9px;background:var(--warm-2)}
.mr-h{font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-weight:700;margin:0 0 7px}
.mr-health .wahb-metrics{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:6px}
.wahb-chip{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 8px;border-radius:999px;border:1px solid}
.wahb-chip .wahb-dot{width:7px;height:7px;border-radius:50%}
.wahb-chip.ok{background:var(--status-good-bg);color:var(--status-good);border-color:transparent}
.wahb-chip.ok .wahb-dot{background:var(--status-good)}
.wahb-chip.warn{background:var(--status-mora1-bg);color:var(--status-mora1);border-color:transparent}
.wahb-chip b{font-weight:800}
.wahb-more{background:transparent;border:0;color:var(--accent-dark);font-size:11px;font-weight:600;cursor:pointer;padding:3px 0}
.mr-universe{margin:2px 0 8px}
.uni-one{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--grid);border-radius:8px;padding:7px 9px}
.uni-nm{font-weight:700;font-size:13px;color:var(--text)}
.uni-meta{font-size:11px;color:var(--text-muted)}
.uni-bulk{display:flex;flex-direction:column;gap:3px}
.uni-filter{font-size:11px;font-weight:700;color:var(--accent-dark);background:rgba(44,140,153,.10);border-radius:6px;padding:2px 7px;align-self:flex-start}
.uni-names{font-size:11px;color:var(--text-muted)}
.uni-empty{font-size:11px;color:var(--text-muted);font-style:italic}
.mr-recip{font-size:13px;margin:2px 0}
.mr-recip b{font-size:16px;color:var(--accent-dark);font-family:var(--font-mono)}
.mr-scope{font-size:11px;color:var(--text-muted)}
.mr-allbtn{appearance:none;border:1px dashed var(--grid-strong);background:none;width:100%;margin:6px 0;padding:6px;
  border-radius:7px;font:inherit;font-size:11.5px;color:var(--accent-dark);cursor:pointer}
.mr-allbtn:hover{border-color:var(--accent);background:var(--paper)}
.mr-breakdown{margin-top:4px}
.mr-row{display:flex;justify-content:space-between;font-size:12px;padding:2px 0}
.mr-row .v{font-weight:700;font-family:var(--font-mono)}
.mr-row.ok .v{color:var(--status-good)}
.mr-row.mut .v{color:var(--text-muted)}
.mr-seg{display:flex;border:1px solid var(--grid-strong);border-radius:8px;overflow:hidden}
.mr-segb{flex:1;appearance:none;border:0;background:var(--paper);color:var(--text-soft);font:inherit;font-size:12px;font-weight:700;padding:8px;cursor:pointer}
.mr-segb.active{background:var(--accent);color:#fff}
.mr-segb+.mr-segb{border-left:1px solid var(--grid-strong)}
.mr-typenote{font-size:10.5px;color:var(--text-muted);margin-top:6px}
.mr-tpl{width:100%;border:1px solid var(--grid-strong);border-radius:8px;padding:8px;font:inherit;font-size:12.5px;background:var(--paper);color:var(--text)}
.mr-draft{width:100%;border:1px solid var(--grid-strong);border-radius:8px;padding:9px;font:inherit;font-size:12.5px;
  min-height:82px;background:var(--paper);color:var(--text);resize:vertical}
.mr-paylink{display:flex;align-items:center;gap:7px;font-size:12px;margin-top:7px;cursor:pointer}
.mr-radio{display:flex;align-items:center;gap:7px;font-size:12.5px;padding:3px 0;cursor:pointer}
.mr-when-input{width:100%;margin-top:6px;border:1px solid var(--grid-strong);border-radius:7px;padding:6px;font:inherit;background:var(--paper);color:var(--text)}
.mr-foot{border-top:1px solid var(--grid);padding:11px 14px;background:var(--paper)}
.mr-cost{font-size:11.5px;color:var(--text-muted);margin-bottom:8px}
.mr-free{color:var(--status-good)}
.mr-send{width:100%;appearance:none;border:0;border-radius:10px;background:#25D366;color:#08210F;font:inherit;font-size:14px;font-weight:800;padding:11px;cursor:pointer}
.mr-send:hover{filter:brightness(1.05)}
.mr-send[disabled]{opacity:.5;cursor:not-allowed}
.mr-note{font-size:10px;color:var(--text-muted);text-align:center;margin-top:7px}

/* ---------- FAB ---------- */
.fab-register{position:fixed;bottom:28px;right:354px;z-index:8000;background:var(--accent);color:#fff;border:0;border-radius:32px;
  padding:15px 22px 15px 18px;display:flex;align-items:center;gap:12px;font-family:inherit;font-weight:600;font-size:14px;
  box-shadow:0 10px 28px rgba(44,140,153,.42),0 3px 8px rgba(0,0,0,.16);cursor:pointer;transition:transform .15s,box-shadow .15s,background-color .15s}
body.msgrail-collapsed .fab-register{right:82px}
.fab-register:hover{background:var(--accent-dark);transform:translateY(-2px);box-shadow:0 14px 32px rgba(44,140,153,.5),0 4px 10px rgba(0,0,0,.2)}
.fab-register .fab-plus{width:24px;height:24px;border-radius:50%;background:rgba(255,255,255,.22);display:grid;place-items:center;font-size:17px;font-weight:700;line-height:1}

/* ---------- REGISTER MODAL ---------- */
.rz-modal-backdrop{position:fixed;inset:0;background:rgba(10,14,26,.42);backdrop-filter:blur(2px);z-index:10000;display:grid;place-items:center;padding:24px}
.rz-modal{width:440px;max-width:96vw;background:var(--paper);border-radius:16px;box-shadow:0 24px 60px rgba(0,0,0,.32);overflow:hidden}
.rz-modal-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:20px 22px 14px;border-bottom:1px solid var(--grid)}
.rz-modal-eyebrow{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);font-weight:700}
.rz-modal-title{font-family:var(--font-serif);font-size:19px;margin:4px 0 2px;color:var(--text)}
.rz-modal-sub{font-size:12.5px;color:var(--text-muted)}
.rz-modal-x{background:transparent;border:0;font-size:26px;line-height:1;color:var(--text-muted);cursor:pointer}
.rz-modal-body{padding:18px 22px 22px}
.rz-invoice{background:var(--warm-2);border:1px solid var(--grid);border-radius:12px;padding:12px 14px;margin-bottom:18px}
.rz-inv-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0}
.rz-inv-row .label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-weight:700}
.rz-chip-sel{background:var(--accent);color:#fff;border-radius:999px;padding:3px 11px;font-size:12px;font-weight:600}
.rz-amount{font-size:18px;font-weight:700;color:var(--text)}
.rz-amount small{font-size:11px;color:var(--text-muted);font-weight:600}
.rz-trace{font-size:12px;color:var(--text-soft)}
.rz-method-h{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-weight:700;margin-bottom:10px}
.rz-methods{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.method-btn{position:relative;display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 8px;border-radius:12px;
  border:1.5px solid var(--grid-strong);background:var(--paper);cursor:pointer;font-family:inherit;font-size:12.5px;font-weight:600;color:var(--text);transition:border-color .12s,transform .08s}
.method-btn:hover:not(:disabled){border-color:var(--accent);transform:translateY(-2px)}
.method-btn:disabled{opacity:.5;cursor:not-allowed}
.method-btn .ico{font-size:24px}
.method-btn.cash .ico{color:var(--cash-color)}
.method-btn.transfer .ico{color:var(--transfer-color)}
.method-btn.card .ico{color:var(--card-color)}
.soon-badge{position:absolute;top:6px;right:6px;font-size:8.5px;text-transform:uppercase;letter-spacing:.04em;background:var(--warm-2);color:var(--text-muted);padding:1px 5px;border-radius:999px;font-weight:700}
.rz-modal-note{font-size:11.5px;color:var(--text-muted);margin:14px 0 0;text-align:center}

/* ---------- TOAST ---------- */
.rz-toast{position:fixed;bottom:96px;left:50%;transform:translateX(-50%);z-index:11000;display:flex;align-items:center;gap:8px;
  background:var(--primary);color:#fff;padding:11px 18px;border-radius:10px;font-size:13px;font-weight:600;
  box-shadow:0 10px 30px rgba(0,0,0,.28);animation:toastIn .2s ease}
.rz-toast svg{color:#86EFAC;font-size:16px}
.rz-toast.warn svg{color:#FCD34D}
@keyframes toastIn{from{opacity:0;transform:transl(-50%,8px)}to{opacity:1}}
@keyframes toastIn{from{opacity:0;transform:translateX(-50%) translateY(8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* dark-mode band tints */
:root[data-theme="dark"] table.libro thead tr.band-row .band-pay{background:#1A2433}
:root[data-theme="dark"] table.libro thead tr.band-row .band-paid{background:#16241B}
:root[data-theme="dark"] table.libro thead tr.band-row .band-saldo{background:#2A1B1B}
:root[data-theme="dark"] td.money.paid{color:#86EFAC}
:root[data-theme="dark"] td.money.mora{color:#FCA5A5}
:root[data-theme="dark"] .pill.good{color:#86EFAC}
:root[data-theme="dark"] .pill.mora1{color:#FCD34D}
:root[data-theme="dark"] .pill.mora2{color:#FCA5A5}
:root[data-theme="dark"] .pill.pagado{color:#93C5FD}
:root[data-theme="dark"] th.current-month{background:#92400E;color:#FCD34D}
:root[data-theme="dark"] .col-acc .action-wa{color:#86EFAC}
