:root{--color-primary:#1e40af;--color-primary-dark:#1e3a8a;--color-income:#16a34a;--color-income-bg:#dcfce7;--color-expense:#dc2626;--color-expense-bg:#fee2e2;--color-warning:#d97706;--color-warning-bg:#fef3c7;--color-projected:#7c3aed;--color-projected-bg:#ede9fe;--color-detracciones:#d97706;--color-detracciones-bg:#fef3c7;--color-balance:#1e40af;--color-balance-bg:#dbeafe;--color-bg:#f1f5f9;--color-surface:#fff;--color-text:#0f172a;--color-text-secondary:#64748b;--color-border:#e2e8f0;--color-hover:#f8fafc;--color-sidebar-bg:#0f172a;--color-sidebar-text:#e2e8f0;--color-sidebar-hover:hsla(0,0%,100%,.08);--color-sidebar-active:#1e40af;--color-overlay:rgba(0,0,0,.5);--font-sans:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--text-xs:0.75rem;--text-sm:0.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-full:9999px;--shadow-sm:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);--shadow-md:0 4px 6px rgba(0,0,0,.07),0 2px 4px rgba(0,0,0,.06);--shadow-lg:0 10px 15px rgba(0,0,0,.1),0 4px 6px rgba(0,0,0,.08);--sidebar-width:260px;--header-height:56px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text);line-height:1.6}.app,body{min-height:100vh}.app{display:grid;grid-template-columns:var(--sidebar-width) 1fr}.sidebar{background-color:var(--color-sidebar-bg);color:var(--color-sidebar-text);width:var(--sidebar-width);position:fixed;top:0;left:0;height:100vh;overflow-y:auto;display:flex;flex-direction:column;z-index:200;transition:transform .3s ease}.sidebar-logo{gap:var(--space-3);padding:var(--space-5) var(--space-5);border-bottom:1px solid hsla(0,0%,100%,.1)}.sidebar-logo,.sidebar-logo-icon{display:flex;align-items:center;flex-shrink:0}.sidebar-logo-icon{font-size:var(--text-xl);width:40px;height:40px;background:var(--color-primary);border-radius:var(--radius-md);justify-content:center}.sidebar-logo-text{font-weight:700;font-size:var(--text-base);line-height:1.2;color:#fff}.sidebar-logo-text span{display:block;font-size:var(--text-xs);font-weight:400;color:var(--color-sidebar-text);opacity:.7}.sidebar-nav{list-style:none;padding:var(--space-3) 0;flex:1 1}.sidebar-nav li{padding:0 var(--space-3)}.sidebar-nav li a,.sidebar-nav li button{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);border:none;border-left:3px solid transparent;background:none;color:var(--color-sidebar-text);font-size:var(--text-sm);font-family:var(--font-sans);cursor:pointer;border-radius:var(--radius-sm);text-align:left;transition:background .15s,border-color .15s,color .15s;text-decoration:none}.sidebar-nav li a:hover,.sidebar-nav li button:hover{background:var(--color-sidebar-hover);color:#fff}.sidebar-nav li a.active,.sidebar-nav li button.active{background:var(--color-sidebar-active);border-left-color:#60a5fa;color:#fff}.sidebar-section-title{padding:var(--space-4) var(--space-6) var(--space-2)!important;font-size:var(--text-xs)!important;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:hsla(0,0%,100%,.4)!important;pointer-events:none}.sidebar-section-title button{display:none!important}.nav-icon{font-size:var(--text-base);width:20px;text-align:center;flex-shrink:0}.main{grid-column:2;padding:var(--space-6);overflow-y:auto;min-height:100vh;display:flex;flex-direction:column;gap:var(--space-6)}.mobile-header{display:none;position:-webkit-sticky;position:sticky;top:0;z-index:150;background:var(--color-sidebar-bg);color:#fff;height:var(--header-height);align-items:center;padding:0 var(--space-4);gap:var(--space-3);box-shadow:var(--shadow-sm)}.hamburger{background:none;border:none;color:#fff;font-size:var(--text-xl);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-sm);line-height:1}.overlay{display:none;position:fixed;inset:0;background:var(--color-overlay);z-index:190}.overlay.active{display:block}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap}.page-header h1{font-size:var(--text-2xl);font-weight:700;color:var(--color-text);line-height:1.2}.page-header p{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.header-actions{flex-wrap:wrap}.header-actions,.section-header{display:flex;align-items:center;gap:var(--space-3)}.section-header{justify-content:space-between}.section-title{font-size:var(--text-lg);font-weight:600;color:var(--color-text)}.metrics-grid{display:grid;grid-template-columns:repeat(5,1fr);grid-gap:var(--space-4);gap:var(--space-4)}.metric-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--space-2)}.metric-card-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.metric-card-label{font-size:var(--text-sm);color:var(--color-text-secondary);font-weight:500;line-height:1.3}.metric-card-icon{width:36px;height:36px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:var(--text-base);flex-shrink:0}.metric-card-icon.balance{background:var(--color-balance-bg)}.metric-card-icon.income{background:var(--color-income-bg)}.metric-card-icon.expense{background:var(--color-expense-bg)}.metric-card-icon.projected{background:var(--color-projected-bg)}.metric-card-icon.detracciones{background:var(--color-detracciones-bg)}.metric-card-value{font-size:var(--text-2xl);font-weight:700;line-height:1.1}.metric-card-value.positive{color:var(--color-income)}.metric-card-value.negative{color:var(--color-expense)}.metric-card-value.neutral{color:var(--color-text)}.metric-card-value.warning{color:var(--color-warning)}.metric-card-sub{font-size:var(--text-xs);color:var(--color-text-secondary)}.progress-bar-container{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.progress-visual{display:flex;flex-direction:column;gap:var(--space-3)}.progress-labels{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);font-size:var(--text-sm);color:var(--color-text-secondary);flex-wrap:wrap}.progress-track{display:flex;height:28px;border-radius:var(--radius-full);overflow:hidden;background:var(--color-border)}.progress-fill-income{background:var(--color-income);border-radius:var(--radius-full) 0 0 var(--radius-full)}.progress-fill-expense,.progress-fill-income{display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);color:#fff;font-weight:600;transition:width .5s ease;min-width:0;overflow:hidden;white-space:nowrap}.progress-fill-expense{background:var(--color-expense);border-radius:0 var(--radius-full) var(--radius-full) 0}.progress-legend{gap:var(--space-5);flex-wrap:wrap}.legend-item,.progress-legend{display:flex;align-items:center}.legend-item{gap:var(--space-2);font-size:var(--text-xs);color:var(--color-text-secondary)}.legend-dot{width:10px;height:10px;border-radius:var(--radius-full);flex-shrink:0}.legend-dot.income{background:var(--color-income)}.legend-dot.expense{background:var(--color-expense)}.legend-dot.remaining{background:var(--color-border);border:1px solid #94a3b8}.bank-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:var(--space-4);gap:var(--space-4)}.bank-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--space-3)}.bank-card-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.bank-card-name{font-size:var(--text-sm);font-weight:600;color:var(--color-text)}.bank-card-type{font-size:var(--text-xs);color:var(--color-text-secondary);background:var(--color-bg);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm)}.bank-card-balance{font-size:var(--text-xl);font-weight:700;color:var(--color-text)}.bank-card-currency{font-size:var(--text-xs);color:var(--color-text-secondary)}.bank-card-actions{display:flex;gap:var(--space-2);margin-top:var(--space-1)}.table-container{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);overflow:hidden}.table-scroll{overflow-x:auto;width:100%}table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}thead{background:var(--color-bg)}thead th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-secondary);white-space:nowrap}tbody tr{border-top:1px solid var(--color-border);transition:background .1s}tbody tr:hover{background:var(--color-hover)}tbody td{padding:var(--space-3) var(--space-4);color:var(--color-text);vertical-align:middle}.text-right{text-align:right}.table-empty{text-align:center;color:var(--color-text-secondary);padding:var(--space-10) var(--space-4);font-size:var(--text-sm)}.status-badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600}.status-badge.pending{background:var(--color-warning-bg);color:var(--color-warning)}.status-badge.executed{background:var(--color-income-bg);color:var(--color-income)}.filters-row{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.tabs{display:inline-flex;gap:0;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;background:var(--color-surface)}.tab{padding:var(--space-2) var(--space-4);border:none;background:none;font-size:var(--text-sm);font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;transition:background .15s,color .15s;border-right:1px solid var(--color-border)}.tab:last-child{border-right:none}.tab:hover{background:var(--color-hover);color:var(--color-text)}.tab.active{background:var(--color-primary);color:#fff;font-weight:600}.filter-input,.filter-select{padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm);font-family:var(--font-sans);color:var(--color-text);background:var(--color-surface);outline:none;transition:border-color .15s,box-shadow .15s;min-width:160px}.filter-input:focus,.filter-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(30,64,175,.12)}.btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border:1px solid transparent;border-radius:var(--radius-md);font-size:var(--text-sm);font-family:var(--font-sans);font-weight:500;cursor:pointer;transition:background .15s,border-color .15s,color .15s,box-shadow .15s;white-space:nowrap;text-decoration:none}.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark)}.btn-income{background:var(--color-income-bg);color:var(--color-income);border-color:rgba(22,163,74,.3)}.btn-income:hover{background:#bbf7d0}.btn-expense{background:var(--color-expense-bg);color:var(--color-expense);border-color:rgba(220,38,38,.3)}.btn-expense:hover{background:#fecaca}.btn-ghost{background:none;color:var(--color-text-secondary);border-color:var(--color-border)}.btn-ghost:hover{background:var(--color-hover);color:var(--color-text)}.btn-danger{background:var(--color-expense-bg);color:var(--color-expense);border-color:rgba(220,38,38,.3)}.btn-danger:hover{background:#fecaca}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--text-xs)}.modal-backdrop{display:none;position:fixed;inset:0;background:var(--color-overlay);z-index:300;align-items:center;justify-content:center;padding:var(--space-4)}.modal,.modal-backdrop.open{display:flex}.modal{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:540px;max-height:calc(100vh - var(--space-8));flex-direction:column;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border);flex-shrink:0}.modal-title{font-size:var(--text-lg);font-weight:600;color:var(--color-text)}.modal-close{background:none;border:none;font-size:var(--text-lg);cursor:pointer;color:var(--color-text-secondary);padding:var(--space-1);border-radius:var(--radius-sm);line-height:1;transition:color .15s,background .15s}.modal-close:hover{color:var(--color-text);background:var(--color-bg)}.modal-body{padding:var(--space-6);overflow-y:auto;flex:1 1;display:flex;flex-direction:column;gap:var(--space-4)}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border);flex-shrink:0}.form-group{display:flex;flex-direction:column;gap:var(--space-1)}.form-label{font-size:var(--text-sm);font-weight:500;color:var(--color-text)}.required{color:var(--color-expense);margin-left:var(--space-1)}.form-input,.form-select{padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm);font-family:var(--font-sans);color:var(--color-text);background:var(--color-surface);outline:none;transition:border-color .15s,box-shadow .15s;width:100%}.form-input:focus,.form-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(30,64,175,.12)}.form-input.invalid,.form-select.invalid{border-color:var(--color-expense)}.form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--space-4);gap:var(--space-4)}.form-error{font-size:var(--text-xs);color:var(--color-expense);display:none}.form-error.visible,.invalid+.form-error{display:block}.form-hint{font-size:var(--text-xs);color:var(--color-text-secondary)}.type-toggle{display:flex;gap:var(--space-3)}.type-toggle-option{flex:1 1}.type-toggle-option input[type=radio]{position:absolute;opacity:0;width:0;height:0}.type-toggle-option label{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-sm);font-weight:500;transition:border-color .15s,background .15s}.type-toggle-option input[type=radio]:checked+label.income-label{border-color:var(--color-income);background:var(--color-income-bg);color:var(--color-income)}.type-toggle-option input[type=radio]:checked+label.expense-label{border-color:var(--color-expense);background:var(--color-expense-bg);color:var(--color-expense)}.month-selector{position:relative}.month-selector select{padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-sm);font-family:var(--font-sans);color:var(--color-text);background:var(--color-surface);cursor:pointer;outline:none}.month-selector select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(30,64,175,.12)}.toast-container{position:fixed;bottom:var(--space-5);right:var(--space-5);display:flex;flex-direction:column;gap:var(--space-2);z-index:400;pointer-events:none}.toast{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);background:var(--color-text);color:#fff;font-size:var(--text-sm);font-weight:500;box-shadow:var(--shadow-lg);pointer-events:auto;animation:slideInToast .25s ease}.toast.success{background:var(--color-income)}.toast.error{background:var(--color-expense)}.toast.warning{background:var(--color-warning)}@keyframes slideInToast{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media (max-width:1024px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.app{grid-template-columns:1fr}.main{grid-column:1}.mobile-header{display:flex;grid-column:1}.bank-grid,.metrics-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.main{padding:var(--space-4);gap:var(--space-4)}.bank-grid,.metrics-grid{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start}.header-actions{width:100%}.form-row{grid-template-columns:1fr}.filters-row{flex-direction:column;align-items:stretch}.filter-input,.filter-select{min-width:unset;width:100%}.modal{max-width:100%;margin:var(--space-4)}}