:root{--bg:#0a0c0f;--bg2:#111318;--bg3:#181c23;--bg4:#1f2430;--border:#252b38;--border2:#2e3545;--text:#e8ecf4;--text2:#8b95a8;--text3:#505a6e;--green:#00e5a0;--green-dim:#00e5a015;--green-mid:#00e5a030;--yellow:#f5c842;--yellow-dim:#f5c84215;--red:#ff4d6d;--red-dim:#ff4d6d15;--blue:#4d9fff;--blue-dim:#4d9fff15;--orange:#fb923c;--orange-dim:#fb923c15;--purple:#a78bfa;--radius:12px;--radius-sm:8px;--font-display:"DM Sans",sans-serif;--font-mono:"DM Mono",monospace;--font-body:"DM Sans",sans-serif}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font-body);min-height:100vh;font-size:14px;line-height:1.5}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg2)}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}button{cursor:pointer;font-family:var(--font-body)}input,select,textarea{font-family:var(--font-body)}.app{min-height:100vh;display:flex}.main{flex-direction:column;flex:1;margin-left:220px;display:flex}.sidebar{background:var(--bg2);border-right:1px solid var(--border);z-index:100;flex-direction:column;width:220px;min-height:100vh;padding:24px 0;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.sidebar-logo{border-bottom:1px solid var(--border);margin-bottom:16px;padding:0 20px 24px}.sidebar-logo .logo-mark{color:var(--green);letter-spacing:-.3px;font-size:18px;font-weight:700}.sidebar-logo .logo-sub{color:var(--text3);font-size:11px;font-family:var(--font-mono);margin-top:2px}.nav-section{margin-bottom:8px;padding:0 12px}.nav-label{font-size:10px;font-family:var(--font-mono);color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px;padding:0 8px}.nav-item{border-radius:var(--radius-sm);cursor:pointer;color:var(--text2);text-align:left;background:0 0;border:1px solid #0000;align-items:center;gap:10px;width:100%;margin-bottom:2px;padding:9px 12px;font-size:13.5px;font-weight:500;transition:all .15s;display:flex}.nav-item:hover{background:var(--bg3);color:var(--text)}.nav-item.active{background:var(--green-dim);color:var(--green);border-color:var(--green-mid)}.nav-icon{text-align:center;width:20px;font-size:16px}.sidebar-bottom{border-top:1px solid var(--border);margin-top:auto;padding:16px 20px 0}.auth-status{color:var(--text3);align-items:center;gap:8px;margin-bottom:8px;font-size:12px;display:flex}.auth-dot{background:var(--red);border-radius:50%;flex-shrink:0;width:6px;height:6px}.auth-dot.connected{background:var(--green)}.tasa-widget{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);margin:12px 0;padding:10px 12px}.tasa-label{font-size:10px;font-family:var(--font-mono);color:var(--text3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px}.tasa-value{color:var(--yellow);font-size:16px;font-weight:700;font-family:var(--font-mono)}.tasa-sub{color:var(--text3);font-size:10px;font-family:var(--font-mono);margin-top:2px}.topbar{background:var(--bg2);border-bottom:1px solid var(--border);z-index:50;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:12px 28px;display:flex;position:sticky;top:0}.topbar-left{flex-wrap:wrap;align-items:center;gap:14px;display:flex}.page-title{color:var(--text);font-size:16px;font-weight:600}.topbar-right{align-items:center;gap:8px;display:flex}.month-selector{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);flex-wrap:wrap;align-items:center;gap:3px;padding:3px;display:flex}.month-btn{color:var(--text2);cursor:pointer;font-family:var(--font-mono);background:0 0;border:none;border-radius:6px;padding:4px 11px;font-size:11.5px;font-weight:500;transition:all .15s;position:relative}.month-btn:hover{color:var(--text);background:var(--bg4)}.month-btn.active{background:var(--green);color:#000;font-weight:600}.month-btn.has-v2:after{content:"";background:var(--yellow);border-radius:50%;width:4px;height:4px;position:absolute;top:2px;right:2px}.version-toggle{background:var(--yellow-dim);border:1px solid var(--yellow);border-radius:var(--radius-sm);cursor:pointer;color:var(--yellow);font-size:12px;font-family:var(--font-mono);align-items:center;gap:6px;padding:5px 12px;display:none}.version-toggle.visible{display:flex}.btn-primary{background:var(--green);color:#000;border-radius:var(--radius-sm);font-family:var(--font-display);cursor:pointer;border:none;align-items:center;gap:6px;padding:7px 16px;font-size:13px;font-weight:600;transition:opacity .15s;display:inline-flex}.btn-primary:hover{opacity:.85}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-secondary{background:var(--bg3);color:var(--text2);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:6px;padding:7px 14px;font-size:13px;transition:all .15s;display:inline-flex}.btn-secondary:hover{border-color:var(--border2);color:var(--text)}.content{flex:1;padding:24px 28px}.kpi-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.kpi-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;transition:border-color .2s;position:relative;overflow:hidden}.kpi-card:hover{border-color:var(--border2)}.kpi-card:before{content:"";height:2px;position:absolute;top:0;left:0;right:0}.kpi-card.green:before{background:var(--green)}.kpi-card.yellow:before{background:var(--yellow)}.kpi-card.red:before{background:var(--red)}.kpi-card.blue:before{background:var(--blue)}.kpi-label{font-size:11px;font-family:var(--font-mono);color:var(--text3);text-transform:uppercase;letter-spacing:.8px;justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.kpi-value{margin-bottom:5px;font-size:22px;font-weight:700;line-height:1.15}.kpi-card.green .kpi-value{color:var(--green)}.kpi-card.yellow .kpi-value{color:var(--yellow)}.kpi-card.red .kpi-value{color:var(--red)}.kpi-card.blue .kpi-value{color:var(--blue)}.kpi-sub{color:var(--text3);font-size:12px;font-family:var(--font-mono)}.charts-grid{grid-template-columns:2fr 1fr;gap:16px;margin-bottom:24px;display:grid}.charts-row2{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px;display:grid}.chart-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.chart-header{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.chart-title{color:var(--text);font-size:14px;font-weight:600}.chart-subtitle{color:var(--text3);font-size:11px;font-family:var(--font-mono);margin-top:2px}.chart-wrap{height:200px;position:relative}.table-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:20px;overflow:hidden}.table-header{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:14px 20px;display:flex}.table-title{font-size:14px;font-weight:600}.table-controls{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.search-input{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);outline:none;width:180px;padding:6px 12px;font-size:13px;transition:border-color .15s}.search-input:focus{border-color:var(--green)}.search-input::placeholder{color:var(--text3)}.filter-select{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font-mono);cursor:pointer;outline:none;padding:6px 10px;font-size:12px}table{border-collapse:collapse;width:100%}th{background:var(--bg3);text-align:left;font-family:var(--font-mono);color:var(--text3);text-transform:uppercase;letter-spacing:.8px;border-bottom:1px solid var(--border);white-space:nowrap;padding:9px 16px;font-size:11px}td{border-bottom:1px solid var(--border);vertical-align:middle;padding:10px 16px;font-size:13.5px}tr:last-child td{border-bottom:none}tr:hover td{background:var(--bg3)}.amount-cell{font-family:var(--font-mono);font-weight:500}.amount-negative{color:var(--red)}.amount-positive{color:var(--green)}.status-badge{font-size:11px;font-family:var(--font-mono);white-space:nowrap;border-radius:20px;align-items:center;gap:4px;padding:2px 8px;font-weight:500;display:inline-flex}.status-pagado{background:var(--green-dim);color:var(--green);border:1px solid var(--green-mid)}.status-pendiente{background:var(--yellow-dim);color:var(--yellow);border:1px solid #f5c84230}.status-aplazado{background:var(--blue-dim);color:var(--blue);border:1px solid #4d9fff30}.status-finaliza{background:var(--red-dim);color:var(--red);border:1px solid #ff4d6d30}.status-pagado50{background:var(--orange-dim);color:var(--orange);border:1px solid #fb923c30}.status-none{background:var(--bg3);color:var(--text3);border:1px solid var(--border)}.action-btns{gap:6px;display:flex}.btn-icon{border:1px solid var(--border);background:var(--bg3);width:28px;height:28px;color:var(--text3);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;font-size:13px;transition:all .15s;display:flex}.btn-icon:hover{border-color:var(--border2);color:var(--text)}.btn-icon.edit:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-dim)}.btn-icon.delete:hover{border-color:var(--red);color:var(--red);background:var(--red-dim)}.btn-icon.nota:hover{border-color:var(--purple);color:var(--purple);background:#a78bfa15}.modal-overlay{z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:16px;width:480px;max-width:95vw;max-height:90vh;padding:26px;animation:.18s modalIn;overflow-y:auto}@keyframes modalIn{0%{opacity:0;transform:translateY(10px)scale(.97)}to{opacity:1;transform:none}}.modal-title{justify-content:space-between;align-items:center;margin-bottom:20px;font-size:17px;font-weight:700;display:flex}.modal-close{border:1px solid var(--border);width:28px;height:28px;color:var(--text3);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;font-size:16px;transition:all .15s;display:flex}.modal-close:hover{color:var(--text);border-color:var(--border2)}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;margin-top:20px;padding-top:14px;display:flex}.form-group{margin-bottom:14px}.form-label{font-size:11px;font-family:var(--font-mono);color:var(--text3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px;display:block}.form-input,.form-select{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);outline:none;padding:9px 12px;font-size:14px;transition:border-color .15s}.form-input:focus,.form-select:focus{border-color:var(--green)}.form-select option{background:var(--bg3)}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.toast-container{z-index:300;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.toast{background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius-sm);align-items:center;gap:8px;min-width:240px;padding:11px 16px;font-size:13px;animation:.2s toastIn;display:flex;box-shadow:0 8px 24px #0006}.toast.success{border-left:3px solid var(--green)}.toast.error{border-left:3px solid var(--red)}.toast.loading{border-left:3px solid var(--yellow)}@keyframes toastIn{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:none}}.spinner{border:2px solid var(--border2);border-top-color:var(--green);vertical-align:middle;border-radius:50%;width:14px;height:14px;margin-right:6px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.loading-cell{text-align:center;color:var(--text3);font-family:var(--font-mono);padding:32px;font-size:13px}.empty-state{text-align:center;color:var(--text3);font-family:var(--font-mono);padding:40px 24px;font-size:13px}.empty-icon{margin-bottom:10px;font-size:28px}.nota-text{color:var(--text3);white-space:nowrap;text-overflow:ellipsis;max-width:180px;font-size:12px;font-style:italic;overflow:hidden}.nota-cell{max-width:200px}.deuda-grid{grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:16px;margin-bottom:20px;display:grid}.deuda-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:18px}.deuda-name{margin-bottom:12px;font-size:14px;font-weight:600}.deuda-row{justify-content:space-between;align-items:center;margin-bottom:7px;display:flex}.deuda-key{font-size:11px;font-family:var(--font-mono);color:var(--text3);text-transform:uppercase}.deuda-val{font-family:var(--font-mono);font-size:13px;font-weight:500}.progress-bar{background:var(--bg4);border-radius:2px;height:4px;margin-top:12px;overflow:hidden}.progress-fill{background:var(--green);border-radius:2px;height:100%;transition:width .5s}.cobrar-summary{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px;display:grid}.summary-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px}.summary-label{font-size:11px;font-family:var(--font-mono);color:var(--text3);text-transform:uppercase;margin-bottom:8px}.summary-val{color:var(--yellow);font-size:20px;font-weight:700}.historial-campo{font-family:var(--font-mono);color:var(--blue);background:var(--blue-dim);border-radius:4px;padding:1px 6px;font-size:11px}.historial-before{color:var(--text3);font-family:var(--font-mono);font-size:12px}.historial-after{color:var(--green);font-family:var(--font-mono);font-size:12px;font-weight:500}.historial-date{font-family:var(--font-mono);color:var(--text3);white-space:nowrap;font-size:11px}.search-group{margin-bottom:16px}.search-group-title{font-size:11px;font-family:var(--font-mono);color:var(--text3);text-transform:uppercase;letter-spacing:.8px;border-bottom:1px solid var(--border);margin-bottom:8px;padding:6px 0}.search-result-item{border-radius:var(--radius-sm);cursor:pointer;justify-content:space-between;align-items:center;gap:12px;padding:8px 10px;transition:background .12s;display:flex}.search-result-item:hover{background:var(--bg3)}.search-result-name{flex:1;font-size:13px;font-weight:500}.search-result-val{font-family:var(--font-mono);color:var(--red);font-size:12px}.ppto-bar-wrap{border-bottom:1px solid var(--border);flex-direction:column;gap:6px;padding:12px 0;display:flex}.ppto-bar-wrap:last-child{border-bottom:none}.ppto-bar-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.ppto-bar-name{align-items:center;gap:8px;font-size:13px;font-weight:500;display:flex}.ppto-bar-amounts{font-family:var(--font-mono);color:var(--text3);font-size:12px}.ppto-bar-track{background:var(--bg4);border-radius:4px;height:8px;overflow:hidden}.ppto-bar-fill{border-radius:4px;height:100%;transition:width .6s}.ppto-bar-ok{background:var(--green)}.ppto-bar-warn{background:var(--yellow)}.ppto-bar-over{background:var(--red);animation:1.5s infinite pulse-red}@keyframes pulse-red{0%,to{opacity:1}50%{opacity:.6}}.ppto-bar-footer{justify-content:space-between;align-items:center;margin-top:2px;display:flex}.ppto-pct{font-family:var(--font-mono);font-size:11px;font-weight:600}.ppto-pct.ok{color:var(--green)}.ppto-pct.warn{color:var(--yellow)}.ppto-pct.over{color:var(--red)}.cat-swatch{border:1px solid #ffffff1a;border-radius:6px;flex-shrink:0;width:20px;height:20px;display:inline-block}.cat-legend-item{align-items:center;gap:10px;display:flex}.cat-legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.cat-legend-name{color:var(--text2);flex:1;font-size:12px}.cat-legend-val{font-family:var(--font-mono);color:var(--text3);font-size:12px}.comp-check-wrap{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-size:12px;font-family:var(--font-mono);-webkit-user-select:none;user-select:none;align-items:center;gap:6px;padding:5px 12px;transition:all .15s;display:flex}.comp-check-wrap:hover{border-color:var(--border2)}.comp-check-wrap.selected{border-color:var(--green);color:var(--green);background:var(--green-dim)}.auth-screen{text-align:center;background:var(--bg);flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100vh;display:flex}.auth-logo{color:var(--green);margin-bottom:4px;font-size:40px;font-weight:700}.auth-desc{color:var(--text2);max-width:360px;line-height:1.6}.signin-btn{background:var(--green);color:#000;border-radius:var(--radius-sm);font-family:var(--font-display);cursor:pointer;border:none;align-items:center;gap:8px;margin-top:8px;padding:11px 28px;font-size:14px;font-weight:600;transition:opacity .15s;display:inline-flex}.signin-btn:hover{opacity:.85}@media print{.sidebar,.topbar,.action-btns,.table-controls,.btn-primary,.btn-secondary,.version-toggle{display:none!important}.main{margin-left:0!important}body{font-size:12px;color:#000!important;background:#fff!important}.content{padding:16px!important}.kpi-grid{grid-template-columns:repeat(4,1fr)!important}.kpi-card{background:#f9f9f9!important;border:1px solid #ddd!important}.kpi-value,.kpi-label,.kpi-sub{color:#333!important}table{border-collapse:collapse!important}th,td{color:#000!important;background:#fff!important;border:1px solid #ddd!important;padding:6px 10px!important}th{background:#f0f0f0!important}@page{margin:1cm}}@media (width<=900px){.sidebar{display:none}.main{margin-left:0}.kpi-grid{grid-template-columns:repeat(2,1fr)}.charts-grid,.charts-row2{grid-template-columns:1fr}.cobrar-summary{grid-template-columns:1fr 1fr}}
