:root{--primary:#6366f1;--primary-light:#e0e7ff;--primary-dark:#4f46e5;--ingreso:#10b981;--gasto:#ef4444;--bg:#f1f5f9;--surface:#fff;--border:#cbd5e1;--text:#0f172a;--text-secondary:#475569;--text-tertiary:#64748b;--radius:12px;--radius-lg:20px;--shadow-sm:0 1px 3px #0f172a0f,0 1px 2px #0f172a0a;--shadow-md:0 4px 16px #0f172a14,0 1px 3px #0f172a0a;--shadow-primary:0 8px 24px #6366f159;--font:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono:"SF Mono", ui-monospace, "Menlo", "Consolas", monospace}[data-theme=dark]{--primary:#818cf8;--primary-light:#1e1b4b;--primary-dark:#a5b4fc;--ingreso:#34d399;--gasto:#f87171;--bg:#0f172a;--surface:#1e293b;--border:#334155;--text:#f1f5f9;--text-secondary:#94a3b8;--text-tertiary:#64748b;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-primary:0 8px 24px #818cf840}[data-theme=dark] .tx-icon{background:#1e293b}[data-theme=dark] .tx-card,[data-theme=dark] .acct-card,[data-theme=dark] .cat-row{border-color:var(--border)}[data-theme=dark] .input,[data-theme=dark] .chip{background:var(--surface);border-color:var(--border);color:var(--text)}[data-theme=dark] .chip:hover{border-color:#475569}[data-theme=dark] .chip.active{background:var(--primary-light);color:var(--primary);border-color:var(--primary)}[data-theme=dark] .segmented{background:#1e293b}[data-theme=dark] .segmented button.active{color:var(--text);background:#334155}[data-theme=dark] .panel,[data-theme=dark] .panel-row{border-color:var(--border)}[data-theme=dark] .auth-shell{background:linear-gradient(160deg,#1e1b4b 0%,#0f172a 60%)}[data-theme=dark] .auth-card{border-color:#1e1b4b}[data-theme=dark] .icon-btn:hover{background:#334155}[data-theme=dark] .icon-btn.danger:hover{background:#450a0a}[data-theme=dark] .cat-badge{background:#334155}[data-theme=dark] .balance-card{box-shadow:0 12px 30px -8px #818cf84d}*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}a{color:inherit;text-decoration:none}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overscroll-behavior-y:contain;font-size:15px;line-height:1.5}button{cursor:pointer;touch-action:manipulation;font-family:inherit;text-decoration:none}input{font-family:inherit}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.app-shell{min-height:100vh;display:flex}.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:240px;height:100vh;padding:24px 14px;display:flex;position:sticky;top:0}.sidebar-logo{color:var(--primary);align-items:center;gap:8px;padding:0 12px 24px;font-size:22px;font-weight:800;display:flex}.sidebar-logo-mark{background:linear-gradient(135deg,var(--primary),#818cf8);color:#fff;border-radius:9px;place-items:center;width:32px;height:32px;font-size:16px;display:grid;box-shadow:0 4px 10px #6366f159}.sidebar-nav{flex-direction:column;gap:2px;display:flex}.nav-link{color:var(--text-secondary);text-align:left;background:0 0;border:0;border-radius:10px;align-items:center;gap:12px;width:100%;padding:11px 14px;font-size:14.5px;font-weight:500;transition:background .15s,color .15s;display:flex}.nav-link:hover{background:var(--primary-light);color:var(--text)}.nav-link.active{background:var(--primary-light);color:var(--primary);font-weight:600}.nav-link .nav-icon{justify-content:center;width:22px;font-size:18px;display:inline-flex}.sidebar-footer{border-top:1px solid var(--border);align-items:center;gap:10px;margin-top:auto;padding:12px;display:flex}.avatar{width:36px;height:36px;color:var(--primary-dark);background:linear-gradient(135deg,#c7d2fe,#a5b4fc);border-radius:50%;flex-shrink:0;place-items:center;font-weight:700;display:grid}.avatar-meta{min-width:0;line-height:1.2}.avatar-meta .name{color:var(--text);font-size:13.5px;font-weight:600}.avatar-meta .email{color:var(--text-tertiary);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.main{flex:1;width:100%;min-width:0;max-width:1024px;margin:0 auto;padding:32px 40px 60px}.bottom-nav,.bn-voz-btn{display:none}@media (max-width:767px){.sidebar{display:none}.main{padding:env(safe-area-inset-top,12px) 16px calc(96px + env(safe-area-inset-bottom));padding-top:max(16px,env(safe-area-inset-top));max-width:100%}.bottom-nav{background:var(--surface);border-top:1px solid var(--border);padding:6px 4px calc(10px + env(safe-area-inset-bottom));z-index:30;grid-template-columns:repeat(5,1fr);display:grid;position:fixed;bottom:0;left:0;right:0;overflow:visible}.bottom-nav a{color:var(--text-tertiary);touch-action:manipulation;background:0 0;border:0;flex-direction:column;align-items:center;gap:3px;padding:6px 4px;font-size:10.5px;font-weight:500;transition:color .15s;display:flex}.bottom-nav a .bn-icon{justify-content:center;align-items:center;line-height:1;display:flex}.bottom-nav a.active{color:var(--primary)}.bn-voz-btn{touch-action:manipulation;background:0 0;border:0;justify-content:center;align-items:flex-end;padding:0 0 8px;display:flex;position:relative;overflow:visible}.bn-voz-inner{background:linear-gradient(135deg,var(--primary) 0%,#818cf8 100%);color:#fff;border:3px solid var(--surface);border-radius:50%;place-items:center;width:54px;height:54px;transition:transform .12s,box-shadow .12s;display:grid;position:absolute;bottom:calc(100% - 24px);left:50%;transform:translate(-50%);box-shadow:0 4px 20px #6366f180}.bn-voz-btn:active .bn-voz-inner{transform:translate(-50%)scale(.93);box-shadow:0 2px 10px #6366f166}}.page-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:22px;display:flex}.page-title{letter-spacing:-.01em;margin:0;font-size:22px;font-weight:800}.page-subtitle{color:var(--text-tertiary);margin-top:2px;font-size:13.5px}@media (max-width:767px){.page-title{font-size:20px}}.balance-card{background:linear-gradient(170deg,var(--primary) 0%,#818cf8 100%);color:#fff;border-radius:var(--radius-lg);padding:22px 22px 18px;position:relative;overflow:hidden;box-shadow:0 12px 30px -8px #6366f173}.balance-card:after{content:"";pointer-events:none;background:radial-gradient(circle at 90% -20%,#ffffff2e,#0000 50%);position:absolute;inset:0}.balance-label{opacity:.85;letter-spacing:.02em;font-size:13px}.balance-amount{letter-spacing:-.02em;font-variant-numeric:tabular-nums;margin-top:6px;font-size:36px;font-weight:800}.balance-amount .currency{opacity:.85;vertical-align:4px;margin-right:6px;font-size:18px;font-weight:600}.balance-amount .cents{opacity:.8;font-size:22px;font-weight:700}.balance-chips{flex-wrap:wrap;gap:8px;margin-top:16px;display:flex}.balance-chip{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff29;border-radius:999px;align-items:center;gap:7px;padding:6px 12px;font-size:12.5px;font-weight:500;display:flex}.balance-chip .dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.balance-chip .chip-amt{opacity:.85;font-variant-numeric:tabular-nums}@media (max-width:767px){.balance-amount{font-size:28px}.balance-amount .cents{font-size:18px}}.balance-grid{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:8px;display:grid}.balance-card--empty .balance-chips{display:none}@media (max-width:600px){.balance-grid{grid-template-columns:1fr}}.section-head{justify-content:space-between;align-items:baseline;margin:28px 4px 12px;display:flex}.section-head h2{color:var(--text);letter-spacing:.01em;text-transform:uppercase;margin:0;font-size:14.5px;font-weight:700}.section-head .link{color:var(--primary);background:0 0;border:0;font-size:13px;font-weight:600}.tx-list{flex-direction:column;gap:8px;display:flex}.tx-day-sep{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:2px;padding:8px 0 4px;display:flex}.tx-day-label{color:var(--text);text-transform:capitalize;font-size:13px;font-weight:600}.tx-day-totals{gap:10px;font-size:12px;font-weight:600;display:flex}.tx-day-in{color:var(--ingreso)}.tx-day-out{color:var(--gasto)}.tx-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--border);align-items:center;gap:12px;padding:14px;display:flex}.tx-icon{border-radius:50%;flex-shrink:0;place-items:center;width:40px;height:40px;display:grid}.tx-info{flex:1;min-width:0}.tx-label{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:14.5px;font-weight:600;overflow:hidden}.tx-sub{color:var(--text-tertiary);text-overflow:ellipsis;white-space:nowrap;margin-top:2px;font-size:12.5px;overflow:hidden}.tx-edit-btn,.tx-delete-btn{opacity:0;transition:opacity .15s}.tx-card:hover .tx-edit-btn,.tx-card:hover .tx-delete-btn{opacity:1}@media (hover:none){.tx-edit-btn,.tx-delete-btn{opacity:.55}}.tx-amount{font-variant-numeric:tabular-nums;white-space:nowrap;font-size:15px;font-weight:700}.tx-amount.ingreso{color:var(--ingreso)}.tx-amount.gasto{color:var(--gasto)}.acct-list{flex-direction:column;gap:10px;display:flex}.acct-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--border);border-left:4px solid var(--primary);align-items:center;gap:14px;padding:14px 16px;display:flex}.acct-emoji{text-align:center;width:36px;font-size:26px;line-height:1}.acct-info{flex:1;min-width:0}.acct-info .name{color:var(--text);font-size:15px;font-weight:600}.acct-info .type{color:var(--text-tertiary);text-transform:capitalize;margin-top:2px;font-size:12.5px}.acct-balance{font-variant-numeric:tabular-nums;text-align:right;font-size:15px;font-weight:700}.acct-actions{gap:4px;margin-left:4px;display:flex}.icon-btn{width:32px;height:32px;color:var(--text-tertiary);background:0 0;border:0;border-radius:8px;place-items:center;font-size:14px;display:grid}.icon-btn:hover{background:var(--primary-light);color:var(--text)}.icon-btn.danger:hover{color:var(--gasto);background:#fef2f2}.cat-section{margin-top:12px}.cat-section h3{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin:18px 4px 10px;font-size:13px;font-weight:700}.cat-list{flex-direction:column;gap:6px;display:flex}.cat-row{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--border);align-items:center;gap:12px;padding:12px 14px;display:flex}.cat-icon{background:var(--bg);border-radius:50%;flex-shrink:0;place-items:center;width:36px;height:36px;display:grid}.cat-name{flex:1;font-size:14.5px;font-weight:500}.cat-meta{color:var(--text-tertiary);text-align:center;min-width:20px;font-size:11px}.cat-row.subcat{border-left:2px solid var(--border);margin-left:40px;padding-left:14px}.cat-badge{color:var(--text-secondary);background:#f1f5f9;border-radius:6px;padding:3px 8px;font-size:11px;font-weight:600}.fab{background:var(--primary);color:#fff;width:60px;height:60px;box-shadow:var(--shadow-primary);z-index:25;touch-action:manipulation;border:0;border-radius:50%;place-items:center;font-size:30px;font-weight:400;line-height:1;transition:transform .15s;display:grid;position:fixed;bottom:28px;right:24px}.fab:hover{transform:scale(1.05)}@media (max-width:767px){.fab{bottom:calc(80px + env(safe-area-inset-bottom));right:20px}}.fab-group{z-index:25;touch-action:manipulation;flex-direction:column;align-items:center;gap:14px;display:flex;position:fixed;bottom:28px;right:24px}.fab-main{color:#fff;cursor:pointer;background:linear-gradient(135deg,#f59e0b,#f97316);border:0;border-radius:50%;place-items:center;width:64px;height:64px;font-size:28px;transition:transform .15s,box-shadow .15s;display:grid;box-shadow:0 8px 28px #f59e0b73}.fab-main:hover{transform:scale(1.08);box-shadow:0 12px 32px #f59e0b8c}.fab-main.recording{background:linear-gradient(135deg,var(--gasto),#dc2626);animation:1.5s ease-in-out infinite pulse;box-shadow:0 0 0 8px #ef44444d}.fab-secondary{background:var(--surface);width:46px;height:46px;color:var(--primary);border:2px solid var(--primary);box-shadow:var(--shadow-md);cursor:pointer;border-radius:50%;place-items:center;font-size:22px;font-weight:300;line-height:1;transition:transform .15s;display:grid}.fab-secondary:hover{background:var(--primary-light);transform:scale(1.08)}@keyframes pulse{0%,to{box-shadow:0 0 0 8px #ef44444d}50%{box-shadow:0 0 0 16px #ef44441a}}.fab-secondary:hover:disabled,.fab-secondary:disabled{cursor:default;opacity:.5}.fab-main.processing{background:linear-gradient(135deg,var(--primary),var(--primary-dark));box-shadow:0 8px 28px #6366f173}.fab-main:disabled{cursor:default}.fab-processing-label{color:var(--primary);white-space:nowrap;font-size:13px;font-weight:500;position:absolute;bottom:-28px;right:0}.voice-overlay{z-index:50;-webkit-backdrop-filter:blur(12px);background:#0f172ad9;flex-direction:column;justify-content:center;align-items:center;animation:.3s ease-out fadeIn;display:flex;position:fixed;inset:0}.voice-waves{place-items:center;width:120px;height:120px;display:grid;position:relative}.voice-wave-ring{border:3px solid var(--gasto);opacity:0;border-radius:50%;width:80px;height:80px;animation:2s ease-out infinite voiceWave;position:absolute}.voice-wave-ring:nth-child(2){animation-delay:.6s}.voice-wave-ring:nth-child(3){animation-delay:1.2s}@keyframes voiceWave{0%{opacity:.6;width:80px;height:80px}to{opacity:0;width:200px;height:200px}}.voice-recording-label{color:#fff;align-items:center;gap:10px;margin-top:24px;font-size:18px;font-weight:500;display:flex}.voice-rec-dot{background:var(--gasto);border-radius:50%;width:12px;height:12px;animation:.8s ease-in-out infinite voiceRecDot}@keyframes voiceRecDot{0%,to{opacity:1}50%{opacity:.3}}.voice-cancel-btn:hover{border-color:var(--gasto);background:#ef444459;transform:scale(1.08)}.voice-actions{align-items:center;gap:24px;margin-top:48px;display:flex}.voice-stop-btn{background:var(--gasto);color:#fff;cursor:pointer;border:none;border-radius:50%;place-items:center;width:72px;height:72px;transition:transform .15s,box-shadow .15s;display:grid;box-shadow:0 0 24px #ef444466}.voice-stop-btn:hover{transform:scale(1.1);box-shadow:0 0 32px #ef444499}.voice-cancel-btn{color:#fff;cursor:pointer;background:#ffffff1f;border:2px solid #ffffff40;border-radius:50%;place-items:center;width:56px;height:56px;margin-top:0;transition:background .15s,transform .15s;display:grid}.toast{background:var(--text);color:var(--bg);z-index:60;text-align:center;border-radius:12px;max-width:90vw;padding:14px 24px;font-size:14.5px;font-weight:500;animation:.25s ease-out toastIn;position:fixed;bottom:110px;left:50%;transform:translate(-50%);box-shadow:0 8px 24px #0003}.toast.success{background:var(--ingreso)}.toast.error{background:var(--gasto)}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(12px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@media (max-width:767px){.toast{bottom:calc(96px + env(safe-area-inset-bottom))}}[data-theme=dark] .toast{color:var(--text);box-shadow:0 8px 24px #00000080}.chips-row{scrollbar-width:none;gap:8px;margin:0 -2px 8px;padding:4px 0;display:flex;overflow-x:auto}.chips-row::-webkit-scrollbar{display:none}.chip{background:var(--surface);border:1px solid var(--border);color:var(--text-secondary);white-space:nowrap;border-radius:20px;flex-shrink:0;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.chip:hover{border-color:var(--text-tertiary)}.chip.active{border-color:var(--primary);background:var(--primary-light);color:var(--primary);font-weight:600}.filter-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:20px;padding:14px 18px}.filter-row{flex-wrap:wrap;align-items:flex-start;gap:20px;display:flex}.filter-group{flex-direction:column;gap:4px;display:flex}.filter-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);margin-bottom:2px;font-size:11px;font-weight:600}.filter-dates{align-items:center;gap:6px;display:flex}.input.sm{border-radius:8px;width:140px;height:36px;padding:0 10px;font-size:13px}.filter-actions{border-top:1px solid var(--border);align-items:center;gap:8px;margin-top:12px;padding-top:12px;display:flex}@media (max-width:767px){.filter-bar{background:0 0;border:none;margin-bottom:8px;padding:0}.filter-row{flex-direction:column;gap:0}.filter-group .chips-row{margin-bottom:4px}.filter-group:not(:first-child) .filter-label{display:none}.filter-dates .input.sm{width:120px}}.multi-select-trigger{background:var(--surface);border:1px solid var(--border);min-width:160px;height:36px;color:var(--text);cursor:pointer;white-space:nowrap;text-overflow:ellipsis;border-radius:8px;justify-content:space-between;align-items:center;gap:8px;padding:0 12px;font-size:13px;display:flex;overflow:hidden}.multi-select-trigger:hover{border-color:var(--primary)}.multi-select-dropdown{z-index:30;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);min-width:200px;max-height:240px;margin-top:4px;padding:4px;position:absolute;top:100%;left:0;overflow-y:auto;box-shadow:0 8px 24px #0000001f}.multi-select-item{cursor:pointer;color:var(--text);border-radius:6px;align-items:center;gap:8px;padding:8px 10px;font-size:13px;display:flex}.multi-select-item:hover{background:var(--primary-light)}.multi-select-check{border:2px solid var(--border);width:18px;height:18px;color:var(--primary);border-radius:4px;flex-shrink:0;place-items:center;display:grid}.multi-select-check.active{background:var(--primary);border-color:var(--primary);color:#fff}.multi-select-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}@media (max-width:767px){.multi-select-trigger{min-width:120px}}.chip .chip-dot{border-radius:50%;width:8px;height:8px}.field{flex-direction:column;margin-bottom:14px;display:flex}.field label{color:var(--text-secondary);margin-bottom:6px;font-size:14px;font-weight:500}.input{border:1.5px solid var(--border);height:48px;color:var(--text);background:var(--surface);border-radius:10px;width:100%;padding:0 14px;font-size:15px;transition:border-color .15s,box-shadow .15s}.input:focus{border-color:var(--primary);outline:0;box-shadow:0 0 0 3px #6366f11f}select.input{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding-right:36px}.input.has-affix{padding-right:44px}.input-wrap{position:relative}.input-affix{width:34px;height:34px;color:var(--text-tertiary);background:0 0;border:0;border-radius:8px;place-items:center;font-size:13px;display:grid;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.input-affix:hover{background:var(--primary-light);color:var(--text)}.error-msg{color:var(--gasto);margin-top:8px;font-size:13px}.btn{border-radius:var(--radius);border:1.5px solid #0000;justify-content:center;align-items:center;gap:8px;height:48px;padding:0 18px;font-size:15px;font-weight:600;transition:all .15s;display:inline-flex}.btn.primary{background:var(--primary);color:#fff}.btn.primary:hover{background:var(--primary-dark)}.btn.secondary{border-color:var(--primary);color:var(--primary);background:0 0}.btn.secondary:hover{background:var(--primary-light)}.btn.danger{background:var(--gasto);color:#fff}.btn.danger:hover{background:#dc2626}.btn.ghost{color:var(--text-secondary);background:0 0}.btn.ghost:hover{background:var(--primary-light);color:var(--text)}.btn.sm{border-radius:10px;height:38px;padding:0 14px;font-size:13.5px}.btn[disabled]{opacity:.6;cursor:not-allowed}.btn.full{width:100%}.modal-overlay{z-index:50;background:#0f172a73;place-items:center;padding:16px;animation:.15s fadeIn;display:grid;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.modal{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:480px;max-height:90vh;padding:24px;animation:.2s slideUp;overflow-y:auto;box-shadow:0 24px 48px -12px #0f172a40}.modal-head{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.modal-head h3{margin:0;font-size:18px;font-weight:700}.modal-actions{gap:10px;margin-top:8px;display:flex}@media (max-width:480px){.modal-overlay{align-items:flex-end;padding:0}.modal{border-radius:20px 20px 0 0;max-width:100%;max-height:92vh}}.color-picker{flex-wrap:wrap;gap:10px;padding:4px 0;display:flex}.color-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;width:32px;height:32px;transition:transform .1s;position:relative}.color-swatch:hover{transform:scale(1.08)}.color-swatch.active{border-color:var(--text);box-shadow:0 0 0 2px var(--surface) inset}.panel{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.panel-row{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;gap:12px;padding:14px 18px;display:flex}.panel-row:last-child{border-bottom:0}.panel-row .label{color:var(--text-tertiary);font-size:13px}.panel-row .value{font-size:14px;font-weight:600}.panel-row.col{flex-direction:column;align-items:flex-start;gap:8px}.empty{text-align:center;color:var(--text-tertiary);padding:60px 20px}.empty-icon{opacity:.5;margin-bottom:10px;font-size:40px}.empty p{margin:0;font-size:14.5px}.auth-shell{background:linear-gradient(160deg,#eef2ff 0%,#f8fafc 60%);place-items:center;min-height:100vh;padding:24px;display:grid}.auth-card{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);width:100%;max-width:400px;padding:32px 28px;box-shadow:0 10px 40px -10px #6366f12e,0 2px 4px #0f172a0a}.auth-logo{color:var(--primary);letter-spacing:-.01em;justify-content:center;align-items:center;gap:10px;margin-bottom:6px;font-size:26px;font-weight:800;display:flex}.auth-logo .emoji{font-size:28px}.auth-tagline{text-align:center;color:var(--text-tertiary);margin-bottom:26px;font-size:13.5px}.auth-toggle-text{text-align:center;color:var(--text-secondary);margin-top:16px;font-size:14px}.auth-toggle-text button{color:var(--primary);background:0;border:0;padding:0 4px;font-weight:600}.segmented{background:#f1f5f9;border-radius:10px;padding:4px;display:inline-flex}.segmented button{color:var(--text-secondary);background:0 0;border:0;border-radius:7px;padding:8px 14px;font-size:13.5px;font-weight:600}.segmented button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.row{align-items:center;gap:10px;display:flex}.spacer{flex:1}.muted{color:var(--text-tertiary);font-size:12.5px}.mono{font-family:var(--font-mono)}.note-small{color:var(--text-tertiary);margin-top:8px;font-size:12.5px;line-height:1.45}.info-badge{border:1.5px solid var(--text-tertiary);width:18px;height:18px;color:var(--text-tertiary);cursor:help;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:inline-flex}.tooltip-wrap{display:inline-flex;position:relative}.tooltip-text{background:var(--surface);color:var(--text);white-space:normal;text-align:left;z-index:9999;pointer-events:none;border:1px solid var(--border);border-radius:12px;width:270px;padding:12px 16px;font-size:12.5px;font-weight:400;line-height:1.5;display:none;position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);box-shadow:0 8px 24px #0f172a26}.tooltip-text:after{content:"";border:6px solid #0000;border-top-color:var(--surface);position:absolute;top:100%;left:50%;transform:translate(-50%)}.tooltip-wrap:hover .tooltip-text{display:block}[data-theme=dark] .tooltip-text{box-shadow:0 8px 24px #0006}.spinner{border:3px solid #e2e8f0;border-top-color:var(--primary);border-radius:50%;width:32px;height:32px;margin:0 auto;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}@media (max-width:900px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.stats-grid{grid-template-columns:1fr}}.stat-block{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);padding:18px 20px;position:relative;overflow:hidden}.stat-block:before{content:"";height:3px;position:absolute;top:0;left:0;right:0}.stat-block.saldo:before{background:linear-gradient(90deg,var(--ingreso),#34d399)}.stat-block.capital:before{background:linear-gradient(90deg,var(--primary),#818cf8)}.stat-block.deudas:before{background:linear-gradient(90deg,var(--gasto),#f87171)}.stat-block.gastos:before{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.stat-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px;font-size:12px;font-weight:600}.stat-amount{color:var(--text);letter-spacing:-.02em;font-variant-numeric:tabular-nums;font-size:26px;font-weight:800}.stat-block.saldo .stat-amount{color:var(--ingreso)}.stat-block.deudas .stat-amount{color:var(--gasto)}.stat-block.gastos .stat-amount{color:#f59e0b}.dashboard-grid{grid-template-columns:minmax(0,1fr) 380px;align-items:start;gap:24px;display:grid}@media (max-width:960px){.dashboard-grid{grid-template-columns:1fr}}.chart-section{grid-template-columns:repeat(3,1fr);gap:18px;display:grid}.chart-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--border);padding:16px}@media (max-width:900px){.chart-section{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.chart-section{grid-template-columns:1fr}}.chart-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;margin-bottom:10px;font-size:13px;font-weight:700}.chart-empty{text-align:center;color:var(--text-tertiary);padding:30px 16px;font-size:13px}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:var(--border);stroke-opacity:.5}.recharts-text{fill:var(--text-tertiary);font-size:12px}.recharts-default-tooltip{background:var(--surface)!important;border:1px solid var(--border)!important;box-shadow:var(--shadow-md)!important;border-radius:8px!important}.recharts-tooltip-label{font-weight:600;color:var(--text)!important}.recharts-legend-item-text{color:var(--text-secondary)!important;font-size:12px!important}[data-theme=dark] .stat-block,[data-theme=dark] .chart-card{border-color:var(--border)}[data-theme=dark] .recharts-default-tooltip{background:var(--surface)!important}[data-theme=dark] .cat-icon{background:#334155}.icon-picker-wrap{flex-direction:column;gap:8px;display:flex}.icon-picker-search{background:var(--surface);border:1.5px solid var(--border);height:36px;color:var(--text-tertiary);border-radius:10px;align-items:center;gap:6px;padding:0 10px;display:flex}.icon-picker-search .input{height:100%;color:var(--text);background:0 0;border:none;outline:none;flex:1;padding:0;font-size:13px}.icon-picker-search .input::placeholder{color:var(--text-tertiary)}.icon-search-clear{background:var(--border);width:20px;height:20px;color:var(--text-secondary);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;place-items:center;padding:0;display:grid}.icon-search-clear:hover{background:var(--text-tertiary);color:var(--surface)}.icon-picker{flex-wrap:wrap;gap:8px;max-height:220px;padding-right:4px;display:flex;overflow-y:auto}.icon-picker::-webkit-scrollbar{width:4px}.icon-picker::-webkit-scrollbar-track{background:0 0}.icon-picker::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.icon-picker-empty{text-align:center;width:100%;color:var(--text-tertiary);padding:20px;font-size:13px}.icon-pick{border:1.5px solid var(--border);background:var(--surface);width:40px;height:40px;color:var(--text-secondary);cursor:pointer;border-radius:10px;flex-shrink:0;place-items:center;transition:all .15s;display:grid}.icon-pick:hover{border-color:var(--primary);color:var(--primary)}.icon-pick.active{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}@media (max-width:767px){.fab-group{bottom:calc(84px + env(safe-area-inset-bottom));right:20px}.fab-main{display:none}.fab-secondary{width:50px;height:50px}.input,.input.sm,select.input,textarea.input{font-size:16px}.btn{touch-action:manipulation;min-height:48px}.icon-btn{width:40px;height:40px}.chip{touch-action:manipulation;min-height:40px;padding:8px 16px}.nav-link{touch-action:manipulation}.tx-card{gap:14px;padding:16px 14px}.tx-icon{width:44px;height:44px}.acct-card{padding:16px 18px}.cat-row{padding:14px 16px}}@media (max-width:600px){.stats-grid{grid-template-columns:1fr 1fr;gap:12px}.stat-block{padding:14px 16px}.stat-amount{font-size:22px}}@media (max-width:380px){.stats-grid{grid-template-columns:1fr}}@media (max-width:600px){.chart-section{grid-template-columns:1fr;gap:12px}.chart-card{padding:14px}}@media (max-width:767px){.filter-bar{background:0 0;border:none;margin-bottom:6px;padding:0}.filter-row{flex-direction:column;gap:6px}.filter-group .filter-label{margin-bottom:2px;font-size:10px}.filter-group:not(:first-child) .filter-label{display:none}.chips-row{gap:6px;padding-bottom:4px}.chip{padding:6px 12px;font-size:12.5px}.input.sm{width:130px;height:40px;font-size:15px}}@media (max-width:480px){.modal-overlay{align-items:flex-end;padding:0}.modal{max-width:100%;max-height:94vh;padding:20px 20px calc(20px + env(safe-area-inset-bottom));border-radius:20px 20px 0 0}.modal:before{content:"";background:var(--border);border-radius:2px;width:40px;height:4px;margin:0 auto 16px;display:block}}@media (max-width:767px){.page-header{gap:8px;margin-bottom:16px}.page-title{font-size:22px;font-weight:800}.chips-row{-webkit-overflow-scrolling:touch;scroll-snap-type:x proximity}.panel-row{padding:16px 18px}}@media (max-width:400px){.auth-card{border-radius:var(--radius-lg);padding:28px 20px}}@media (max-width:767px){.dashboard-grid{grid-template-columns:1fr;gap:16px}.section-head{margin:20px 2px 10px}.section-head h2{font-size:13px}.balance-grid{grid-template-columns:1fr;gap:10px}}[data-theme=dark] .bn-voz-inner{border-color:var(--surface);box-shadow:0 4px 20px #818cf866}.sync-banner{left:0;right:0;bottom:calc(64px + env(safe-area-inset-bottom));background:var(--primary);color:#fff;z-index:28;justify-content:center;align-items:center;gap:10px;padding:9px 16px;font-size:13px;font-weight:500;animation:.2s ease-out slideUpBanner;display:flex;position:fixed}@keyframes slideUpBanner{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sync-spinner{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.7s linear infinite spin}.sync-banner--mobile{display:none}@media (max-width:767px){.sync-banner--mobile{display:flex}.sync-banner:not(.sync-banner--mobile){display:none}}.mobile-settings-btn{justify-content:center;align-items:center;display:flex}@media (min-width:768px){.mobile-settings-btn{display:none}.sync-banner:not(.sync-banner--mobile){background:var(--primary-light);color:var(--primary);border-radius:8px;gap:8px;margin:0 14px 10px;padding:8px 12px;font-size:12px;animation:none;position:static}.sync-banner:not(.sync-banner--mobile) .sync-spinner{border-color:#6366f140;border-top-color:var(--primary)}}
