:root{--bg:#0d1321;--bg2:#111827;--bg3:#1a2540;--border:#1e2d45;--accent:#2563eb;--accent2:#1d4ed8;--text:#e2eaf6;--text2:#94a3b8;--muted:#64748b;--danger:#ef4444;--success:#22c55e;--warning:#f59e0b;--font:"Segoe UI",system-ui,sans-serif;--shadow:0 4px 20px rgba(0,0,0,.4);--input-placeholder:#475569}[data-theme=light]{--bg:#f5f8ff;--bg2:#fff;--bg3:#eef3fc;--border:#c8d9f0;--accent:#1d4ed8;--accent2:#1e40af;--text:#0d1b2e;--text2:#334155;--muted:#64748b;--danger:#dc2626;--success:#16a34a;--warning:#b45309;--shadow:0 4px 20px rgba(0,0,0,.1);--input-placeholder:#94a3b8}*{box-sizing:border-box;margin:0;padding:0}body,html{height:100%}body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:14px;transition:background .2s,color .2s}.header{background:var(--bg2);border-bottom:1px solid var(--border);padding:1rem 1.5rem;justify-content:space-between;gap:1rem;flex-wrap:wrap;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header,.logo{display:flex;align-items:center}.logo{gap:10px}.logo-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.logo h1{font-size:17px;font-weight:600;color:var(--text)}.logo p{font-size:12px;color:var(--muted)}.header-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:7px;border:none;cursor:pointer;font-size:13px;font-weight:500;transition:all .15s;font-family:var(--font)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent2)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{filter:brightness(.9)}.btn-ghost{background:transparent;color:var(--text2);border:1px solid var(--border)}.btn-ghost:hover{background:var(--bg3);color:var(--text)}.toolbar{background:var(--bg2);padding:.75rem 1.5rem;display:flex;gap:10px;align-items:center;border-bottom:1px solid var(--border);flex-wrap:wrap}.search-wrap{position:relative;flex:1 1;min-width:200px;max-width:400px}.search-wrap svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}.search-wrap input{padding-left:34px}input,select,textarea{background:var(--bg3);border:1px solid var(--border);color:var(--text);border-radius:7px;padding:7px 12px;font-size:13px;outline:none;transition:border-color .15s,background .2s,color .2s;width:100%;font-family:var(--font)}input::placeholder,textarea::placeholder{color:var(--input-placeholder)}input:focus,select:focus,textarea:focus{border-color:var(--accent)}select option{color:var(--text)}.stats,select option{background:var(--bg2)}.stats{display:flex;gap:1rem;padding:.75rem 1.5rem;border-bottom:1px solid var(--border)}.stat-val{font-size:20px;font-weight:700;color:var(--accent)}.stat-lbl{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.table-wrap{overflow:auto;height:calc(100vh - var(--fixed-bars-h, 220px))}.table-wrap table{min-width:900px;width:100%;border-collapse:collapse}thead th{background:var(--bg2);padding:10px 12px;text-align:left;font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);position:-webkit-sticky;position:sticky;top:0;z-index:10;white-space:nowrap;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}thead th:hover{color:var(--text)}.sort-arrow{margin-left:4px;opacity:.4}th.sorted .sort-arrow{opacity:1;color:var(--accent)}tbody tr{border-bottom:1px solid var(--border);transition:background .1s;cursor:pointer}tbody tr:hover{background:var(--bg3)}tbody tr.selected{background:rgba(37,99,235,.1)}tbody td{padding:9px 12px;vertical-align:middle;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text);transition:background .3s}td.usuario{font-weight:600;color:var(--accent)}td.notas{color:var(--muted);font-size:12px}.mac-tag{display:inline-block;background:var(--bg3);border:1px solid var(--border);border-radius:4px;padding:2px 7px;font-size:11px;font-family:monospace;color:var(--text2);margin:1px}.mac-empty{color:var(--muted);font-size:11px}.estado-select{background:transparent;border:none;cursor:pointer;font-size:11px;font-weight:600;border-radius:20px;padding:3px 8px;outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none}.estado-select.cobrado{background:rgba(34,197,94,.15);color:var(--success);border:1px solid rgba(34,197,94,.3)}.estado-select.pendiente{background:rgba(245,158,11,.15);color:var(--warning);border:1px solid rgba(245,158,11,.3)}.estado-select.caducado{background:rgba(239,68,68,.15);color:var(--danger);border:1px solid rgba(239,68,68,.3)}.estado-select option{background:var(--bg2);color:var(--text)}@keyframes flashGreen{0%,to{background:transparent}30%{background:rgba(34,197,94,.2)}}@keyframes flashAmber{0%,to{background:transparent}30%{background:rgba(245,158,11,.2)}}@keyframes flashRed{0%,to{background:transparent}30%{background:rgba(239,68,68,.2)}}.flash-green{animation:flashGreen .7s ease}.flash-amber{animation:flashAmber .7s ease}.flash-red{animation:flashRed .7s ease}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}.badge-cobrado{background:rgba(34,197,94,.15);color:var(--success);border:1px solid rgba(34,197,94,.3)}.badge-pendiente{background:rgba(245,158,11,.15);color:var(--warning);border:1px solid rgba(245,158,11,.3)}.badge-caducado{background:rgba(239,68,68,.15);color:var(--danger);border:1px solid rgba(239,68,68,.3)}.filter-btns{display:flex;gap:4px}.fbtn{padding:5px 12px;border-radius:6px;border:1px solid var(--border);background:var(--bg3);color:var(--muted);cursor:pointer;font-size:12px;font-weight:500;transition:all .15s;white-space:nowrap;font-family:var(--font)}.fbtn:hover{color:var(--text);border-color:var(--accent)}.fbtn.active-all{background:var(--accent);border-color:var(--accent);color:#fff}.fbtn.active-cob{background:rgba(34,197,94,.15);border-color:rgba(34,197,94,.4);color:var(--success)}.fbtn.active-pen{background:rgba(245,158,11,.15);border-color:rgba(245,158,11,.4);color:var(--warning)}.fbtn.active-cad{background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.4);color:var(--danger)}.actions-cell{display:flex;gap:6px;align-items:center}.icon-btn{background:none;border:none;cursor:pointer;padding:5px;border-radius:5px;display:inline-flex;align-items:center;color:var(--muted);transition:all .15s}.btn-wa{background:#25d366;color:#fff}.btn-wa:hover{background:#1da851}.icon-btn.wa:hover{color:#25d366;background:rgba(37,211,102,.1)}.icon-btn.edit:hover{color:var(--accent);background:rgba(37,99,235,.1)}.icon-btn.del:hover{color:var(--danger);background:rgba(239,68,68,.1)}.pagination{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;border-top:1px solid var(--border);flex-wrap:wrap;gap:8px;background:var(--bg2)}.pag-info{color:var(--muted);font-size:13px}.pag-btns{display:flex;gap:4px}.pag-btn{padding:5px 10px;border-radius:6px;border:1px solid var(--border);background:var(--bg2);color:var(--text);cursor:pointer;font-size:13px;transition:all .15s;font-family:var(--font)}.pag-btn:hover:not(:disabled){background:var(--bg3)}.pag-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.pag-btn:disabled{opacity:.3;cursor:default}.bulk-bar{background:rgba(37,99,235,.1);border:1px solid rgba(37,99,235,.3);border-radius:8px;padding:8px 16px;display:flex;align-items:center;gap:12px;font-size:13px;color:var(--text)}.bulk-bar span{color:var(--accent);font-weight:600}.bulk-wrap{padding:.5rem 1.5rem;background:var(--bg2);border-bottom:1px solid var(--border)}.export-dropdown{position:relative}.dropdown-menu{position:absolute;top:calc(100% + 6px);right:0;background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:4px;min-width:200px;z-index:200;box-shadow:var(--shadow)}.dropdown-item{display:block;padding:8px 12px;border-radius:5px;cursor:pointer;font-size:13px;color:var(--text)}.dropdown-item:hover{background:var(--bg3)}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:999;display:flex;align-items:center;justify-content:center}.modal{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:1.5rem;width:520px;max-width:95vw;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow)}.modal h2{font-size:16px;font-weight:600;margin-bottom:1.25rem;display:flex;align-items:center;gap:8px;color:var(--text)}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:12px;font-weight:500;color:var(--muted);margin-bottom:5px;text-transform:uppercase;letter-spacing:.3px}.form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border)}.view-field{margin-bottom:.9rem}.view-field label{display:block;font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.3px;margin-bottom:4px}.view-val{font-size:14px;color:var(--text);padding:7px 12px;background:var(--bg3);border:1px solid var(--border);border-radius:7px;min-height:34px;word-break:break-all}.view-val.empty{color:var(--muted);font-style:italic}.view-header{gap:10px;margin-bottom:1.25rem}.view-avatar,.view-header{display:flex;align-items:center}.view-avatar{width:42px;height:42px;border-radius:9px;background:rgba(37,99,235,.15);border:1px solid rgba(37,99,235,.3);justify-content:center;font-size:18px;flex-shrink:0}.view-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:0 16px;gap:0 16px}.confirm-modal{max-width:380px;text-align:center}.confirm-modal h2{justify-content:center}.confirm-modal p{color:var(--text2);margin-bottom:1.25rem;font-size:14px}.confirm-btns{display:flex;gap:8px;justify-content:center}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9999;display:flex;flex-direction:column;gap:8px}.toast-item{background:var(--bg2);border:1px solid var(--border);border-radius:8px;padding:10px 16px;font-size:13px;display:flex;align-items:center;gap:8px;box-shadow:var(--shadow);min-width:220px;color:var(--text);animation:slideIn .2s ease}.toast-item.ok{border-left:3px solid var(--success)}.toast-item.err{border-left:3px solid var(--danger)}@keyframes slideIn{0%{transform:translateX(30px);opacity:0}to{transform:translateX(0);opacity:1}}.loading-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:9998;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.loading-overlay p{color:var(--text2);font-size:14px}.empty-state{text-align:center;padding:4rem 2rem;color:var(--muted)}.empty-state p{font-size:15px;margin-top:1rem}input[type=checkbox]{accent-color:var(--accent);width:14px;height:14px;cursor:pointer}select.rows-select{width:auto;padding:6px 10px}.theme-toggle{background:var(--bg3);border:1px solid var(--border);border-radius:20px;padding:5px 12px;display:flex;align-items:center;gap:6px;cursor:pointer;font-size:12px;color:var(--text2);transition:all .15s;font-family:var(--font)}.theme-toggle:hover{border-color:var(--accent);color:var(--text)}@media (max-width:768px){.header{padding:.75rem 1rem}.logo h1{font-size:15px}.logo p{display:none}.header-actions{gap:6px}.btn{padding:6px 10px;font-size:12px}.toolbar{padding:.6rem 1rem;gap:8px}.search-wrap{min-width:0;max-width:100%;width:100%;flex:1 1 100%}.filter-btns{width:100%;overflow-x:auto;padding-bottom:2px;flex-wrap:nowrap}.fbtn{font-size:11px;padding:4px 10px;white-space:nowrap}select.rows-select{display:none}.stats{padding:.5rem 1rem;gap:.75rem}.stat-val{font-size:16px}.pagination,.table-wrap{display:none}.card-list{display:flex;flex-direction:column;gap:10px;padding:.75rem 1rem;overflow-y:auto;height:calc(100vh - var(--mobile-bars-h, 260px))}.client-card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:14px;cursor:pointer;transition:background .15s}.client-card:hover{background:var(--bg3)}.client-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;gap:8px}.client-card-usuario{font-weight:700;color:var(--accent);font-size:15px;flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.client-card-body{display:flex;flex-direction:column;gap:5px}.client-card-row{display:flex;gap:6px;align-items:flex-start;font-size:13px;color:var(--text2)}.client-card-row span:first-child{color:var(--muted);font-size:11px;min-width:60px;text-transform:uppercase;letter-spacing:.3px;padding-top:1px}.client-card-actions{display:flex;gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.client-card-actions .icon-btn{padding:6px 8px;border-radius:7px;border:1px solid var(--border);background:var(--bg3)}.mobile-load-more{text-align:center;padding:1rem;color:var(--muted);font-size:13px}}@media (min-width:769px){.card-list{display:none}}