@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{--bg-app:#090d16;--bg-surface:#111827;--bg-surface-hover:#1f2937;--border-color:#ffffff14;--border-focus:#8b5cf6;--text-primary:#f3f4f6;--text-secondary:#9ca3af;--text-muted:#6b7280;--accent:#8b5cf6;--accent-light:#a78bfa;--accent-dark:#6d28d9;--accent-glow:#8b5cf640;--success:#10b981;--success-glow:#10b98126;--danger:#ef4444;--danger-glow:#ef444426;--warning:#f59e0b;--font-family:"Outfit", system-ui, -apple-system, sans-serif;--border-radius-sm:8px;--border-radius-md:12px;--border-radius-lg:20px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000004d, 0 4px 6px -2px #00000026;--shadow-glow:0 0 20px 0 var(--accent-glow);--transition-fast:.15s ease;--transition-normal:.25s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--bg-app);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-image:radial-gradient(at 0 0,#8b5cf614 0,#0000 50%),radial-gradient(at 100% 100%,#3b82f60d 0,#0000 50%);background-attachment:fixed;min-height:100vh;line-height:1.5}#root{flex-direction:column;min-height:100vh;display:flex}.app-container{flex-direction:column;flex-grow:1;gap:24px;width:100%;max-width:1200px;margin:0 auto;padding:24px 16px;display:flex}.loading-screen{height:100vh;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.spinner{border:3px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.auth-container{justify-content:center;align-items:center;min-height:calc(100vh - 48px);padding:20px;display:flex}.card-login{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);width:100%;max-width:420px;box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-direction:column;gap:28px;padding:40px 32px;animation:.4s ease-out fadeIn;display:flex;position:relative;overflow:hidden}.card-login:before{content:"";background:linear-gradient(90deg, var(--accent), #3b82f6);width:100%;height:4px;position:absolute;top:0;left:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.logo-header{text-align:center;flex-direction:column;align-items:center;gap:8px;display:flex}.logo-header h1{letter-spacing:-.5px;color:var(--text-primary);align-items:center;gap:8px;font-size:28px;font-weight:700;display:flex}.logo-header h1 span{background:linear-gradient(135deg, var(--accent-light), #60a5fa);-webkit-text-fill-color:transparent;-webkit-background-clip:text}.logo-header p{color:var(--text-secondary);font-size:14px}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:var(--text-secondary);font-size:14px;font-weight:500}.input-field{border:1px solid var(--border-color);color:var(--text-primary);border-radius:var(--border-radius-md);font-family:var(--font-family);transition:var(--transition-fast);background-color:#ffffff08;outline:none;padding:12px 16px;font-size:15px}.input-field:focus{border-color:var(--border-focus);background-color:#ffffff0d;box-shadow:0 0 0 3px #8b5cf626}.btn-primary{background:linear-gradient(135deg, var(--accent), var(--accent-dark));color:#fff;border-radius:var(--border-radius-md);font-family:var(--font-family);cursor:pointer;transition:var(--transition-normal);border:none;justify-content:center;align-items:center;gap:8px;padding:14px;font-size:16px;font-weight:600;display:flex;box-shadow:0 4px 12px #8b5cf633}.btn-primary:hover:not(:disabled){opacity:.95;transform:translateY(-2px);box-shadow:0 6px 20px #8b5cf659}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.alert-message{border-radius:var(--border-radius-md);align-items:center;gap:8px;padding:12px 16px;font-size:14px;font-weight:500;display:flex}.alert-error{background-color:var(--danger-glow);color:#fca5a5;border:1px solid #ef444433}.header-app{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding-bottom:16px;display:flex}.header-user{align-items:center;gap:16px;display:flex}.user-email{color:var(--text-secondary);border:1px solid var(--border-color);background-color:#ffffff0d;border-radius:20px;padding:4px 12px;font-size:14px}.btn-logout{color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);font-family:var(--font-family);cursor:pointer;transition:var(--transition-fast);background:0 0;padding:8px 16px;font-size:14px;font-weight:500}.btn-logout:hover{color:#f87171;background-color:#ef44441a;border-color:#ef444433}.summary-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;display:grid}.summary-card{background-color:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);flex-direction:column;gap:8px;padding:24px;display:flex;position:relative;overflow:hidden}.summary-card:after{content:"";pointer-events:none;background:radial-gradient(circle,#ffffff08 0%,#0000 70%);width:80px;height:80px;position:absolute;top:0;right:0}.summary-card-title{color:var(--text-secondary);align-items:center;gap:6px;font-size:14px;font-weight:500;display:flex}.summary-card-value{letter-spacing:-.5px;font-size:32px;font-weight:700}.value-income{color:var(--success)}.value-expense{color:var(--text-primary)}.value-balance{color:var(--accent-light)}.control-panel{background-color:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--border-radius-md);box-shadow:var(--shadow-sm);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:16px 24px;display:flex}.btn-secondary{color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);font-family:var(--font-family);cursor:pointer;transition:var(--transition-fast);background-color:#ffffff0d;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:500;display:flex}.btn-secondary:hover:not(:disabled){border-color:var(--text-secondary);background-color:#ffffff14}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.transactions-section{flex-direction:column;gap:16px;display:flex}.section-title{color:var(--text-primary);align-items:center;gap:8px;font-size:20px;font-weight:600;display:flex}.table-container{background-color:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);overflow:hidden}.table-responsive{width:100%;overflow-x:auto}.transaction-table{border-collapse:collapse;text-align:left;width:100%;font-size:14px}.transaction-table th{color:var(--text-secondary);border-bottom:1px solid var(--border-color);background-color:#ffffff05;padding:16px 20px;font-weight:600}.transaction-table td{border-bottom:1px solid var(--border-color);vertical-align:middle;color:var(--text-primary);padding:16px 20px}.transaction-table tr:last-child td{border-bottom:none}.transaction-table tr:hover td{background-color:#ffffff03}.badge-category{border:1px solid #0000;border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;display:inline-flex}.badge-source{border:1px solid var(--border-color);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;background-color:#ffffff0d;border-radius:6px;padding:3px 8px;font-size:11px;font-weight:500;display:inline-flex}.text-amount-income{color:var(--success);font-weight:600}.text-amount-expense{color:#ef4444;font-weight:500}.empty-state{text-align:center;color:var(--text-secondary);flex-direction:column;align-items:center;gap:12px;padding:48px 24px;display:flex}.empty-icon{margin-bottom:8px;font-size:32px}.month-selector{scrollbar-width:none;gap:8px;padding-bottom:4px;display:flex;overflow-x:auto}.month-selector::-webkit-scrollbar{display:none}.month-btn{background:var(--bg-surface);border:1px solid var(--border-color);color:var(--text-secondary);font-family:var(--font-family);cursor:pointer;white-space:nowrap;transition:var(--transition-fast);border-radius:20px;padding:8px 18px;font-size:13px;font-weight:500}.month-btn:hover{border-color:var(--accent);color:var(--text-primary)}.month-btn-active{background:linear-gradient(135deg, var(--accent), var(--accent-dark));color:#fff;border-color:#0000;box-shadow:0 2px 12px #8b5cf659}.breakdown-section{flex-direction:column;gap:16px;display:flex}.breakdown-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;display:grid}.breakdown-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--border-radius-md);flex-direction:column;gap:10px;padding:16px 20px;display:flex}.breakdown-header{justify-content:space-between;align-items:center;display:flex}.breakdown-label{color:var(--text-primary);font-size:14px;font-weight:500}.breakdown-pct{color:var(--text-secondary);font-size:13px;font-weight:600}.breakdown-bar-bg{background:#ffffff0f;border-radius:3px;width:100%;height:6px;overflow:hidden}.breakdown-bar-fill{border-radius:3px;height:100%;transition:width .4s}.breakdown-amount{color:#ef4444;font-size:18px;font-weight:700}.tx-count{color:var(--text-muted);background:#ffffff0d;border-radius:12px;margin-left:8px;padding:2px 10px;font-size:13px;font-weight:400}.badge-sin-cat{color:#ef4444;cursor:pointer;white-space:nowrap;background:#ef44441f;border:1px solid #ef44444d;border-radius:99px;align-items:center;gap:6px;padding:4px 12px;font-size:12px;font-weight:600;transition:background .2s,border-color .2s;animation:2s ease-in-out infinite pulse-badge;display:inline-flex}.badge-sin-cat:hover{background:#ef444438;border-color:#ef444480}@keyframes pulse-badge{0%,to{opacity:1}50%{opacity:.7}}.breakdown-card-clickable{cursor:pointer;transition:border-color .2s,box-shadow .2s,transform .15s}.breakdown-card-clickable:hover{border-color:#8b5cf666;transform:translateY(-1px);box-shadow:0 0 0 1px #8b5cf633}.breakdown-card-active{border-color:var(--accent)!important;box-shadow:0 0 0 2px var(--accent-glow)!important;background:#8b5cf614!important}.filter-active-bar{border-radius:var(--border-radius-sm);color:var(--text-secondary);background:#8b5cf61a;border:1px solid #8b5cf640;justify-content:space-between;align-items:center;margin-bottom:4px;padding:8px 16px;font-size:13px;display:flex}.filter-active-bar strong{color:var(--accent-light)}.filter-clear-btn{color:var(--accent-light);cursor:pointer;background:0 0;border:1px solid #8b5cf64d;border-radius:99px;padding:3px 12px;font-size:12px;font-weight:600;transition:background .2s}.filter-clear-btn:hover{background:#8b5cf626}.tx-filter-label{color:var(--accent-light);background:#8b5cf61f;border:1px solid #8b5cf640;border-radius:99px;margin-left:4px;padding:2px 10px;font-size:13px;font-weight:500}.btn-export-csv{border:1px solid var(--border-color);color:var(--text-secondary);border-radius:var(--border-radius-sm);cursor:pointer;white-space:nowrap;background:#ffffff0d;margin-left:4px;padding:4px 14px;font-size:12px;font-weight:600;transition:background .2s,color .2s,border-color .2s}.btn-export-csv:hover{color:var(--success);background:#10b9811a;border-color:#10b9814d}.main-nav{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--border-radius-md);gap:4px;padding:4px;display:flex}.nav-btn{color:var(--text-secondary);border-radius:calc(var(--border-radius-md) - 2px);font-family:var(--font-family);cursor:pointer;transition:var(--transition-fast);white-space:nowrap;background:0 0;border:none;flex:1;padding:8px 12px;font-size:13px;font-weight:500}.nav-btn:hover{color:var(--text-primary);background:#ffffff0d}.nav-btn-active{background:linear-gradient(135deg, var(--accent), var(--accent-dark));color:#fff;box-shadow:0 2px 8px #8b5cf64d}.badge-category-btn{cursor:pointer;font-family:var(--font-family);transition:var(--transition-fast);background:0 0;border:1px solid;border-radius:20px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-flex}.badge-category-btn:hover{filter:brightness(1.2);transform:translateY(-1px)}.badge-no-cat{border-color:#ffffff1a!important}.cat-dropdown-wrap{min-width:180px;position:relative}.cat-select{background:var(--bg-surface);border:1px solid var(--accent);width:100%;color:var(--text-primary);font-family:var(--font-family);cursor:pointer;border-radius:8px;outline:none;padding:6px 10px;font-size:13px}.cat-select:focus{box-shadow:0 0 0 2px #8b5cf64d}.spinner-sm{border:2px solid #ffffff26;border-top-color:var(--accent);border-radius:50%;width:14px;height:14px;animation:.7s linear infinite spin;display:inline-block}.tendencias-section{flex-direction:column;gap:20px;display:flex}.chart-container{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--border-radius-md);align-items:flex-end;gap:12px;height:200px;padding:20px 20px 0;display:flex}.chart-col{flex-direction:column;flex:1;align-items:center;gap:6px;height:100%;display:flex}.chart-bars{flex:1;justify-content:center;align-items:flex-end;gap:4px;width:100%;display:flex}.chart-bar{border-radius:4px 4px 0 0;flex:1;min-height:2px;transition:height .4s}.chart-bar-income{background:var(--success)}.chart-bar-expense{background:#ef4444}.chart-label{color:var(--text-secondary);padding-bottom:4px;font-size:12px;font-weight:600}.chart-sublabel{color:var(--text-muted);padding-bottom:8px;font-size:10px}.chart-legend{color:var(--text-secondary);align-items:center;gap:6px;font-size:13px;display:flex}.legend-dot{border-radius:50%;width:10px;height:10px;display:inline-block}.legend-income{background:var(--success)}.legend-expense{background:#ef4444}.reglas-section{flex-direction:column;gap:20px;display:flex}.reglas-desc{color:var(--text-secondary);margin:0;font-size:13px;line-height:1.6}.regla-form{flex-wrap:wrap;gap:8px;display:flex}.regla-input{flex:1;min-width:180px}.regla-select{min-width:200px}.regla-btn{white-space:nowrap}.reglas-list{flex-direction:column;gap:8px;display:flex}.regla-item{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--border-radius-md);flex-wrap:wrap;align-items:center;gap:10px;padding:12px 16px;display:flex}.regla-keyword{color:var(--text-primary);background:#ffffff0d;border-radius:4px;padding:2px 8px;font-family:monospace;font-size:13px}.regla-arrow{color:var(--text-muted);font-size:14px}.regla-delete{color:var(--text-muted);cursor:pointer;transition:var(--transition-fast);background:0 0;border:none;border-radius:4px;margin-left:auto;padding:4px 8px;font-size:14px}.regla-delete:hover{color:#ef4444;background:#ef444426}.breakdown-layout{align-items:flex-start;gap:24px;display:flex}.donut-panel{flex-direction:column;align-items:center;gap:8px;min-width:160px;display:flex}.donut-svg{width:160px;height:160px}.donut-total-label{color:#ef4444;text-align:center;font-size:15px;font-weight:700}.breakdown-layout .breakdown-grid{flex:1;min-width:0}.filter-chips{flex-wrap:wrap;gap:6px;margin-bottom:10px;display:flex}.chip{border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;white-space:nowrap;font-size:12px;font-weight:500;font-family:var(--font-family);background:#ffffff0d;border-radius:99px;padding:5px 14px;transition:background .2s,color .2s,border-color .2s}.chip:hover{color:var(--text-primary);background:#ffffff17}.chip-active{color:var(--accent-light);background:#8b5cf626;border-color:#8b5cf666}.search-bar{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);align-items:center;margin-bottom:12px;padding:0 12px;transition:border-color .2s;display:flex;position:relative}.search-bar:focus-within{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}.search-icon{color:var(--text-muted);margin-right:8px;font-size:14px}.search-input{color:var(--text-primary);font-family:var(--font-family);background:0 0;border:none;outline:none;flex:1;padding:10px 0;font-size:13px}.search-input::placeholder{color:var(--text-muted)}.search-clear{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px;font-size:14px;line-height:1}.search-clear:hover{color:var(--text-primary)}.btn-manual-tx{color:var(--accent-light);border-radius:var(--border-radius-sm);cursor:pointer;white-space:nowrap;font-size:12px;font-weight:600;font-family:var(--font-family);background:#8b5cf61a;border:1px solid #8b5cf64d;margin-left:auto;padding:4px 12px;transition:background .2s,border-color .2s}.btn-manual-tx:hover{background:#8b5cf633;border-color:#8b5cf680}.tipo-tag{vertical-align:middle;letter-spacing:.03em;border-radius:99px;margin-left:6px;padding:1px 7px;font-size:10px;font-weight:700;display:inline-block}.tag-cobrar{color:#f59e0b;background:#f59e0b26;border:1px solid #f59e0b4d}.tag-no-gasto{color:var(--text-muted);border:1px solid var(--border-color);background:#ffffff0f}.tx-row{transition:background .15s}.tx-por-cobrar td:first-child{border-left:3px solid #f59e0b}.tx-no-gasto{opacity:.55}.tx-no-gasto td:first-child{border-left:3px solid #ffffff26}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#000000a6;justify-content:center;align-items:center;padding:16px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal-card{background:var(--bg-surface);border-radius:var(--border-radius-lg);border:1px solid #ffffff1a;width:100%;max-width:480px;max-height:90vh;padding:24px;animation:.2s slideUp;overflow-y:auto;box-shadow:0 24px 60px #00000080}.modal-card-form{max-width:420px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header-row{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.modal-close-btn{border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;background:#ffffff0f;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;transition:background .2s;display:flex}.modal-close-btn:hover{color:var(--text-primary);background:#ffffff1f}.modal-amount-row{align-items:baseline;gap:2px;display:flex}.modal-amount-input{font-family:var(--font-family);background:0 0;border:none;outline:none;width:180px;min-width:80px;font-size:28px;font-weight:800}.modal-merchant{color:var(--text-primary);margin-bottom:6px;font-size:15px;font-weight:600}.modal-meta-row{align-items:center;gap:10px;margin-bottom:16px;display:flex}.modal-date-input{border:1px solid var(--border-color);color:var(--text-secondary);font-family:var(--font-family);cursor:pointer;background:#ffffff0d;border-radius:8px;padding:4px 10px;font-size:13px}.modal-date-input:focus{border-color:var(--accent);outline:none}.modal-tipo-row{gap:6px;margin-bottom:16px;display:flex}.tipo-btn{border-radius:var(--border-radius-sm);cursor:pointer;font-size:11px;font-weight:600;font-family:var(--font-family);white-space:nowrap;border:1px solid var(--border-color);color:var(--text-muted);background:#ffffff0a;flex:1;padding:7px 4px;transition:background .2s,border-color .2s}.tipo-btn.tipo-gasto.active{color:var(--accent-light);background:#8b5cf626;border-color:#8b5cf680}.tipo-btn.tipo-cobrar.active{color:#f59e0b;background:#f59e0b26;border-color:#f59e0b80}.tipo-btn.tipo-no-gasto.active{color:var(--text-secondary);background:#ffffff14;border-color:#fff3}.modal-section-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;font-size:11px;font-weight:600}.modal-cat-grid{grid-template-columns:repeat(auto-fill,minmax(76px,1fr));gap:6px;max-height:220px;margin-bottom:14px;display:grid;overflow-y:auto}.modal-cat-btn{border:1px solid var(--border-color);border-radius:var(--border-radius-sm);cursor:pointer;font-family:var(--font-family);background:#ffffff0a;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;transition:background .15s,border-color .15s;display:flex}.modal-cat-btn:hover{background:#ffffff14}.modal-cat-active{border-color:var(--accent)!important;background:#8b5cf61f!important}.modal-cat-emoji{font-size:20px;line-height:1}.modal-cat-name{color:var(--text-secondary);text-align:center;font-size:10px;line-height:1.2}.modal-rule-label{color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);cursor:pointer;background:#ffffff0a;align-items:flex-start;gap:8px;margin-bottom:4px;padding:10px 12px;font-size:12px;display:flex}.modal-rule-label input{flex-shrink:0;margin-top:2px}.modal-rule-label em{color:var(--accent-light);font-style:normal}.modal-rule-label strong{color:var(--text-primary)}.manual-form{flex-direction:column;gap:12px;margin-top:12px;display:flex}.manual-tipo-toggle{border:1px solid var(--border-color);border-radius:var(--border-radius-sm);display:flex;overflow:hidden}.manual-tipo-toggle button{color:var(--text-muted);font-family:var(--font-family);cursor:pointer;background:#ffffff08;border:none;flex:1;padding:8px;font-size:13px;font-weight:600;transition:background .15s,color .15s}.manual-tipo-toggle button.active.egreso{color:#ef4444;background:#ef44441f}.manual-tipo-toggle button.active.ingreso{color:var(--success);background:#10b9811f}.period-selector{gap:4px;margin-bottom:16px;display:flex}.period-btn{border:1px solid var(--border-color);color:var(--text-secondary);border-radius:var(--border-radius-sm);cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font-family);background:#ffffff0d;padding:5px 14px;transition:background .2s,color .2s,border-color .2s}.period-btn:hover{color:var(--text-primary);background:#ffffff17}.period-btn-active{color:var(--accent-light);background:#8b5cf626;border-color:#8b5cf666}.breakdown-tx-count{color:var(--text-muted);border:1px solid var(--border-color);background:#ffffff0f;border-radius:99px;padding:1px 7px;font-size:10px;font-weight:600}.donut-legend{flex-direction:column;gap:4px;width:100%;margin-top:4px;display:flex}.donut-legend-item{align-items:center;gap:6px;display:flex}.donut-legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.presupuesto-row{flex-direction:column;gap:3px;margin-top:6px;display:flex}.presupuesto-bar-bg{background:#ffffff12;border-radius:99px;height:4px;overflow:hidden}.presupuesto-bar-fill{border-radius:99px;height:100%;transition:width .4s}.presupuesto-label{font-size:10px;font-weight:600}.config-block{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--border-radius-md);overflow:hidden}.config-block summary{color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;padding:12px 16px;font-size:13px;font-weight:600;list-style:none;transition:background .15s;display:flex}.config-block summary::-webkit-details-marker{display:none}.config-block summary:before{content:"▶";color:var(--text-muted);font-size:10px;transition:transform .2s}.config-block[open] summary:before{transform:rotate(90deg)}.config-block summary:hover{background:#ffffff08}.config-block-body{color:var(--text-secondary);padding:0 16px 16px;font-size:13px;line-height:1.7}.sql-block{border-radius:var(--border-radius-sm);color:#a78bfa;white-space:pre;background:#00000059;border:1px solid #ffffff14;margin-top:8px;padding:12px 14px;font-family:Courier New,monospace;font-size:12px;line-height:1.7;overflow-x:auto}.config-block-body code{color:#a78bfa;background:#ffffff14;border-radius:4px;padding:1px 6px;font-family:Courier New,monospace;font-size:12px}.grupos-config{border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background:#ffffff05;overflow:hidden}.grupos-config summary{color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;padding:10px 14px;font-size:12px;list-style:none}.grupos-config summary::-webkit-details-marker{display:none}.grupos-list{flex-direction:column;gap:8px;padding:8px 14px 12px;display:flex}.grupo-row{border-bottom:1px solid #ffffff0a;flex-wrap:wrap;align-items:center;gap:10px;padding:6px 0;display:flex}.grupo-row:last-child{border-bottom:none}.breakdown-groups{flex-direction:column;flex:1;gap:12px;min-width:0;display:flex}.breakdown-group{width:100%}.breakdown-group-header{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);border-bottom:1px solid var(--border-color);margin-bottom:6px;padding:0 0 6px;font-size:11px;font-weight:700}.cat-by-month-table{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--border-radius-md);overflow:hidden}.cbm-header,.cbm-row{grid-template-columns:160px repeat(var(--cbm-cols,6), 1fr);align-items:center;gap:8px;padding:10px 16px;display:grid}.cbm-header{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border-color);background:#ffffff0a;font-size:11px;font-weight:600}.cbm-row{border-bottom:1px solid var(--border-color)}.cbm-row:last-child{border-bottom:none}.cbm-cat-label{font-size:13px;font-weight:500}.cbm-month,.cbm-cell{text-align:center}.cbm-pct{font-size:13px;font-weight:600}.cbm-empty{color:var(--text-muted);font-size:13px}@media (width<=900px){.summary-card-value{font-size:24px}.transaction-table th:nth-child(3),.transaction-table td:nth-child(3){display:none}}@media (width<=640px){.app-container{gap:14px;padding:12px}.header-app{flex-flow:wrap;align-items:center;gap:8px;padding-bottom:12px}.logo-header h1{font-size:20px!important}.header-user{gap:8px}.user-email{text-overflow:ellipsis;white-space:nowrap;max-width:140px;font-size:11px;overflow:hidden}.btn-logout{padding:6px 10px;font-size:12px}.main-nav{gap:3px;padding:3px}.nav-btn{padding:8px 6px;font-size:12px}.summary-grid{grid-template-columns:repeat(2,1fr);gap:10px}.summary-card{gap:4px;padding:14px 12px}.summary-card-title{font-size:11px}.summary-card-value{font-size:20px}.month-btn{padding:6px 12px;font-size:12px}.control-panel{flex-direction:column;align-items:stretch;gap:10px;padding:12px}.btn-secondary{justify-content:center;font-size:13px}.section-title{font-size:16px}.table-container{border-radius:var(--border-radius-md)}.transaction-table thead{display:none}.transaction-table tbody tr{border-bottom:1px solid var(--border-color);grid-template-rows:auto auto auto;grid-template-columns:1fr auto;gap:3px 8px;padding:14px;display:grid;position:relative}.transaction-table tbody tr:last-child{border-bottom:none}.transaction-table tbody tr:hover td{background:0 0}.transaction-table td{vertical-align:middle;border:none;padding:0}.transaction-table td:first-child{color:var(--text-muted);grid-area:1/1;font-size:11px}.transaction-table td:nth-child(2){color:var(--text-primary);grid-area:2/1;font-size:15px;font-weight:600}.transaction-table td:nth-child(3){display:none}.transaction-table td:nth-child(4){grid-area:3/1;align-self:center}.transaction-table td:nth-child(5){grid-area:4/1;padding-top:4px}.transaction-table td:nth-child(6){text-align:right;white-space:nowrap;grid-area:1/2/3;align-self:center;font-size:15px;font-weight:700}.transaction-table td:nth-child(4),.transaction-table td:nth-child(5){flex-wrap:wrap;align-items:center;gap:6px;display:flex}.badge-source{padding:2px 6px;font-size:10px}.badge-category,.badge-category-btn{padding:3px 8px;font-size:11px}.breakdown-layout{flex-direction:column;align-items:center}.donut-panel{width:100%}.donut-svg{width:130px;height:130px}.breakdown-grid{grid-template-columns:1fr;width:100%}.filter-chips{flex-wrap:nowrap;padding-bottom:4px;overflow-x:auto}.chip{flex-shrink:0}.period-selector{flex-wrap:wrap}.modal-card{border-radius:var(--border-radius-md);max-width:100%;padding:16px}.modal-amount-input{width:140px;font-size:22px}.modal-cat-grid{grid-template-columns:repeat(auto-fill,minmax(65px,1fr))}.modal-tipo-row{flex-wrap:wrap}.tipo-btn{padding:6px 2px;font-size:10px}.cat-by-month-table{display:none}.regla-form{flex-direction:column}.regla-select,.regla-input{width:100%;min-width:unset}.regla-btn{justify-content:center;width:100%}.chart-container{gap:6px;height:140px;padding:12px 12px 0}.chart-label{font-size:10px}.chart-sublabel{font-size:9px}}
