  *{box-sizing:border-box;margin:0;padding:0}
  :root{
    --ink:#1a1a18;--paper:#f5f2eb;--surface:#fffef9;--muted:#888780;
    --border:rgba(0,0,0,0.12);--border-strong:rgba(0,0,0,0.22);
    --green:#3B6D11;--green-bg:#EAF3DE;--green-text:#27500A;
    --amber:#854F0B;--amber-bg:#FAEEDA;--amber-text:#633806;
    --red:#A32D2D;--red-bg:#FCEBEB;--red-text:#791F1F;
    --blue:#185FA5;--blue-bg:#E6F1FB;--blue-text:#0C447C;
    --purple:#534AB7;--purple-bg:#EEEDFE;--purple-text:#3C3489;
  }
  body.dark{
    --ink:#e8e4dc;--paper:#1a1917;--surface:#222120;--muted:#6b6860;
    --border:rgba(255,255,255,0.09);--border-strong:rgba(255,255,255,0.18);
    --green:#6aaa2a;--green-bg:#1e2e10;--green-text:#8dc957;
    --amber:#d4872a;--amber-bg:#2e1f08;--amber-text:#e8a84a;
    --red:#d95555;--red-bg:#2e1010;--red-text:#e87777;
    --blue:#4a9de8;--blue-bg:#0d1e30;--blue-text:#6db3f2;
    --purple:#8b82e8;--purple-bg:#1a1630;--purple-text:#a89ff2;
  }
  body{font-family:'IBM Plex Mono',monospace;background:var(--paper);color:var(--ink);font-size:13px;min-height:100vh}
  .container{max-width:1280px;margin:0 auto;padding:0 2rem 3rem}

  /* Tabs */
  .tabs-nav{display:flex;gap:0;border-bottom:1px solid var(--border-strong);padding-top:1.75rem}
  .tab-btn{font-family:'IBM Plex Mono',monospace;font-size:12px;padding:9px 22px;border:0.5px solid transparent;border-bottom:none;background:transparent;color:var(--muted);cursor:pointer;border-radius:4px 4px 0 0;position:relative;bottom:-1px;transition:all 0.15s;letter-spacing:0.3px}
  .tab-btn.active{background:var(--surface);border-color:var(--border-strong);border-bottom-color:var(--surface);color:var(--ink);font-weight:500;box-shadow:inset 0 2px 0 var(--ink)}
  .tab-btn:not(.active):hover{color:var(--ink)}
  .tab-panel{display:none;background:var(--surface);border:0.5px solid var(--border-strong);border-top:none;border-radius:0 0 6px 6px;padding:1.5rem 1.5rem 2rem}
  .tab-panel.active{display:block}
  .cfg-sub-btn{font-family:'IBM Plex Mono',monospace;font-size:11px;padding:6px 16px;border:0.5px solid transparent;border-bottom:none;background:transparent;color:var(--muted);cursor:pointer;border-radius:4px 4px 0 0;position:relative;bottom:-1px;transition:all 0.15s}
  .cfg-sub-btn.active{background:var(--paper);border-color:var(--border);border-bottom-color:var(--paper);color:var(--ink);font-weight:500}
  .cfg-sub-btn:not(.active):hover{color:var(--ink)}
  .cfg-panel{display:none}.cfg-panel.active{display:block}

  h1{font-family:Fraunces,serif;font-weight:600;font-size:24px;letter-spacing:-0.5px}
  .panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}
  .panel-header-right{display:flex;gap:8px;align-items:center}

  .btn{font-family:'IBM Plex Mono',monospace;font-size:12px;padding:7px 16px;border:0.5px solid var(--border-strong);background:transparent;color:var(--ink);border-radius:4px;cursor:pointer;transition:background 0.15s}
  .btn:hover{background:rgba(0,0,0,0.06)}
  .btn-primary{background:var(--ink);color:#fff;border-color:var(--ink)}
  .btn-primary:hover{background:#333}

  .stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:1.25rem}
  .stat{background:var(--paper);border:0.5px solid var(--border);border-radius:6px;padding:14px 16px}
  .stat-label{font-size:11px;color:var(--muted);letter-spacing:0.5px;text-transform:uppercase;margin-bottom:6px}
  .stat-val{font-size:20px;font-weight:500;font-family:Fraunces,serif}
  .stat-val.amber{color:var(--amber)}
  .stat-val.red{color:var(--red)}

  .filters{display:flex;gap:8px;margin-bottom:0.75rem;align-items:center;flex-wrap:wrap}
  .filter-tab{font-family:'IBM Plex Mono',monospace;font-size:10px;padding:4px 10px;border:0.5px solid var(--border);border-radius:20px;background:transparent;color:var(--muted);cursor:pointer;transition:all 0.15s}
  .filter-tab.active{border-color:var(--ink);color:var(--ink);background:rgba(0,0,0,0.05);font-weight:500}
  .filter-tab:hover{color:var(--ink)}
  .search-box{margin-left:auto;font-family:'IBM Plex Mono',monospace;font-size:12px;padding:6px 14px;border:0.5px solid var(--border);border-radius:20px;background:var(--paper);color:var(--ink);outline:none;width:200px}
  .search-box:focus{border-color:var(--border-strong)}

  .table-wrap{overflow-x:auto}
  table{width:100%;border-collapse:collapse;margin-top:4px}
  thead tr{border-bottom:1px solid var(--border-strong)}
  th{font-size:11px;text-transform:uppercase;letter-spacing:0.5px;color:var(--muted);padding:9px 10px;text-align:left;font-weight:400}
  td{padding:11px 10px;border-bottom:0.5px solid var(--border);vertical-align:middle}
  tr:last-child td{border-bottom:none}
  tbody tr:hover td{background:rgba(0,0,0,0.02)}

  .badge{display:inline-block;font-size:10px;padding:3px 9px;border-radius:20px;font-weight:500;letter-spacing:0.3px;white-space:nowrap}
  .badge-en-cartera{background:var(--amber-bg);color:var(--amber-text)}
  .badge-depositado{background:var(--blue-bg);color:var(--blue-text)}
  .badge-endosado{background:var(--purple-bg);color:var(--purple-text)}
  .badge-rechazado{background:var(--red-bg);color:var(--red-text)}
  .badge-extraviado{background:#F0F0F0;color:#555}
  .badge-borrado{background:#E0E0E0;color:#444}
  .badge-fisica{background:var(--blue-bg);color:var(--blue-text)}
  .badge-juridica{background:var(--purple-bg);color:var(--purple-text)}

  .amount{font-weight:500;font-family:Fraunces,serif;font-size:14px;text-align:right;white-space:nowrap}
  .text-muted{color:var(--muted)}
  .action-btns{display:flex;gap:4px}
  .action-btn{font-size:10px;padding:3px 9px;border:0.5px solid var(--border);border-radius:3px;background:transparent;cursor:pointer;font-family:'IBM Plex Mono',monospace;color:var(--muted);transition:all 0.12s}
  .action-btn:hover{border-color:var(--border-strong);color:var(--ink);background:rgba(0,0,0,0.04)}
  .empty{text-align:center;padding:3rem;color:var(--muted)}
  .mobile-cards{display:none}
  .cheque-card{background:var(--surface);border:0.5px solid var(--border);border-radius:10px;padding:14px;margin-bottom:10px}
  .cheque-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}
  .cheque-card-num{font-weight:500;font-size:13px;display:flex;gap:6px;align-items:center}
  .cheque-card-importe{font-family:Fraunces,serif;font-size:19px;font-weight:600}
  .cheque-card-mid{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}
  .cheque-card-row{display:flex;justify-content:space-between;font-size:12px;gap:8px}
  .cheque-card-label{color:var(--muted);flex-shrink:0}
  .cheque-card-val{font-weight:500;text-align:right}
  .cheque-card-actions{display:flex;gap:6px;border-top:0.5px solid var(--border);padding-top:10px}
  .cheque-card-btn{flex:1;font-family:'IBM Plex Mono',monospace;font-size:11px;padding:8px 4px;border:0.5px solid var(--border);border-radius:6px;background:transparent;color:var(--muted);cursor:pointer;text-align:center}
  .cheque-card-btn:active{background:rgba(0,0,0,0.06)}
  .cheque-card-btn.danger{color:var(--red);border-color:var(--red-bg)}
  th.sortable{cursor:pointer;user-select:none;white-space:nowrap}
  th.sortable:hover{color:var(--ink)}
  th.sortable::after{content:' ⇕';opacity:0.3;font-size:10px}
  th.sort-asc::after{content:' ↑';opacity:1}
  th.sort-desc::after{content:' ↓';opacity:1}
  .pagination{display:flex;align-items:center;justify-content:space-between;padding:10px 0 0;margin-top:6px;border-top:0.5px solid var(--border);flex-wrap:wrap;gap:8px}
  .pagination-info{font-size:11px;color:var(--muted)}
  .pagination-btns{display:flex;gap:4px;align-items:center}
  .page-btn{font-family:'IBM Plex Mono',monospace;font-size:11px;padding:4px 10px;border:0.5px solid var(--border);border-radius:3px;background:transparent;color:var(--muted);cursor:pointer;transition:all 0.12s;min-width:32px;text-align:center}
  .page-btn:hover:not(:disabled){border-color:var(--border-strong);color:var(--ink);background:rgba(0,0,0,0.04)}
  .page-btn.active{background:var(--ink);color:var(--surface);border-color:var(--ink)}
  .page-btn:disabled{opacity:0.35;cursor:default}
  .page-size-sel{font-family:'IBM Plex Mono',monospace;font-size:11px;padding:4px 8px;border:0.5px solid var(--border);border-radius:3px;background:var(--surface);color:var(--muted);cursor:pointer}
  .date-range{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
  .date-range input[type=date]{font-family:'IBM Plex Mono',monospace;font-size:10px;padding:4px 7px;border:0.5px solid var(--border);border-radius:20px;background:var(--paper);color:var(--ink);outline:none}
  .date-range input[type=date]:focus{border-color:var(--border-strong)}
  .date-range-sep{font-size:11px;color:var(--muted)}
  .hist-entry{display:flex;gap:8px;padding:7px 0;border-bottom:0.5px solid var(--border);font-size:11px;align-items:baseline}
  .hist-entry:last-child{border-bottom:none}
  .hist-date{color:var(--muted);white-space:nowrap;min-width:130px}
  .hist-user{color:var(--blue-text);font-weight:500}
  .hist-msg{flex:1}
  .btn-export{color:var(--red-text);border-color:var(--red-bg);background:var(--red-bg)}
  .btn-export:hover{background:var(--red-bg);filter:brightness(0.93)}
  .btn-import{color:var(--green-text);border-color:var(--green-bg);background:var(--green-bg)}
  .btn-import:hover{background:var(--green-bg);filter:brightness(0.93)}

  .cheque-saved-banner{position:fixed;top:0;left:0;right:0;z-index:9000;background:#2d6a0a;color:#fff;padding:14px 24px;display:flex;align-items:flex-start;justify-content:space-between;gap:16px;box-shadow:0 4px 16px rgba(0,0,0,0.2);transform:translateY(-110%);transition:transform 0.35s cubic-bezier(0.34,1.56,0.64,1);font-family:'IBM Plex Mono',monospace}
  .cheque-saved-banner.show{transform:translateY(0)}
  .cheque-saved-title{font-size:13px;font-weight:600;margin-bottom:4px;letter-spacing:0.3px}
  .cheque-saved-body{font-size:11px;opacity:0.92;line-height:1.7}
  .toast{position:fixed;bottom:2rem;right:2rem;background:var(--ink);color:#fff;font-family:'IBM Plex Mono',monospace;font-size:12px;padding:10px 18px;border-radius:4px;opacity:0;transition:opacity 0.2s;pointer-events:none;z-index:999}
  .toast.show{opacity:1}

  /* Modal */
  .modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.4);z-index:100;align-items:center;justify-content:center}
  .modal-overlay.open{display:flex}
  .modal{background:var(--surface);border:0.5px solid var(--border-strong);border-radius:8px;padding:1.75rem;width:460px;max-width:95vw;box-shadow:0 8px 32px rgba(0,0,0,0.12);max-height:90vh;overflow-y:auto}
  .modal h2{font-family:Fraunces,serif;font-size:20px;margin-bottom:1.25rem}
  .form-row{margin-bottom:13px}
  .form-row label{display:block;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:5px}
  .form-row input,.form-row select{width:100%;font-family:'IBM Plex Mono',monospace;font-size:13px;padding:8px 11px;border:0.5px solid var(--border-strong);border-radius:4px;background:var(--surface);color:var(--ink);outline:none;transition:border-color 0.15s}
  .form-row input:focus,.form-row select:focus{border-color:var(--ink)}
  .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  .modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:1.5rem;padding-top:1rem;border-top:0.5px solid var(--border)}

  /* Select + add button */
  .select-with-add{display:flex;gap:6px}
  .select-with-add select{flex:1;min-width:0}
  .btn-inline-add{font-family:'IBM Plex Mono',monospace;font-size:16px;line-height:1;padding:0 11px;border:0.5px solid var(--border-strong);border-radius:4px;background:transparent;color:var(--muted);cursor:pointer;transition:all 0.15s;flex-shrink:0}
  .btn-inline-add:hover{color:var(--ink);background:rgba(0,0,0,0.05)}

  /* eCheck */
  .check-row{display:flex;align-items:center;gap:10px;padding:8px 0 2px}
  .check-row input[type=checkbox]{width:15px;height:15px;accent-color:var(--ink);cursor:pointer;flex-shrink:0}
  .check-row label{font-size:12px;color:var(--ink);cursor:pointer;user-select:none;margin:0;font-family:'IBM Plex Mono',monospace}
  .badge-echeq{background:#E8F4FD;color:#0969A2;font-size:9px;padding:2px 6px;border-radius:3px;font-weight:600;letter-spacing:0.5px;margin-left:4px;vertical-align:middle}

  /* Confirm */
  .confirm-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.35);z-index:200;align-items:center;justify-content:center}
  .confirm-overlay.open{display:flex}
  .confirm-box{background:var(--surface);border:0.5px solid var(--border-strong);border-radius:8px;padding:1.5rem;width:320px;max-width:90vw}
  .confirm-box p{font-size:14px;margin-bottom:1.25rem;line-height:1.6}
  .confirm-actions{display:flex;justify-content:flex-end;gap:8px}

  /* Pago checklist */
  .pago-check-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-bottom:0.5px solid var(--border);cursor:pointer;transition:background 0.1s}
  .pago-check-item:last-child{border-bottom:none}
  .pago-check-item:hover{background:rgba(0,0,0,0.02)}
  .pago-check-item input[type=checkbox]{width:14px;height:14px;accent-color:var(--ink);cursor:pointer;flex-shrink:0}
  .pago-check-item .pci-num{font-weight:500;font-size:12px;min-width:80px}
  .pago-check-item .pci-lib{color:var(--muted);font-size:11px;flex:1}
  .pago-check-item .pci-imp{font-family:Fraunces,serif;font-size:13px;font-weight:500;white-space:nowrap}
  .pago-check-item .pci-venc{font-size:11px;color:var(--muted);white-space:nowrap;min-width:70px;text-align:right}

  /* Role restrictions */
  body.role-estandar .supervisor-only{display:none!important}

  /* Login screen */
  #loginScreen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--paper)}
  .login-box{background:var(--surface);border:0.5px solid var(--border-strong);border-radius:10px;padding:2.5rem 2.25rem;width:360px;max-width:95vw;box-shadow:0 8px 32px rgba(0,0,0,0.10)}
  .login-box h1{margin-bottom:0.25rem;font-size:22px}
  .login-subtitle{font-size:11px;color:var(--muted);margin-bottom:1.75rem}
  .login-error{font-size:12px;color:var(--red);margin-bottom:10px;min-height:18px}
  .login-box .form-row{margin-bottom:14px}
  .login-box input{width:100%;font-family:'IBM Plex Mono',monospace;font-size:13px;padding:9px 12px;border:0.5px solid var(--border-strong);border-radius:4px;background:var(--surface);color:var(--ink);outline:none}
  .login-box input:focus{border-color:var(--ink)}
  .login-box .btn-primary{width:100%;padding:10px;font-size:13px;margin-top:4px}
  #appWrapper{display:none}
  .topbar{display:flex;align-items:center;justify-content:space-between;padding:0.9rem 2.5rem;background:var(--surface);border-bottom:0.5px solid var(--border-strong)}
  .topbar-appname{font-family:Fraunces,serif;font-size:16px;font-weight:600;letter-spacing:-0.3px}
  .topbar-right{display:flex;align-items:center;gap:12px}
  .topbar-user{font-size:11px;color:var(--muted)}
  .topbar-user strong{color:var(--ink)}
  .badge-supervisor{background:var(--purple-bg);color:var(--purple-text);font-size:9px;padding:2px 7px;border-radius:20px;font-weight:600;letter-spacing:0.3px}
  .badge-estandar{background:var(--blue-bg);color:var(--blue-text);font-size:9px;padding:2px 7px;border-radius:20px;font-weight:600;letter-spacing:0.3px}
  .badge-rol-supervisor{background:var(--purple-bg);color:var(--purple-text)}
  .badge-rol-estandar{background:var(--blue-bg);color:var(--blue-text)}

  @media(max-width:600px){
    .container{padding:0 0 4rem}
    .tabs-nav{padding-top:0;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap;display:flex;border-bottom:1px solid var(--border-strong)}
    .tab-btn{font-size:11px;padding:10px 16px;flex-shrink:0}
    .tab-panel{border-radius:0;border-left:none;border-right:none;padding:1rem 1rem 2rem}
    h1{font-size:19px}
    .panel-header{flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:1rem}
    .panel-header-right{width:100%;display:flex;flex-wrap:wrap;gap:6px}
    .panel-header-right .btn{flex:1;min-width:100px;font-size:11px;padding:8px 6px;text-align:center}
    .panel-header-right span{width:100%;order:-1}
    .stats-row{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:1rem}
    .stat{padding:10px 12px}
    .stat-val{font-size:15px}
    .stat-label{font-size:10px}
    .filters{gap:6px;margin-bottom:0.75rem;flex-wrap:wrap}
    .filter-tab{font-size:11px;padding:6px 12px}
    .search-box{margin-left:0;width:100%;border-radius:8px}
    .date-range{width:100%}
    .date-range input[type=date]{flex:1;font-size:11px}
    .table-wrap table{display:none}
    .mobile-cards{display:block!important}
    .pagination{flex-direction:column;gap:6px;align-items:flex-start}
    .pagination-btns{width:100%;justify-content:center}
    .page-btn{padding:6px 12px;font-size:12px}
    .form-grid{grid-template-columns:1fr}
    .modal{width:100vw!important;max-width:100vw!important;border-radius:16px 16px 0 0!important;position:fixed!important;bottom:0!important;left:0!important;max-height:90vh;overflow-y:auto}
    .modal-overlay.open{align-items:flex-end}
    .modal h2{font-size:17px;margin-bottom:1rem}
    .form-row input,.form-row select{font-size:16px;padding:10px 12px}
    .modal-actions{gap:8px}
    .modal-actions .btn{flex:1;padding:10px;font-size:13px;text-align:center}
    .topbar{padding:0.75rem 1rem}
    .topbar-appname{font-size:14px}
    .topbar-right{gap:8px}
    .topbar-user{display:none}
    .pago-check-item{padding:10px 12px}
    .pago-check-item input[type=checkbox]{width:18px;height:18px}
  }
  .badge-presup-borrador{background:var(--paper);color:var(--muted);border:0.5px solid var(--border)}
  .badge-presup-enviado{background:var(--blue-bg);color:var(--blue-text)}
  .badge-presup-aprobado{background:var(--green-bg);color:var(--green-text)}
  .badge-presup-rechazado{background:var(--red-bg);color:var(--red-text)}
  .badge-factura-emitida{background:var(--green-bg);color:var(--green-text)}
  .dash-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:0.5px solid var(--border);font-size:12px;gap:8px}
  .dash-item:last-child{border-bottom:none}
  .dash-item-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .dash-item-val{font-family:Fraunces,serif;font-size:13px;font-weight:500;white-space:nowrap;flex-shrink:0}
  .dash-empty{font-size:12px;color:var(--muted);padding:12px 0;text-align:center}
  .pi-input{font-family:'IBM Plex Mono',monospace;font-size:12px;padding:5px 8px;border:0.5px solid var(--border);border-radius:3px;background:var(--surface);color:var(--ink);outline:none;width:100%}
  .pi-input:focus{border-color:var(--border-strong)}
  .pi-row td{padding:5px 8px;border-bottom:0.5px solid var(--border);vertical-align:middle}
  .pi-row:last-child td{border-bottom:none}
  @media(max-width:700px){
    #dashStatsRow{grid-template-columns:1fr 1fr!important}
    #dashGrid2,#dashGrid3{grid-template-columns:1fr!important}
  }
