*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-base: #0b0b18;--bg-surface: #0f0f20;--bg-card: #131326;--bg-hover: #1a1a35;--sidebar-bg: #07070f;--sidebar-act: #111130;--text-1: #eeeeff;--text-2: #9090b8;--text-3: #54547e;--green: #00e5a0;--red: #ff4d6a;--orange: #ff8c42;--blue: #4da6ff;--purple: #9f7aea;--teal: #00c8d4;--yellow: #f6c90e;--pink: #f687b3;--slate: #718096;--border: rgba(255,255,255,.055);--border2: rgba(255,255,255,.1);--r: 12px;--r-s: 8px;--r-xs: 5px;--ff-display: "Syne", sans-serif;--ff-body: "DM Sans", sans-serif;--ff-mono: "JetBrains Mono", monospace;color-scheme:dark}html[data-theme=light]{--bg-base: #f4f5fb;--bg-surface: #ffffff;--bg-card: #ffffff;--bg-hover: #eef0f9;--sidebar-bg: #eef0f9;--sidebar-act:#e2e5f5;--text-1: #0d0d1e;--text-2: #5a5a80;--text-3: #aaaac4;--green: #00a86b;--red: #e63650;--orange: #d97020;--blue: #2e7fd4;--purple: #7050cc;--teal: #0098ac;--yellow: #b08800;--pink: #cc4488;--slate: #4a5568;--border: rgba(0, 0, 0, .07);--border2: rgba(0, 0, 0, .13);color-scheme:light}html,body{height:100%}body{background:var(--bg-base);color:var(--text-1);font-family:var(--ff-body);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}#root{height:100%}button{font-family:inherit}::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-3);border-radius:2px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes fade-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.app-layout{display:flex;height:100vh;overflow:hidden}.main-content{flex:1;overflow-y:auto;padding:26px 26px 48px;display:flex;flex-direction:column;gap:16px}.sidebar{width:62px;background:var(--sidebar-bg);border-right:1px solid var(--border);display:flex;flex-direction:column;align-items:center;padding:14px 0;flex-shrink:0}.sidebar-logo{width:38px;height:38px;display:flex;align-items:center;justify-content:center;margin-bottom:20px}.sidebar-nav{display:flex;flex-direction:column;gap:2px;flex:1;align-items:center;width:100%;padding:0 8px}.sidebar-bottom{display:flex;flex-direction:column;align-items:center;gap:2px;width:100%;padding:0 8px}.sb-btn{width:100%;height:40px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--r-s);color:var(--text-2);cursor:pointer;transition:background .15s,color .15s;text-decoration:none}.sb-btn:hover{background:var(--bg-hover);color:var(--text-1)}.sb-btn.active{background:var(--sidebar-act);color:var(--text-1)}.gmail-indicator-btn{position:relative}.gmail-dot{position:absolute;bottom:6px;right:6px;width:7px;height:7px;border-radius:50%;border:1.5px solid var(--sidebar-bg);transition:background .4s,box-shadow .4s}.top-bar{display:flex;align-items:center;gap:12px;margin-bottom:4px}.greeting{font-family:var(--ff-display);font-size:21px;font-weight:700;letter-spacing:-.4px}.demo-tag{font-family:var(--ff-mono);font-size:10px;padding:3px 9px;background:#ff8c421f;color:var(--orange);border:1px solid rgba(255,140,66,.25);border-radius:100px}.page-title{font-family:var(--ff-display);font-size:20px;font-weight:700;color:var(--text-1);margin-bottom:4px}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);padding:18px 20px 16px;display:flex;flex-direction:column;gap:6px;animation:fade-up .35s ease both}.stat-card:nth-child(2){animation-delay:.05s}.stat-card:nth-child(3){animation-delay:.1s}.stat-label{font-family:var(--ff-mono);font-size:9.5px;font-weight:600;letter-spacing:1.3px;color:var(--text-2);text-transform:uppercase}.stat-value{font-family:var(--ff-mono);font-size:30px;font-weight:600;letter-spacing:-1.5px;line-height:1}.stat-sub{font-size:12px;color:var(--text-2)}.charts-row{display:grid;grid-template-columns:1.55fr 1fr;gap:12px}.panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);padding:18px 20px;animation:fade-up .4s ease both}.panel-title{font-family:var(--ff-mono);font-size:9.5px;font-weight:600;letter-spacing:1.3px;color:var(--text-2);text-transform:uppercase;margin-bottom:16px}.chart-tooltip{background:var(--bg-card);border:1px solid var(--border2);border-radius:var(--r-s);padding:8px 12px;display:flex;flex-direction:column;gap:2px;box-shadow:0 4px 16px #0003}.chart-tooltip-label{font-size:11px;color:var(--text-2)}.chart-tooltip-value{font-family:var(--ff-mono);font-size:15px;font-weight:600;color:var(--text-1)}.category-list{display:flex;flex-direction:column;gap:13px}.category-row{display:flex;align-items:center;gap:10px}.cat-emoji{font-size:17px;width:22px;text-align:center;flex-shrink:0}.cat-info{flex:1;display:flex;flex-direction:column;gap:5px}.cat-header{display:flex;justify-content:space-between;align-items:baseline}.cat-name{font-size:13px;color:var(--text-1)}.cat-amount{font-family:var(--ff-mono);font-size:12px;color:var(--text-2)}.cat-bar-track{height:3px;background:var(--border2);border-radius:2px;overflow:hidden}.cat-bar-fill{height:100%;border-radius:2px;transition:width .7s cubic-bezier(.16,1,.3,1)}.tx-list{display:flex;flex-direction:column}.tx-row{display:flex;align-items:center;gap:14px;padding:13px 0;border-bottom:1px solid var(--border);animation:fade-up .3s ease both}.tx-row:last-child{border-bottom:none}.tx-icon{width:40px;height:40px;border-radius:var(--r-s);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.tx-info{flex:1;display:flex;flex-direction:column;gap:5px}.tx-merchant{font-size:14px;font-weight:500;color:var(--text-1)}.tx-badge{display:inline-flex;align-items:center;font-size:11px;font-weight:500;padding:2px 8px;border-radius:100px;width:fit-content}.tx-desc{font-size:12px;color:var(--text-2);line-height:1.3}.tx-right{display:flex;flex-direction:column;align-items:flex-end;gap:3px}.tx-amount{font-family:var(--ff-mono);font-size:14px;font-weight:500;color:var(--red)}.tx-date{font-size:11px;color:var(--text-2)}.loading-wrap{flex:1;display:flex;align-items:center;justify-content:center}.spinner{width:28px;height:28px;border:2px solid var(--border2);border-top-color:var(--green);border-radius:50%;animation:spin .7s linear infinite}.page-gastos{display:flex;flex-direction:column;gap:14px}.page-top{display:flex;justify-content:space-between;align-items:center}.sync-btn{display:flex;align-items:center;gap:6px;font-size:13px;font-family:var(--ff-body);padding:7px 14px;background:var(--bg-card);border:1px solid var(--border2);border-radius:var(--r-s);color:var(--text-2);cursor:pointer;transition:background .15s,color .15s}.sync-btn:hover{background:var(--bg-hover);color:var(--text-1)}.sync-btn:disabled{opacity:.6;cursor:not-allowed}.filter-bar{display:flex;gap:8px;flex-wrap:wrap}.filter-badge{display:flex;flex-direction:column;align-items:center;gap:1px;font-size:13px;padding:6px 14px;background:transparent;border:1px solid var(--border2);border-radius:var(--r-s);color:var(--text-2);cursor:pointer;transition:all .15s;font-family:var(--ff-body)}.filter-badge:hover{border-color:var(--text-2);color:var(--text-1)}.filter-badge-amount{font-family:var(--ff-mono);font-size:10px;opacity:.75}.expense-list{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden}.expense-item{display:flex;align-items:center;gap:14px;padding:13px 16px;border-bottom:1px solid var(--border);animation:fade-up .25s ease both}.expense-item:last-child{border-bottom:none}.exp-icon{width:40px;height:40px;border-radius:var(--r-s);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.exp-info{flex:1;display:flex;flex-direction:column;gap:5px}.exp-merchant{font-size:14px;font-weight:500;color:var(--text-1)}.exp-badge{display:inline-flex;font-size:11px;font-weight:500;padding:2px 8px;border-radius:100px;width:fit-content}.exp-right{display:flex;flex-direction:column;align-items:flex-end;gap:3px}.exp-amount{font-family:var(--ff-mono);font-size:14px;font-weight:500;color:var(--red)}.exp-date{font-size:11px;color:var(--text-2)}.empty-msg{padding:32px;text-align:center;color:var(--text-2);font-size:14px}.fab-bar{padding-top:4px}.fab-btn{width:100%;padding:14px;background:var(--bg-card);border:1px solid var(--border2);border-radius:var(--r);color:var(--text-1);font-size:14px;font-weight:500;cursor:pointer;transition:background .15s;font-family:var(--ff-body)}.fab-btn:hover{background:var(--bg-hover);border-color:var(--green);color:var(--green)}.page-agregar{display:flex;flex-direction:column;gap:18px}.scanner-zone{border:2px dashed rgba(0,229,160,.35);border-radius:var(--r);background:#00e5a00a;padding:32px 24px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:border-color .2s,background .2s;text-align:center}.scanner-zone:hover{border-color:#00e5a099;background:#00e5a014}.scanner-zone.done{border-color:#00e5a080;background:#00e5a00f}html[data-theme=light] .scanner-zone{border-color:#00a86b66;background:#00a86b0d}html[data-theme=light] .scanner-zone:hover{border-color:#00a86ba6;background:#00a86b1a}html[data-theme=light] .scanner-zone.done{border-color:#00a86b8c;background:#00a86b14}.scanner-icon{font-size:32px;line-height:1}.scanner-title{font-size:15px;font-weight:500;color:var(--text-1)}.scanner-sub{font-size:13px;color:var(--text-2)}.manual-divider{display:flex;align-items:center;gap:12px;color:var(--text-3);font-size:12px}.manual-divider:before,.manual-divider:after{content:"";flex:1;height:1px;background:var(--border)}.manual-form{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);padding:20px;display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:12px;color:var(--text-2);font-family:var(--ff-mono)}.form-group input,.form-group select{background:var(--bg-surface);border:1px solid var(--border2);border-radius:var(--r-s);padding:10px 12px;color:var(--text-1);font-size:14px;font-family:var(--ff-body);outline:none;transition:border-color .15s}.form-group input:focus,.form-group select:focus{border-color:var(--green)}.form-group select{cursor:pointer}.form-group input[type=date],.eem-input[type=date]{color-scheme:inherit}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.submit-btn{padding:13px;background:var(--green);border:none;border-radius:var(--r-s);color:#07120e;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s;font-family:var(--ff-body)}.submit-btn:hover{opacity:.9}.panel-header-row{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:4px}.panel-header-row .panel-title{margin-bottom:0}.panel-grand-total{font-family:var(--ff-mono);font-size:22px;font-weight:600;color:var(--text-1);letter-spacing:-1px;margin:4px 0 0}.month-selector{display:flex;gap:6px;flex-wrap:wrap}.month-btn{padding:4px 12px;border-radius:20px;border:1px solid rgba(255,255,255,.12);background:transparent;color:var(--text-2);font-size:12px;cursor:pointer;transition:background .2s,color .2s,border-color .2s;font-family:var(--ff-body)}.month-btn:hover{background:#ffffff12;color:var(--text-1)}.month-btn.active{background:var(--green);color:#0b0b18;border-color:var(--green);font-weight:600}.empty-msg{color:var(--text-3);font-size:14px;padding:32px 0;text-align:center}.pie-wrap{display:flex;align-items:center;gap:24px;flex-wrap:wrap;margin-top:12px}.pie-legend{display:flex;flex-direction:column;gap:10px}.pie-item{display:flex;align-items:center;gap:8px}.pie-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.pie-label{font-size:12px;color:var(--text-2)}.pie-label strong{color:var(--text-1)}.profile-card{display:flex;flex-direction:column;gap:20px}.profile-head{display:flex;align-items:center;gap:16px}.avatar{width:52px;height:52px;border-radius:50%;background:#00e5a033;border:2px solid var(--green);display:flex;align-items:center;justify-content:center;font-family:var(--ff-display);font-size:22px;font-weight:700;color:var(--green);flex-shrink:0}.profile-meta{display:flex;flex-direction:column;gap:3px}.profile-name{font-size:17px;font-weight:600;color:var(--text-1);font-family:var(--ff-display)}.profile-email{font-size:13px;color:var(--text-2)}.pstats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.pstat{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-s);padding:14px 16px;display:flex;flex-direction:column;gap:6px}.pstat-label{font-size:11px;color:var(--text-2)}.pstat-val{font-family:var(--ff-mono);font-size:20px;font-weight:600;color:var(--green);letter-spacing:-.5px}.progress-section{display:flex;flex-direction:column;gap:8px}.progress-row{display:flex;justify-content:space-between;font-size:13px;color:var(--text-2)}.progress-pct{color:var(--text-1);font-weight:600;font-family:var(--ff-mono)}.progress-track{height:6px;background:var(--border2);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--green);border-radius:3px;transition:width .8s cubic-bezier(.16,1,.3,1)}.tip-card{background:#f6c90e12;border:1px solid rgba(246,201,14,.2);border-radius:var(--r);padding:16px 18px;display:flex;gap:12px;align-items:flex-start}.tip-icon{font-size:18px;flex-shrink:0;margin-top:1px}.tip-text{font-size:13px;color:#f6c90ee6;line-height:1.6}.edit-btn{margin-left:auto;font-size:12px;padding:6px 12px;background:transparent;border:1px solid var(--border2);border-radius:var(--r-xs);color:var(--text-2);cursor:pointer;transition:background .15s,color .15s;font-family:var(--ff-body);white-space:nowrap}.edit-btn:hover{background:var(--bg-hover);color:var(--text-1)}.edit-form{display:flex;flex-direction:column;gap:14px;padding:4px 0}.save-toast{background:#00e5a01f;border:1px solid rgba(0,229,160,.3);border-radius:var(--r-s);padding:10px 16px;font-size:13px;color:var(--green);animation:fade-up .25s ease}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:200;padding:16px}.expense-edit-modal{background:var(--bg-card);border:1px solid var(--border2);border-radius:var(--r);padding:24px;width:100%;max-width:440px;display:flex;flex-direction:column;gap:18px}.eem-header{display:flex;justify-content:space-between;align-items:center}.eem-title{font-size:15px;font-weight:600;color:var(--text-1)}.eem-close{background:none;border:none;color:var(--text-2);font-size:22px;line-height:1;cursor:pointer;padding:0 4px;transition:color .15s}.eem-close:hover{color:var(--text-1)}.eem-fields{display:flex;flex-direction:column;gap:12px}.eem-row{display:flex;flex-direction:column;gap:5px}.eem-label{font-size:11px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.04em}.eem-input{background:var(--bg-base);border:1px solid var(--border2);border-radius:var(--r-xs);padding:9px 12px;color:var(--text-1);font-size:14px;font-family:var(--ff-body);width:100%;transition:border-color .15s}.eem-input:focus{outline:none;border-color:var(--green)}.eem-actions{display:flex;gap:10px}.eem-save{flex:1;padding:11px;background:var(--green);border:none;border-radius:var(--r-xs);color:#07120e;font-size:14px;font-weight:600;cursor:pointer;font-family:var(--ff-body);transition:opacity .15s}.eem-save:hover{opacity:.9}.eem-save:disabled{opacity:.5;cursor:not-allowed}.eem-cancel{padding:11px 18px;background:transparent;border:1px solid var(--border2);border-radius:var(--r-xs);color:var(--text-2);font-size:14px;cursor:pointer;font-family:var(--ff-body);transition:background .15s}.eem-cancel:hover{background:var(--bg-hover);color:var(--text-1)}.eem-delete{padding:11px 13px;background:transparent;border:1px solid rgba(255,77,106,.3);border-radius:var(--r-xs);color:var(--red);font-size:15px;cursor:pointer;transition:background .15s,border-color .15s;margin-right:auto}.eem-delete:hover{background:#ff4d6a14;border-color:#ff4d6a8c}.eem-confirm-label{font-size:13px;color:var(--text-2);display:flex;align-items:center;margin-right:auto}.eem-delete-confirm{padding:11px 16px;background:var(--red);border:none;border-radius:var(--r-xs);color:#fff;font-size:14px;font-weight:600;cursor:pointer;font-family:var(--ff-body);transition:opacity .15s}.eem-delete-confirm:hover{opacity:.85}.eem-delete-confirm:disabled{opacity:.5;cursor:not-allowed}.expense-item{cursor:pointer;transition:border-color .15s,background .15s}.expense-item:hover{border-color:var(--border2);background:var(--bg-hover)}.feature-list{display:flex;flex-direction:column;gap:10px}.feature-card{display:flex;align-items:center;gap:14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);padding:16px 18px;transition:border-color .15s}.feature-card:hover{border-color:var(--border2)}.feature-icon-wrap{width:44px;height:44px;border-radius:var(--r-s);display:flex;align-items:center;justify-content:center;flex-shrink:0}.feature-content{flex:1;display:flex;flex-direction:column;gap:3px}.feature-title{font-size:14px;font-weight:500;color:var(--text-1)}.feature-desc{font-size:12px;color:var(--text-2)}.feature-badge{font-size:11px;font-weight:600;padding:4px 10px;border-radius:100px;white-space:nowrap}.cta-btn{width:100%;padding:15px;background:var(--green);border:none;border-radius:var(--r);color:#07120e;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s;font-family:var(--ff-body);margin-top:4px}.cta-btn:hover{opacity:.9}.gmail-page{display:flex;flex-direction:column;gap:24px;max-width:660px}.stepper{display:flex;align-items:flex-start;gap:0}.stepper-step{display:flex;flex-direction:column;align-items:center;gap:6px;min-width:80px}.stepper-circle{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;font-family:var(--ff-mono);background:var(--border2);color:var(--text-2);flex-shrink:0;transition:background .2s,color .2s}.stepper-step.active .stepper-circle,.stepper-step.done .stepper-circle{background:var(--green);color:#07120e}.stepper-label{font-size:10px;color:var(--text-2);text-align:center;line-height:1.3;white-space:pre-line}.stepper-step.active .stepper-label{color:var(--text-1)}.stepper-line{flex:1;height:2px;background:var(--border2);margin-top:15px;transition:background .2s}.stepper-line.done{background:var(--green)}.step-content{display:flex;flex-direction:column;gap:14px}.step-heading{font-size:13px;font-weight:600;letter-spacing:.8px;color:var(--text-2);font-family:var(--ff-mono);text-transform:uppercase}.info-banner{background:#4da6ff14;border:1px solid rgba(77,166,255,.2);border-radius:var(--r-s);padding:12px 14px;font-size:13px;color:#4da6ffe6}.bank-list{display:flex;flex-direction:column;gap:8px}.bank-item{display:flex;align-items:center;gap:14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-s);padding:14px 16px;cursor:pointer;transition:border-color .15s,background .15s}.bank-item:hover{border-color:var(--border2);background:var(--bg-hover)}.bank-item.selected{border-color:var(--green);background:#00e5a00d}.bank-item.connected{border-color:var(--green);background:#00e5a00a;cursor:default}.bank-item.connected:hover{border-color:var(--green);background:#00e5a00a}.bank-connected-badge{font-size:10px;font-weight:600;color:var(--green);background:#00e5a01f;border:1px solid rgba(0,229,160,.3);border-radius:4px;padding:2px 8px;white-space:nowrap;flex-shrink:0}.bank-logo{width:44px;height:44px;border-radius:var(--r-xs);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0;font-family:var(--ff-mono)}.bank-info{flex:1;display:flex;flex-direction:column;gap:3px}.bank-name{font-size:14px;font-weight:500;color:var(--text-1)}.bank-desc{font-size:12px;color:var(--text-2)}.permission-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r);padding:24px;display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}.permission-box strong{font-size:16px;color:var(--text-1)}.permission-box p{font-size:13px;color:var(--text-2);line-height:1.6}.perms-title{font-family:var(--ff-mono);font-size:10px;font-weight:600;letter-spacing:1px;color:var(--text-2)}.perms-list{display:flex;flex-direction:column;gap:10px}.perm-item{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-2)}.perm-icon{font-size:16px}.connect-google{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:13px;background:var(--bg-card);border:1px solid var(--border2);border-radius:var(--r-s);color:var(--text-1);font-size:14px;font-weight:500;cursor:pointer;transition:background .15s;font-family:var(--ff-body)}.connect-google:hover{background:var(--bg-hover);border-color:var(--text-2)}.connect-primary{width:100%;padding:13px;background:var(--green);border:none;border-radius:var(--r-s);color:#07120e;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s;font-family:var(--ff-body)}.connect-primary:hover{opacity:.9}.connect-primary:disabled{opacity:.5;cursor:not-allowed}.connect-back{width:100%;padding:12px;background:transparent;border:1px solid var(--border2);border-radius:var(--r-s);color:var(--text-2);font-size:14px;cursor:pointer;transition:background .15s;font-family:var(--ff-body)}.connect-back:hover{background:var(--bg-hover);color:var(--text-1)}.auth-error-banner{background:#ff4d6a1f;border:1px solid rgba(255,77,106,.35);border-radius:var(--r-s);padding:12px 16px;color:#ff4d6a;font-size:13px;margin-bottom:16px}.email-list{display:flex;flex-direction:column;gap:2px}.email-item{display:flex;align-items:flex-start;gap:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-s);padding:12px 14px}.email-dot{width:8px;height:8px;background:var(--green);border-radius:50%;flex-shrink:0;margin-top:5px}.email-from{font-size:12px;color:var(--text-2);margin-bottom:3px;font-family:var(--ff-mono)}.email-text{font-size:13px;color:var(--text-1)}.result-step{align-items:center;text-align:center}.result-check{width:56px;height:56px;border-radius:50%;background:#00e5a026;border:2px solid var(--green);display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--green)}.result-title{font-family:var(--ff-display);font-size:22px;font-weight:700;color:var(--text-1)}.result-sub{font-size:14px;color:var(--text-2)}.result-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;width:100%}.rstat{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-s);padding:14px;display:flex;flex-direction:column;gap:4px;align-items:center}.rstat-n{font-family:var(--ff-mono);font-size:24px;font-weight:700}.rstat span:last-child{font-size:11px;color:var(--text-2)}.imported-list{display:flex;flex-direction:column;gap:8px;width:100%;text-align:left}.imported-item{display:flex;align-items:center;gap:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-s);padding:12px 14px}.imp-icon{width:36px;height:36px;border-radius:var(--r-xs);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.imp-info{flex:1;display:flex;flex-direction:column;gap:4px}.imp-merchant{font-size:14px;font-weight:500;color:var(--text-1)}.imp-amount{font-family:var(--ff-mono);font-size:14px;font-weight:500;color:var(--red)}.login-page{min-height:100vh;background:var(--bg-base);display:flex;align-items:center;justify-content:center;padding:24px}.login-card{background:var(--bg-card);border-radius:16px;padding:40px 36px;width:100%;max-width:400px;border:1px solid var(--border2)}.login-logo{display:flex;align-items:center;gap:10px;margin-bottom:28px;justify-content:center}.login-logo-text{font-family:var(--ff-display);font-size:22px;font-weight:800;color:var(--text-1);letter-spacing:-.5px}.login-title{font-family:var(--ff-display);font-size:22px;font-weight:700;color:var(--text-1);text-align:center;margin:0 0 8px}.login-subtitle{font-size:14px;color:var(--text-2);text-align:center;margin:0 0 28px}.login-tabs{display:flex;background:var(--bg-base);border-radius:10px;padding:4px;margin-bottom:20px;gap:4px}.login-tab{flex:1;padding:8px 12px;border:none;border-radius:7px;font-size:13px;font-weight:500;cursor:pointer;background:transparent;color:var(--text-2);transition:all .15s;font-family:var(--ff-body)}.login-tab.active{background:var(--bg-card);color:var(--text-1);box-shadow:0 1px 4px #0000002e}.login-google{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:11px 16px;background:#fff;border:1px solid rgba(0,0,0,.14);border-radius:10px;font-size:14px;font-weight:500;color:#1a1a1a;cursor:pointer;text-decoration:none;box-sizing:border-box;transition:background .15s;font-family:var(--ff-body)}.login-google:hover{background:#f4f4f4}.login-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--text-3);font-size:12px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border2)}.login-form{display:flex;flex-direction:column;gap:12px}.login-input{padding:11px 14px;background:var(--bg-surface);border:1px solid var(--border2);border-radius:10px;color:var(--text-1);font-size:14px;font-family:var(--ff-body);outline:none;width:100%;box-sizing:border-box;transition:border-color .15s}.login-input:focus{border-color:var(--green)}.login-input::placeholder{color:var(--text-3)}.login-error{color:var(--red);font-size:13px;margin:0;text-align:center}.login-submit{padding:12px;background:var(--green);border:none;border-radius:10px;color:#07120e;font-size:14px;font-weight:600;cursor:pointer;margin-top:4px;font-family:var(--ff-body);transition:opacity .15s}.login-submit:hover{opacity:.9}.login-submit:disabled{opacity:.6;cursor:not-allowed}.theme-toggle{width:100%;height:40px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--r-s);color:var(--text-2);cursor:pointer;transition:background .15s,color .15s}.theme-toggle:hover{background:var(--bg-hover);color:var(--text-1)}.new-cat-form{display:flex;flex-direction:column;gap:12px;background:var(--bg-surface);border:1px solid var(--border2);border-radius:var(--r-s);padding:14px;margin-top:6px;animation:fade-up .2s ease both}.new-cat-name-input{background:var(--bg-base);border:1px solid var(--border2);border-radius:var(--r-xs);padding:9px 12px;color:var(--text-1);font-size:14px;font-family:var(--ff-body);outline:none;transition:border-color .15s;width:100%}.new-cat-name-input:focus{border-color:var(--green)}.new-cat-name-input::placeholder{color:var(--text-3)}.new-cat-row{display:flex;flex-direction:column;gap:8px}.new-cat-label{font-size:11px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.04em;font-family:var(--ff-mono)}.new-cat-emojis{display:flex;flex-wrap:wrap;gap:6px}.emoji-dot{width:34px;height:34px;display:flex;align-items:center;justify-content:center;font-size:18px;background:var(--bg-base);border:1.5px solid var(--border2);border-radius:var(--r-xs);cursor:pointer;transition:border-color .12s,background .12s;line-height:1}.emoji-dot:hover{border-color:var(--text-2);background:var(--bg-hover)}.emoji-dot.selected{border-color:var(--green);background:#00e5a01a}html[data-theme=light] .emoji-dot.selected{background:#00a86b1a}.new-cat-colors{display:flex;flex-wrap:wrap;gap:8px}.color-dot{width:24px;height:24px;border-radius:50%;border:2.5px solid transparent;cursor:pointer;transition:transform .12s,border-color .12s;outline:none}.color-dot:hover{transform:scale(1.15)}.color-dot.selected{border-color:var(--text-1);transform:scale(1.18);box-shadow:0 0 0 2px var(--bg-base)}.new-cat-actions{display:flex;gap:8px;padding-top:2px}.new-cat-cancel{padding:8px 14px;background:transparent;border:1px solid var(--border2);border-radius:var(--r-xs);color:var(--text-2);font-size:13px;cursor:pointer;font-family:var(--ff-body);transition:background .15s,color .15s}.new-cat-cancel:hover{background:var(--bg-hover);color:var(--text-1)}.new-cat-save{flex:1;padding:8px 14px;background:var(--green);border:none;border-radius:var(--r-xs);color:#07120e;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--ff-body);transition:opacity .15s}.new-cat-save:hover{opacity:.9}.new-cat-save:disabled{opacity:.45;cursor:not-allowed}.feedback-textarea{background:var(--bg-surface);border:1px solid var(--border2);border-radius:var(--r-s);padding:10px 12px;color:var(--text-1);font-size:14px;font-family:var(--ff-body);outline:none;transition:border-color .15s;resize:vertical;width:100%}.feedback-textarea:focus{border-color:var(--green)}.feedback-textarea::placeholder{color:var(--text-3)}.pagination{display:flex;align-items:center;justify-content:center;gap:4px;padding:12px 0 4px;flex-wrap:wrap}.page-btn{min-width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-surface);border:1px solid var(--border2);border-radius:var(--r-s);color:var(--text-2);font-size:13px;cursor:pointer;transition:border-color .15s,color .15s,background .15s;padding:0 8px}.page-btn:hover:not(:disabled){border-color:var(--green);color:var(--green)}.page-btn.active{background:var(--green);color:#07120e;border-color:var(--green);font-weight:600}.page-btn:disabled{opacity:.38;cursor:not-allowed}.page-ellipsis{color:var(--text-3);font-size:13px;padding:0 2px;line-height:32px}.page-info{font-size:11px;color:var(--text-3);margin-left:6px;white-space:nowrap}.gastos-summary{display:flex;justify-content:space-between;align-items:center;padding:2px 0}.gastos-summary-count{font-size:12px;color:var(--text-3)}.gastos-summary-total{font-family:var(--ff-mono);font-size:18px;font-weight:600;color:var(--text-1);letter-spacing:-.5px}.month-tabs-bar{display:flex;gap:6px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}.month-tabs-bar::-webkit-scrollbar{display:none}.month-tab{flex-shrink:0;font-size:12px;padding:5px 13px;background:transparent;border:1px solid var(--border2);border-radius:100px;color:var(--text-2);cursor:pointer;transition:all .15s;font-family:var(--ff-body);white-space:nowrap}.month-tab:hover{border-color:var(--text-2);color:var(--text-1)}.month-tab.active{border-color:var(--green);color:var(--green);background:#00e5a01a;font-weight:600}html[data-theme=light] .month-tab.active{background:#00a86b1a}.search-bar{display:flex;align-items:center;gap:8px;background:var(--bg-card);border:1px solid var(--border2);border-radius:var(--r-s);padding:8px 12px;transition:border-color .15s}.search-bar:focus-within{border-color:var(--green)}.search-icon{font-size:17px;color:var(--text-3);flex-shrink:0;line-height:1}.search-input{flex:1;background:none;border:none;outline:none;color:var(--text-1);font-size:14px;font-family:var(--ff-body)}.search-input::placeholder{color:var(--text-3)}.search-clear{background:none;border:none;color:var(--text-3);font-size:20px;cursor:pointer;padding:0 2px;line-height:1;transition:color .15s}.search-clear:hover{color:var(--text-1)}.scan-choice{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-m);padding:16px;margin-bottom:16px;display:flex;flex-direction:column;gap:12px}.scan-choice-header{display:flex;justify-content:space-between;align-items:center}.scan-choice-merchant{font-weight:600;color:var(--text-1);font-size:14px}.scan-choice-total{font-size:13px;color:var(--text-2)}.scan-choice-btns{display:grid;grid-template-columns:1fr 1fr;gap:8px}.scan-choice-btn{background:var(--bg-surface);border:1px solid var(--border2);border-radius:var(--r-s);padding:9px 12px;color:var(--text-2);font-size:13px;cursor:pointer;transition:all .15s}.scan-choice-btn.active{border-color:var(--green);color:var(--green);background:#00e5a014}.scan-items-list{display:flex;flex-direction:column;gap:6px;max-height:240px;overflow-y:auto}.scan-item-row{display:flex;align-items:center;gap:10px;padding:8px 10px;background:var(--bg-surface);border-radius:var(--r-s);cursor:pointer;font-size:13px}.scan-item-row input[type=checkbox]{accent-color:var(--green);flex-shrink:0}.scan-item-desc{flex:1;color:var(--text-1)}.scan-item-amount{color:var(--text-2);font-variant-numeric:tabular-nums}.scan-item-cat{font-size:11px;color:var(--text-3);background:var(--bg-card);border:1px solid var(--border2);border-radius:100px;padding:2px 8px;flex-shrink:0}.scan-item-cat-select{font-size:11px;color:var(--text-2);background:var(--bg-card);border:1px solid var(--border2);border-radius:100px;padding:2px 8px;flex-shrink:0;cursor:pointer;outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none}
