:root{--bg: #0f172a;--bg-card: #1e293b;--bg-elev: #334155;--text: #f1f5f9;--muted: #94a3b8;--primary: #3b82f6;--primary-strong: #2563eb;--green: #22c55e;--red: #ef4444;--yellow: #f59e0b;--border: #334155}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{margin:0;padding:0;height:100%;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;font-size:16px;overscroll-behavior-y:none}button,input,textarea,select{font:inherit;color:inherit}input,textarea,select{width:100%;background:var(--bg-elev);border:1px solid var(--border);border-radius:10px;padding:14px;color:var(--text);outline:none}input:focus,textarea:focus,select:focus{border-color:var(--primary)}button{background:var(--primary);color:#fff;border:none;border-radius:10px;padding:14px 16px;font-weight:600;cursor:pointer;width:100%}button:active{background:var(--primary-strong)}button.secondary{background:var(--bg-elev);color:var(--text)}button.danger{background:var(--red)}button.success{background:var(--green)}button.ghost{background:transparent;color:var(--muted);border:1px solid var(--border)}button:disabled{opacity:.5}.app{max-width:480px;margin:0 auto;min-height:100%;padding-bottom:72px}.header{position:sticky;top:0;z-index:10;background:var(--bg);padding:env(safe-area-inset-top) 16px 12px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}.header h1{font-size:18px;margin:0}.header .sub{font-size:12px;color:var(--muted);margin-top:2px}.tabs{position:fixed;bottom:0;left:0;right:0;background:var(--bg-card);border-top:1px solid var(--border);display:flex;padding-bottom:env(safe-area-inset-bottom);z-index:20}.tabs .tab{flex:1;text-align:center;padding:12px 4px;background:transparent;color:var(--muted);border-radius:0;font-size:12px;font-weight:500}.tabs .tab.active{color:var(--primary)}.tabs .tab .ico{font-size:18px;display:block;margin-bottom:2px}.content{padding:16px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:14px;margin-bottom:12px}.row{display:flex;gap:8px;align-items:center}.row.between{justify-content:space-between}.col{display:flex;flex-direction:column;gap:12px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.field label{font-size:13px;color:var(--muted)}.muted{color:var(--muted)}.small{font-size:13px}.tiny{font-size:12px}.bold{font-weight:700}.amount{font-size:22px;font-weight:700}.badge{display:inline-block;padding:3px 8px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge.pendiente{background:#f59e0b26;color:var(--yellow)}.badge.aprobada{background:#22c55e26;color:var(--green)}.badge.rechazada{background:#ef444426;color:var(--red)}.center{text-align:center}.login-screen{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:24px;max-width:420px;margin:0 auto}.login-screen h1{margin:0 0 6px;font-size:26px}.login-screen p.sub{color:var(--muted);margin:0 0 24px}.toggle{display:flex;background:var(--bg-card);border-radius:12px;padding:4px;margin-bottom:20px}.toggle button{flex:1;background:transparent;color:var(--muted);font-weight:500;padding:10px}.toggle button.active{background:var(--primary);color:#fff}.error-box{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#fecaca;padding:10px 12px;border-radius:10px;font-size:14px;margin-bottom:12px}.success-box{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#bbf7d0;padding:10px 12px;border-radius:10px;font-size:14px;margin-bottom:12px}.fab{position:fixed;right:16px;bottom:calc(72px + env(safe-area-inset-bottom));width:56px;height:56px;border-radius:50%;background:var(--primary);color:#fff;font-size:28px;font-weight:300;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px #3b82f666;cursor:pointer;z-index:15;border:none;padding:0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:flex-end;justify-content:center;z-index:100}.modal{background:var(--bg-card);width:100%;max-width:480px;max-height:90vh;overflow-y:auto;border-radius:18px 18px 0 0;padding:20px;padding-bottom:calc(20px + env(safe-area-inset-bottom))}.modal h2{margin:0 0 14px;font-size:18px}.combo{position:relative}.combo-list{position:absolute;top:100%;left:0;right:0;background:var(--bg-elev);border:1px solid var(--border);border-radius:10px;margin-top:4px;max-height:180px;overflow-y:auto;z-index:5}.combo-item{padding:12px;cursor:pointer;border-bottom:1px solid var(--border)}.combo-item:hover,.combo-item.highlighted{background:var(--bg-card)}.combo-item:last-child{border-bottom:none}.combo-item.new{color:var(--primary);font-style:italic}.message{padding:10px 12px;border-radius:12px;margin-bottom:8px;max-width:85%;font-size:14px;word-wrap:break-word}.message.mine{background:var(--primary);margin-left:auto}.message.theirs{background:var(--bg-elev)}.message .meta{font-size:11px;opacity:.7;margin-top:4px}.empty{text-align:center;color:var(--muted);padding:40px 20px}.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}.stat{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:12px 10px;text-align:center;min-width:0}.stat-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.stat-value{font-size:16px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stat-delta{font-size:11px;margin-top:4px;font-weight:600}.stat-delta.up{color:var(--green)}.stat-delta.down{color:var(--red)}.donut-row{display:flex;justify-content:center;margin:4px 0 16px}.donut-wrap{position:relative;display:inline-block}.donut-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none;text-align:center}.donut-amount{font-size:16px;font-weight:700;line-height:1.1;padding:0 8px;word-break:break-all}.donut-label{font-size:11px;color:var(--muted);margin-top:4px}.legend{display:flex;flex-direction:column;gap:6px}.legend-row{display:grid;grid-template-columns:12px 1fr auto auto;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px}.legend-row:last-child{border-bottom:none}.legend-dot{width:12px;height:12px;border-radius:3px;display:inline-block}.legend-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.legend-amount{font-weight:600}.legend-pct{color:var(--muted);font-size:12px;min-width:32px;text-align:right}.bars{display:flex;flex-direction:column;gap:12px}.bar-row{display:flex;flex-direction:column;gap:6px}.bar-head{display:flex;justify-content:space-between;align-items:center}.bar-track{height:8px;background:var(--bg-elev);border-radius:999px;overflow:hidden}.bar-fill{height:100%;border-radius:999px;transition:width .3s ease}.toasts{position:fixed;top:env(safe-area-inset-top);left:0;right:0;display:flex;flex-direction:column;align-items:center;gap:8px;padding:8px 12px;pointer-events:none;z-index:200}.toast{pointer-events:auto;background:var(--bg-card);border:1px solid var(--border);border-left:4px solid var(--primary);border-radius:12px;padding:10px 14px;width:100%;max-width:440px;box-shadow:0 8px 24px #0006;font-size:14px;cursor:pointer;animation:toast-in .25s ease}.toast-success{border-left-color:var(--green)}.toast-error{border-left-color:var(--red)}.toast-warning{border-left-color:var(--yellow)}.toast-title{font-weight:700;margin-bottom:2px}.toast-body{color:var(--text);opacity:.9}@keyframes toast-in{0%{transform:translateY(-12px);opacity:0}to{transform:translateY(0);opacity:1}}.conn-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--red);margin-right:6px;vertical-align:middle}.conn-dot.online{background:var(--green);box-shadow:0 0 6px var(--green)}.badge.archivada{background:#94a3b82e;color:var(--muted)}.archived-row{opacity:.6}.search-bar{position:relative;margin-bottom:10px}.search-bar input{padding-left:40px;padding-right:36px}.search-icon{position:absolute;top:50%;left:12px;transform:translateY(-50%);font-size:16px;pointer-events:none;opacity:.7}.search-clear{position:absolute;top:50%;right:6px;transform:translateY(-50%);width:28px;height:28px;padding:0;border-radius:50%;background:var(--bg-elev);color:var(--muted);font-size:18px;line-height:1;border:none;cursor:pointer}.install-banner{background:var(--bg-card);border:1px solid var(--border);border-left:4px solid var(--primary);border-radius:12px;padding:12px;margin-bottom:12px;display:flex;gap:10px;align-items:center;justify-content:space-between}.install-text{min-width:0;flex:1}
