:root{--blue: #0176D3;--blue-dark: #0165B8;--blue-light: #EEF4FF;--blue-mid: #D0E4F8;--green: #2E7D32;--green-light: #E8F5E9;--red: #C62828;--red-light: #FFEBEE;--orange: #E65100;--purple: #6A1B9A;--bg: #F3F3F3;--white: #FFFFFF;--border: #DDDBDA;--surface: #FAFAF9;--text: #1a1a1a;--text-mid: #3E3E3C;--text-muted: #706E6B;--text-light: #9E9E9E;--font: "Segoe UI", system-ui, -apple-system, sans-serif}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font);background:var(--bg);color:var(--text);height:100vh;overflow:hidden;display:flex;flex-direction:column;font-size:14px;line-height:1.5}#root{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-header{height:52px;background:var(--blue);display:flex;align-items:center;padding:0 1.25rem;gap:1rem;flex-shrink:0;box-shadow:0 2px 4px #0003;z-index:200}.header-logo{color:#fff;font-weight:800;font-size:.95rem;display:flex;align-items:center;gap:.5rem;white-space:nowrap}.header-logo-badge{background:#fff;color:var(--blue);border-radius:4px;padding:2px 8px;font-size:.72rem;font-weight:800}.module-switcher{position:absolute;left:50%;transform:translate(-50%);display:flex;gap:.25rem}.app-header{position:relative}.module-btn{color:#ffffffbf;background:#ffffff1a;border:none;padding:.3rem 1rem;border-radius:4px;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:.4rem;font-family:var(--font)}.module-btn:hover{background:#fff3;color:#fff}.module-btn.active{background:#fff;color:var(--blue)}.header-right{margin-left:auto;display:flex;align-items:center;gap:.75rem}.header-user{color:#ffffffd9;font-size:.82rem}.header-avatar{width:30px;height:30px;border-radius:50%;background:#ffb75e;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:800;color:#7a4100;cursor:pointer}.header-logout{color:#ffffffb3;font-size:.78rem;cursor:pointer;border:1px solid rgba(255,255,255,.3);border-radius:4px;padding:3px 10px;background:none;font-family:var(--font);transition:all .15s}.header-logout:hover{background:#ffffff1a;color:#fff}.app-layout{display:flex;flex:1;overflow:hidden;min-height:0}.app-layout>*{flex:1;min-width:0;min-height:0}.sidebar{width:200px;background:var(--white);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}.sidebar-section{padding:1rem .75rem .5rem}.sidebar-label{font-size:.68rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:0 .5rem;margin-bottom:.4rem}.nav-item{display:flex;align-items:center;gap:.6rem;padding:.48rem .75rem;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;color:var(--text-mid);transition:background .12s;margin-bottom:2px;-webkit-user-select:none;user-select:none}.nav-item:hover{background:var(--bg)}.nav-item.active{background:var(--blue-light);color:var(--blue);font-weight:700}.nav-icon{font-size:.9rem;width:18px;text-align:center;flex-shrink:0}.sidebar-divider{border:none;border-top:1px solid var(--border);margin:.4rem 1rem}.sidebar-bottom{margin-top:auto;padding:.75rem;border-top:1px solid var(--border)}.sidebar-bottom .nav-item{color:var(--text-muted);font-size:.82rem}.main-content{flex:1;overflow-y:auto;display:flex;flex-direction:column}.toolbar{background:var(--white);border-bottom:1px solid var(--border);padding:0 1.25rem;height:46px;display:flex;align-items:center;gap:.75rem;flex-shrink:0;position:sticky;top:0;z-index:100}.toolbar-title{font-size:.95rem;font-weight:700;color:var(--text);white-space:nowrap}.tabs-bar{display:flex}.tab-item{padding:0 1rem;height:46px;line-height:46px;font-size:.82rem;font-weight:600;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:color .15s;white-space:nowrap;-webkit-user-select:none;user-select:none}.tab-item:hover{color:var(--blue)}.tab-item.active{color:var(--blue);border-bottom-color:var(--blue)}.toolbar-right{margin-left:auto;display:flex;align-items:center;gap:.5rem}.btn{border-radius:4px;padding:.35rem .85rem;font-size:.8rem;font-weight:600;cursor:pointer;border:none;display:inline-flex;align-items:center;gap:.35rem;font-family:var(--font);transition:all .15s;white-space:nowrap}.btn-primary{background:var(--blue);color:#fff}.btn-primary:hover{background:var(--blue-dark)}.btn-secondary{background:var(--white);color:var(--blue);border:1px solid var(--blue)!important}.btn-secondary:hover{background:var(--blue-light)}.btn-ghost{background:var(--white);color:var(--text-mid);border:1px solid var(--border)!important}.btn-ghost:hover{background:var(--bg)}.btn-danger{background:var(--red-light);color:var(--red);border:1px solid #FFCDD2!important}.btn-danger:hover{background:#ffcdd2}.btn-sm{padding:.25rem .6rem;font-size:.75rem}.page-content{padding:1.1rem 1.25rem;flex:1}.kpi-strip{display:grid;gap:.65rem;margin-bottom:1.1rem}.kpi-strip-5{grid-template-columns:repeat(5,1fr)}.kpi-strip-6{grid-template-columns:repeat(6,1fr)}.kpi-strip-3{grid-template-columns:repeat(3,1fr)}.kpi-strip-4{grid-template-columns:repeat(4,1fr)}.kpi-card{background:var(--white);border:1px solid var(--border);border-radius:6px;padding:.85rem 1rem;border-left:4px solid transparent}.kpi-card.kpi-income{border-left-color:var(--green)}.kpi-card.kpi-expense{border-left-color:var(--red)}.kpi-card.kpi-balance{border-left-color:var(--blue)}.kpi-card.kpi-iva{border-left-color:var(--orange)}.kpi-card.kpi-retention{border-left-color:var(--purple)}.kpi-label{font-size:.7rem;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.35rem}.kpi-value{font-size:1.15rem;font-weight:800;letter-spacing:-.5px;color:var(--text)}.kpi-value.green{color:var(--green)}.kpi-value.red{color:var(--red)}.kpi-value.blue{color:var(--blue)}.kpi-value.orange{color:var(--orange)}.kpi-value.purple{color:var(--purple)}.kpi-sub{font-size:.7rem;color:var(--text-light);margin-top:.2rem}.filter-bar{background:var(--white);border:1px solid var(--border);border-radius:6px;padding:.6rem .9rem;margin-bottom:.85rem;display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.filter-label{font-size:.75rem;color:var(--text-muted);font-weight:700;white-space:nowrap}.filter-sep{color:var(--border)}.filter-input{border:1px solid var(--border);border-radius:4px;padding:.3rem .55rem;font-size:.8rem;color:var(--text);background:var(--white);outline:none;font-family:var(--font)}.filter-input:focus{border-color:var(--blue)}.chip{background:var(--bg);color:var(--text-mid);border:1px solid var(--border);border-radius:4px;padding:.22rem .6rem;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .12s;-webkit-user-select:none;user-select:none;font-family:var(--font)}.chip:hover{background:var(--blue-light);color:var(--blue);border-color:var(--blue-mid)}.chip.active{background:var(--blue);color:#fff;border-color:var(--blue)}.table-container{background:var(--white);border:1px solid var(--border);border-radius:6px;overflow:hidden}.table-bar{padding:.5rem .9rem;border-bottom:1px solid var(--border);background:var(--surface);display:flex;align-items:center;gap:.65rem}.table-count{font-size:.78rem;color:var(--text-muted)}.search-box{margin-left:auto;display:flex;align-items:center;gap:.35rem;border:1px solid var(--border);border-radius:4px;padding:.27rem .6rem;background:var(--white)}.search-box input{border:none;outline:none;font-size:.8rem;width:150px;font-family:var(--font);color:var(--text)}.search-icon{color:var(--text-light);font-size:.85rem}table{width:100%;border-collapse:collapse}thead tr{background:var(--surface);border-bottom:2px solid var(--border)}thead th{padding:.5rem .7rem;text-align:left;font-size:.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none}thead th:hover{color:var(--blue)}thead th.right{text-align:right}thead th.no-sort{cursor:default}thead th.no-sort:hover{color:var(--text-muted)}tbody tr{border-bottom:1px solid #F3F3F3;transition:background .1s}tbody tr:hover{background:#f8f8f8}tbody tr:last-child{border-bottom:none}tbody td{padding:.22rem .7rem;font-size:.82rem;color:var(--text-mid);vertical-align:middle}td.right{text-align:right;font-variant-numeric:tabular-nums}td.bold{font-weight:600;color:var(--text)}td.muted{color:var(--text-light);font-size:.78rem}tfoot tr{border-top:2px solid var(--border)}tfoot td{padding:.28rem .7rem;font-size:.8rem;font-weight:700;background:var(--surface)!important}.badge{display:inline-flex;align-items:center;padding:.15rem .5rem;border-radius:3px;font-size:.7rem;font-weight:700;white-space:nowrap}.badge-income{background:var(--green-light);color:var(--green)}.badge-expense{background:var(--red-light);color:var(--red)}.cat-pill{background:var(--bg);color:var(--text-mid);border-radius:3px;padding:.12rem .45rem;font-size:.7rem;font-weight:500}.bank-pill{border-radius:3px;padding:.12rem .45rem;font-size:.68rem;font-weight:700;white-space:nowrap}.bank-pill.nubank{background:#ede9fe;color:#4527a0}.bank-pill.davivienda{background:#ffebee;color:#b71c1c}.bank-pill.nequi{background:#fce4ec;color:#ad1457}.bank-pill.unknown{background:var(--bg);color:var(--text-muted)}.amount-pos{color:var(--green);font-weight:700}.amount-neg{color:var(--red);font-weight:700}.amount-neu{color:var(--text-mid);font-weight:500}.row-actions{display:flex;align-items:center;gap:.2rem}.row-btn{border:none;background:none;color:var(--text-light);cursor:pointer;padding:.22rem .3rem;border-radius:3px;font-size:.82rem;transition:all .12s;font-family:var(--font)}.row-btn:hover{background:var(--bg);color:var(--text)}.row-btn.danger:hover{background:var(--red-light);color:var(--red)}.split-layout{display:grid;grid-template-columns:1fr 320px;gap:.9rem}.panel{background:var(--white);border:1px solid var(--border);border-radius:6px;overflow:hidden;display:flex;flex-direction:column}.panel-header{background:var(--surface);border-bottom:1px solid var(--border);padding:.62rem 1rem;font-size:.82rem;font-weight:700;color:var(--text);display:flex;align-items:center;gap:.5rem;flex-shrink:0}.panel-body{padding:.85rem;flex:1;display:flex;flex-direction:column;gap:.8rem;overflow-y:auto}.panel-footer{padding:.65rem .85rem;background:var(--surface);border-top:1px solid var(--border);display:flex;gap:.5rem;justify-content:flex-end;flex-shrink:0}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}.form-group{display:flex;flex-direction:column;gap:.28rem}.form-label{font-size:.68rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.form-input{border:1px solid var(--border);border-radius:4px;padding:.42rem .65rem;font-size:.83rem;color:var(--text);outline:none;background:var(--white);font-family:var(--font);width:100%;transition:border-color .15s}.form-input:focus{border-color:var(--blue);box-shadow:0 0 0 2px #0176d31a}.form-input.highlight{border-color:var(--blue);font-weight:700}.upload-zone{border:2px dashed var(--border);border-radius:6px;padding:1.1rem;text-align:center;color:var(--text-light);font-size:.78rem;cursor:pointer;background:var(--surface);transition:all .15s}.upload-zone:hover,.upload-zone.dragging{border-color:var(--blue);background:var(--blue-light);color:var(--blue)}.upload-zone-lg{padding:2rem 1rem}.upload-icon{font-size:1.5rem;margin-bottom:.4rem}.upload-title{font-weight:700;font-size:.85rem;margin-bottom:.25rem}.upload-sub{font-size:.72rem;color:var(--text-light)}.bank-tabs{display:flex;gap:.4rem}.bank-tab{flex:1;padding:.4rem;text-align:center;border:1px solid var(--border);border-radius:4px;font-size:.72rem;font-weight:700;cursor:pointer;color:var(--text-muted);background:var(--white);font-family:var(--font);transition:all .15s}.bank-tab:hover{border-color:var(--blue);color:var(--blue)}.bank-tab.dav{background:#b71c1c;color:#fff;border-color:#b71c1c}.bank-tab.nu{background:#4527a0;color:#fff;border-color:#4527a0}.bank-tab.neq{background:#ad1457;color:#fff;border-color:#ad1457}.preview-list{max-height:260px;overflow-y:auto;border:1px solid var(--border);border-radius:6px}.preview-item{display:flex;align-items:center;gap:.5rem;padding:.42rem .65rem;border-bottom:1px solid #F3F3F3;font-size:.78rem}.preview-item:last-child{border-bottom:none}.preview-date{color:var(--text-light);white-space:nowrap;min-width:68px;font-size:.74rem}.preview-desc{flex:1;color:var(--text-mid);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-cat{background:var(--bg);color:var(--text-muted);border-radius:3px;padding:.1rem .4rem;font-size:.66rem;font-weight:600;white-space:nowrap}.preview-amount{font-weight:700;white-space:nowrap;min-width:85px;text-align:right;font-size:.8rem}.cat-body{padding:1rem;display:flex;flex-direction:column;gap:.7rem}.cat-row{display:flex;align-items:center;gap:.75rem}.cat-name{width:180px;font-size:.78rem;color:var(--text-mid);font-weight:500;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cat-bar-wrap{flex:1;background:var(--bg);border-radius:3px;height:10px;overflow:hidden}.cat-bar{height:100%;border-radius:3px;transition:width .4s ease}.cat-amount{width:95px;text-align:right;font-size:.78rem;font-weight:700;color:var(--red);flex-shrink:0}.cat-count{width:38px;text-align:right;font-size:.72rem;color:var(--text-light);flex-shrink:0}.personal-layout{display:grid;grid-template-columns:340px 1fr;gap:.9rem}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slideInRight{0%{opacity:0;transform:translate(60px)}to{opacity:1;transform:translate(0)}}.hamburger-btn{display:none;align-items:center;justify-content:center;background:none;border:1px solid var(--border);border-radius:5px;cursor:pointer;padding:.3rem .45rem;color:var(--text-mid);flex-shrink:0}.hamburger-btn:hover{background:var(--hover)}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000059;z-index:299}.sidebar-overlay.open{display:block}@media(max-width:900px){.hamburger-btn{display:flex}.sidebar{position:fixed;top:0;left:0;bottom:0;z-index:300;transform:translate(-100%);transition:transform .22s ease;box-shadow:2px 0 12px #0000001f}.sidebar.open{transform:translate(0)}.split-layout,.personal-layout{grid-template-columns:1fr}.kpi-strip-5{grid-template-columns:repeat(2,1fr)}.kpi-strip-6{grid-template-columns:repeat(3,1fr)}.kpi-strip-3,.kpi-strip-4{grid-template-columns:repeat(2,1fr)}.page-content{padding:.75rem}body{overflow:auto}.toolbar{height:auto;flex-wrap:wrap;padding:.55rem .85rem;gap:.4rem}.tabs-bar{order:3;width:100%;border-top:1px solid var(--border)}.tab-item{height:38px;line-height:38px;padding:0 .75rem;font-size:.78rem}.toolbar-right{margin-left:auto}.form-row{grid-template-columns:1fr}.table-container{overflow-x:auto}table{font-size:.76rem;min-width:560px}thead th,tbody td{padding:.4rem .5rem}.filter-bar{flex-wrap:wrap;gap:.4rem;overflow-x:auto}.filter-input{min-width:0}input[type=date]{min-width:130px}}@media(max-width:540px){.kpi-strip-5,.kpi-strip-6{grid-template-columns:1fr 1fr}.kpi-strip-3{grid-template-columns:1fr}.kpi-strip-4,.kpi-strip{grid-template-columns:1fr 1fr}}.app-shell{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-body{display:flex;flex:1;overflow:hidden;position:relative;min-height:0}.app-content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;min-height:0}.app-content>*{flex:1;min-width:0;min-height:0}.mobile-topbar{display:none;align-items:center;gap:.75rem;padding:0 1rem;height:48px;background:var(--blue);flex-shrink:0;color:#fff;z-index:100}.mobile-menu-btn{background:#ffffff26;border:none;border-radius:6px;cursor:pointer;padding:.3rem .42rem;color:#fff;display:flex;align-items:center}.mobile-menu-btn:hover{background:#ffffff40}.global-sidebar{width:52px;min-width:52px;background:var(--white);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;transition:width .22s cubic-bezier(.4,0,.2,1);z-index:100}.global-sidebar:hover,.global-sidebar.has-open-menu{width:210px}.gsb-label{opacity:0;white-space:nowrap;transition:opacity .15s ease;pointer-events:none}.global-sidebar:hover .gsb-label,.global-sidebar.open .gsb-label,.global-sidebar.has-open-menu .gsb-label{opacity:1;pointer-events:auto}.gsb-logo{display:flex;align-items:center;gap:.65rem;padding:.85rem .9rem;border-bottom:1px solid var(--border);flex-shrink:0}.gsb-logo-badge{background:var(--blue);color:#fff;border-radius:6px;width:26px;height:26px;min-width:26px;display:flex;align-items:center;justify-content:center;font-size:.76rem;font-weight:800;flex-shrink:0}.gsb-logo .gsb-label{font-size:.9rem;font-weight:800;color:var(--text)}.gsb-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:.4rem 0}.gsb-item{display:flex;align-items:center;gap:.7rem;padding:.56rem .9rem;cursor:pointer;transition:background .12s;-webkit-user-select:none;user-select:none;min-width:0}.gsb-item:hover{background:var(--bg)}.gsb-item.active{background:var(--blue-light)}.gsb-item.active .gsb-icon,.gsb-item.active>.gsb-label{color:var(--blue)!important;font-weight:700}.gsb-icon{width:22px;height:22px;min-width:22px;display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--text-mid);flex-shrink:0}.gsb-item>.gsb-label{font-size:.85rem;font-weight:500;color:var(--text-mid)}.gsb-subnav{overflow:hidden;max-height:0;transition:max-height .22s ease;background:#f7f9ff}.global-sidebar:hover .gsb-subnav,.global-sidebar.open .gsb-subnav,.global-sidebar.has-open-menu .gsb-subnav{max-height:200px}.gsb-subitem{display:flex;align-items:center;gap:.6rem;padding:.36rem .9rem .36rem 2.6rem;cursor:pointer;transition:background .1s;-webkit-user-select:none;user-select:none}.gsb-subitem:hover{background:#eaefff}.gsb-subitem.active{background:var(--blue-light)}.gsb-subitem .gsb-icon{width:15px;height:15px;min-width:15px;color:var(--text-light)}.gsb-subitem>.gsb-label{font-size:.79rem;font-weight:500;color:var(--text-mid)}.gsb-subitem.active .gsb-icon,.gsb-subitem.active>.gsb-label{color:var(--blue)!important;font-weight:700}.gsb-bottom{border-top:1px solid var(--border);padding:.35rem 0;flex-shrink:0}.gsb-user-expanded{border-bottom:1px solid var(--border);padding-bottom:.2rem;margin-bottom:.2rem}.gsb-user-expanded .gsb-item{padding:.42rem .9rem}.gsb-user-expanded .gsb-item>.gsb-label{font-size:.82rem}.gsb-logout .gsb-icon,.gsb-logout>.gsb-label{color:var(--red)!important}.gsb-user{display:flex;align-items:center;gap:.7rem;padding:.52rem .9rem;cursor:pointer;transition:background .12s}.gsb-user:hover{background:var(--bg)}.gsb-avatar{width:26px;height:26px;min-width:26px;border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:800;flex-shrink:0;overflow:hidden}.gsb-username{font-size:.82rem;font-weight:600;color:var(--text-mid);overflow:hidden;text-overflow:ellipsis}.gsb-overlay{position:fixed;inset:0;background:#00000061;z-index:299}@media(max-width:900px){.mobile-topbar{display:flex}.global-sidebar{position:fixed;top:0;left:0;bottom:0;width:230px;min-width:230px;transform:translate(-100%);transition:transform .22s ease;box-shadow:4px 0 20px #00000026;z-index:300}.global-sidebar:hover{width:230px}.global-sidebar.open{transform:translate(0)}.global-sidebar.open .gsb-label{opacity:1;pointer-events:auto}.global-sidebar.open .gsb-subnav{max-height:200px}}
