*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0d14;--surface: #111520;--card: #161c2d;--border: #1f2a45;--accent: #f0c040;--accent2: #4fd1a5;--accent3: #e05a6b;--text: #e8edf7;--muted: #6b7a9e;--blue: #4a8cf7;--purple: #a78bfa;--font: "Syne", sans-serif;--mono: "JetBrains Mono", monospace}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font);min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");pointer-events:none;z-index:999;opacity:.4}.app{max-width:1100px;margin:0 auto;padding:0 20px 60px}.header{padding:32px 0 24px;display:flex;align-items:flex-start;justify-content:space-between;gap:20px;flex-wrap:wrap;border-bottom:1px solid var(--border);margin-bottom:36px}@media(max-width:720px){.header{flex-direction:column;align-items:stretch}.header-right{width:100%;align-items:stretch}.header-badge{width:100%;max-width:none;text-align:center;box-sizing:border-box}.header-badge .label,.header-badge .value,.header-badge .sub{text-align:center}.header-badge .value{font-size:clamp(22px,7vw,28px)}}.header-left h1{font-size:clamp(22px,4vw,32px);font-weight:800;letter-spacing:-1px;line-height:1}.header-left h1 span{color:var(--accent)}.header-left-row{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:6px}.header-left-row p{color:var(--muted);font-size:13px;margin:0;font-family:var(--mono)}.header-badge{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:12px 20px;text-align:right}.header-badge .label{color:var(--muted);font-size:11px;font-family:var(--mono);text-transform:uppercase;letter-spacing:1px}.header-badge .value{font-size:28px;font-weight:800;color:var(--accent);font-family:var(--mono)}.header-badge .sub{font-size:11px;color:var(--muted);font-family:var(--mono);margin-top:2px}.header-right{display:flex;flex-direction:column;align-items:flex-end;gap:10px}.header-logout{font-size:11px;padding:8px 14px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.login-page--bare{align-items:center}.login-loading-text{font-family:var(--mono);font-size:14px;color:var(--muted);animation:pulse 1.5s ease-in-out infinite}.login-card{width:100%;max-width:400px;background:var(--card);border:1px solid var(--border);border-radius:20px;padding:32px 28px;box-shadow:0 24px 48px #00000059;animation:fadeUp .45s ease both}.login-brand{font-size:clamp(20px,4vw,26px);font-weight:800;letter-spacing:-.5px;text-align:center;margin-bottom:8px}.login-brand span{color:var(--accent)}.login-sub{text-align:center;font-size:12px;color:var(--muted);font-family:var(--mono);margin-bottom:28px;line-height:1.4}.login-banner{font-size:13px;padding:12px 14px;border-radius:10px;margin-bottom:20px;line-height:1.45}.login-banner--warn{background:#e05a6b1f;border:1px solid rgba(224,90,107,.35);color:var(--text)}.login-form .login-submit{width:100%;margin-top:8px;padding:12px;font-size:14px}.login-pass-row{display:flex;gap:8px;align-items:stretch}.login-pass-row input{flex:1;min-width:0}.login-toggle-pass{flex-shrink:0;padding:10px 12px;font-size:14px}.login-error{background:#e05a6b1f;border:1px solid rgba(224,90,107,.3);color:#f8a8b5;font-size:13px;padding:10px 12px;border-radius:8px;margin-top:12px;font-family:var(--mono)}.global-progress{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:20px 24px;margin-bottom:28px}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.progress-header span{font-size:12px;font-family:var(--mono);color:var(--muted)}.progress-header strong{font-size:14px;font-family:var(--mono);color:var(--accent2)}.progress-track{height:10px;background:var(--border);border-radius:99px;overflow:hidden}.progress-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--accent2),var(--accent));transition:width .8s cubic-bezier(.4,0,.2,1);position:relative}.progress-fill:after{content:"";position:absolute;right:0;top:0;bottom:0;width:4px;background:#fff9;border-radius:2px;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:28px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:28px}@media(max-width:700px){.grid-2,.grid-3{grid-template-columns:1fr}}@media(max-width:520px){.debt-header-actions{width:100%;justify-content:flex-start}.progress-header{flex-direction:column;align-items:flex-start;gap:8px}.debts-section-head{flex-direction:column;align-items:stretch}.debts-section-head .btn{width:100%;text-align:center}.app{padding-left:14px;padding-right:14px}}@media(max-width:380px){.debt-header-actions .btn-ghost{flex:1 1 auto;min-width:calc(50% - 4px);justify-content:center;text-align:center}}.card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:20px}.card-title{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--muted);font-family:var(--mono);margin-bottom:16px;display:flex;align-items:center;gap:8px}.card-title .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);display:inline-block}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent-color, var(--accent))}.stat-label{font-size:11px;font-family:var(--mono);color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}.stat-value{font-size:26px;font-weight:800;font-family:var(--mono);color:var(--text);line-height:1}.stat-sub{font-size:11px;color:var(--muted);margin-top:6px;font-family:var(--mono)}.input-group{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.input-group label{font-size:11px;font-family:var(--mono);color:var(--muted);text-transform:uppercase;letter-spacing:1px}.input-group input{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:10px 14px;color:var(--text);font-family:var(--mono);font-size:15px;font-weight:600;width:100%;transition:border-color .2s;outline:none}.input-group input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #f0c04014}.debt-list{display:flex;flex-direction:column;gap:12px}.debt-item{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px 16px;transition:border-color .2s,transform .2s;position:relative;overflow:hidden}.debt-item:hover{border-color:var(--accent);transform:translate(3px)}.debt-item.paid{opacity:.5;border-color:var(--accent2)}.debt-item.paid:before{content:"✓ LIQUIDADA";position:absolute;top:50%;right:14px;transform:translateY(-50%);font-size:10px;font-family:var(--mono);color:var(--accent2);font-weight:700;letter-spacing:1px}.debt-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:8px}.debt-header-actions{display:flex;flex-wrap:wrap;align-items:center;gap:8px;justify-content:flex-end}.debt-name{font-weight:700;font-size:15px;display:flex;align-items:center;gap:8px;flex:1 1 140px;min-width:0;flex-wrap:wrap}.debt-title-text{min-width:0;word-break:break-word}.debt-name .emoji{font-size:16px}.debt-avatar-img{object-fit:contain;flex-shrink:0;border-radius:4px;display:inline-block;vertical-align:middle}.debt-avatar-emoji{line-height:1;display:inline-flex;align-items:center;justify-content:center}.modal-backdrop{position:fixed!important;top:0!important;right:0!important;bottom:0!important;left:0!important;background:#050812bf;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeUp .25s ease both}.modal-panel{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:24px;max-width:420px;width:100%;max-height:min(90vh,640px);overflow-y:auto;box-shadow:0 24px 48px #00000073}.modal-title{font-size:18px;font-weight:800;letter-spacing:-.5px;margin-bottom:20px}.modal-form .input-group:last-of-type{margin-bottom:0}.modal-label-block{font-size:11px;font-family:var(--mono);color:var(--muted);text-transform:uppercase;letter-spacing:1px;display:block;margin-bottom:6px}.modal-file-input{display:block;width:100%;font-family:var(--mono);font-size:12px;color:var(--muted);padding:8px 0}.modal-file-input::file-selector-button{font-family:var(--font);font-weight:600;font-size:12px;margin-right:12px;padding:8px 14px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer}.modal-file-input::file-selector-button:hover{border-color:var(--accent);color:var(--accent)}.modal-hint{font-size:11px;color:var(--muted);margin-top:8px;line-height:1.4;font-family:var(--mono)}.modal-icon-preview-row{display:flex;align-items:center;gap:12px;margin-top:12px;flex-wrap:wrap}.modal-icon-preview{width:40px;height:40px;object-fit:contain;border-radius:8px;background:var(--surface);border:1px solid var(--border);padding:4px}.modal-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px 16px;margin-top:8px}@media(max-width:520px){.modal-grid-3{grid-template-columns:1fr}}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:24px;padding-top:16px;border-top:1px solid var(--border)}.modal-btn-primary{min-width:100px}.debt-inputs{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}.debt-mini-label{font-size:10px;font-family:var(--mono);color:var(--muted);margin-bottom:4px}.debt-mini-input{background:var(--card);border:1px solid var(--border);border-radius:6px;padding:7px 10px;color:var(--text);font-family:var(--mono);font-size:14px;font-weight:600;width:100%;outline:none;transition:border-color .2s}.debt-mini-input:focus{border-color:var(--accent)}.debt-mini-input:disabled{opacity:.4}.debt-bar{height:3px;background:var(--border);border-radius:2px;margin-top:10px}.debt-bar-fill{height:100%;border-radius:2px;background:var(--bar-color, var(--accent));transition:width .8s}.chart-wrap{position:relative}canvas{max-width:100%}.timeline{display:flex;flex-direction:column;gap:0}.tl-item{display:grid;grid-template-columns:90px 24px 1fr;gap:0 16px;align-items:stretch;padding-bottom:0}.tl-date{font-family:var(--mono);font-size:12px;color:var(--muted);text-align:right;padding-top:4px;line-height:1.4}.tl-date strong{display:block;color:var(--text);font-size:13px}.tl-line-wrap{display:flex;flex-direction:column;align-items:center}.tl-dot{width:20px;height:20px;border-radius:50%;border:2px solid var(--dot-color, var(--border));background:var(--card);display:flex;align-items:center;justify-content:center;font-size:9px;flex-shrink:0;z-index:1}.tl-dot.done{background:var(--accent2);border-color:var(--accent2)}.tl-connector{width:2px;flex:1;background:var(--border);min-height:24px}.tl-body{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px 16px;margin-bottom:14px;transition:border-color .2s}.tl-body:hover{border-color:var(--accent)}.tl-body.done{border-color:#4fd1a54d}.tl-month{font-weight:800;font-size:15px;margin-bottom:4px}.tl-goal{font-size:13px;color:var(--muted)}.tl-badge{display:inline-block;background:#4fd1a526;color:var(--accent2);font-size:10px;font-family:var(--mono);padding:2px 8px;border-radius:4px;font-weight:700;margin-top:8px;letter-spacing:.5px}.tabs{display:flex;gap:4px;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:4px;margin-bottom:28px}.tab-btn{flex:1;min-width:0;background:none;border:none;color:var(--muted);font-family:var(--font);font-size:13px;font-weight:600;padding:10px 12px;border-radius:8px;cursor:pointer;transition:all .2s;text-align:center;display:inline-flex;align-items:center;justify-content:center;gap:6px}.tab-icon{font-size:1.15em;line-height:1}.tab-label{white-space:nowrap}@media(max-width:720px){.tab-label{display:none}.tab-btn{padding:10px 6px;gap:0}.tab-icon{font-size:1.35em}}.tab-btn.active{background:var(--accent);color:#000}.tab-btn:hover:not(.active){color:var(--text);background:var(--border)}.section-title{font-size:18px;font-weight:800;margin-bottom:18px;letter-spacing:-.5px;display:flex;align-items:center;gap:10px}.section-title span{color:var(--muted);font-size:13px;font-weight:400;font-family:var(--mono)}.debts-section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:18px}.section-title--inline{margin-bottom:0}.debt-inline-edit{font-size:10px;padding:6px 12px;flex-shrink:0}.btn{background:var(--accent);color:#000;font-family:var(--font);font-weight:700;font-size:13px;border:none;border-radius:8px;padding:10px 20px;cursor:pointer;transition:opacity .2s,transform .15s}.btn:hover{opacity:.85;transform:translateY(-1px)}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--muted);font-family:var(--mono);font-size:11px;padding:6px 12px;border-radius:6px;cursor:pointer;transition:all .2s}.btn-ghost:hover{border-color:var(--text);color:var(--text)}.divider{border:none;border-top:1px solid var(--border);margin:24px 0}.rules-list{list-style:none;display:flex;flex-direction:column;gap:10px}.rules-list li{display:flex;gap:12px;align-items:flex-start;font-size:13px;color:var(--muted);line-height:1.5}.rules-list li .num{font-family:var(--mono);font-size:11px;font-weight:700;color:var(--accent);background:#f0c0401a;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.tag{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-family:var(--mono);padding:3px 8px;border-radius:5px;font-weight:700}.tag-nu{background:#4a8cf726;color:var(--blue)}.tag-bbva{background:#a78bfa26;color:var(--purple)}.two-col-settings{display:grid;grid-template-columns:1fr 1fr;gap:24px}@media(max-width:600px){.two-col-settings{grid-template-columns:1fr}}.income-card{background:linear-gradient(135deg,rgba(240,192,64,.08) 0%,transparent 60%);border-color:#f0c04033}.animate-in{animation:fadeUp .4s ease both}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.input-select{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:10px 14px;color:var(--text);font-family:var(--mono);font-size:14px;font-weight:600;width:100%;outline:none;cursor:pointer;transition:border-color .2s}.input-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #f0c04014}.input-error{font-size:11px;font-family:var(--mono);color:var(--accent3);margin-top:2px}.expenses-section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:24px}.expense-summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}@media(max-width:720px){.expense-summary-grid{grid-template-columns:1fr}}.expense-summary-card .stat-value{font-size:clamp(18px,4vw,24px)}.expense-summary-topcat{font-size:clamp(14px,3.5vw,18px)!important;line-height:1.25;word-break:break-word}.expense-filters-card{margin-bottom:20px}.expense-filters-row{display:flex;flex-direction:column;gap:16px}.expense-filter-field{margin-bottom:0}.expense-filter-field .input-select{max-width:280px}.expense-cat-chips{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.expense-cat-all{font-size:11px;padding:6px 12px}.expense-cat-chip{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-family:var(--mono);padding:6px 10px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--muted);cursor:pointer;-webkit-user-select:none;user-select:none}.expense-cat-chip input{position:absolute;opacity:0;width:0;height:0}.expense-cat-chip.on{border-color:var(--accent);color:var(--accent);background:#f0c04014}.expense-recurring-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.expense-rec-tab{font-family:var(--mono);font-size:11px;font-weight:700;padding:8px 14px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--muted);cursor:pointer;transition:border-color .2s,color .2s}.expense-rec-tab:hover{border-color:var(--accent);color:var(--text)}.expense-rec-tab.active{border-color:var(--accent);color:var(--accent);background:#f0c0401a}.expense-list{display:flex;flex-direction:column;gap:12px}.expense-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px 16px;transition:border-color .2s}.expense-card:hover{border-color:#f0c04059}.expense-card-main{display:flex;align-items:flex-start;gap:12px}.expense-card-icon{font-size:22px;line-height:1;flex-shrink:0}.expense-card-body{flex:1;min-width:0}.expense-card-title-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.expense-card-title{font-weight:700;font-size:15px;word-break:break-word}.expense-badge{font-size:10px;font-family:var(--mono);font-weight:700;letter-spacing:.5px;padding:2px 8px;border-radius:4px;background:#a78bfa26;color:var(--purple)}.expense-card-meta{font-size:12px;color:var(--muted);font-family:var(--mono);margin-top:4px}.expense-card-amount{font-family:var(--mono);font-size:18px;font-weight:800;color:var(--accent);flex-shrink:0;text-align:right}.expense-card-actions{display:flex;align-items:center;gap:8px;margin-top:12px;padding-top:10px;border-top:1px solid var(--border)}.expense-card-btn{font-size:12px;padding:4px 10px}.expense-card-actions-sep{color:var(--border);font-size:12px;-webkit-user-select:none;user-select:none}.expense-empty{text-align:center;padding:40px 20px;background:var(--card);border:1px dashed var(--border);border-radius:12px}.expense-empty-icon{font-size:48px;line-height:1;margin-bottom:12px;opacity:.85}.expense-empty-text{color:var(--muted);font-size:14px;margin-bottom:20px;max-width:280px;margin-left:auto;margin-right:auto}.expense-toggle-row{margin-bottom:0}.expense-toggle-label{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text);cursor:pointer;font-family:var(--font);text-transform:none;letter-spacing:0}.expense-toggle-label input{width:auto;accent-color:var(--accent);cursor:pointer}.expense-form-modal{max-width:440px}.emoji-picker-wrapper{display:flex;flex-direction:column;gap:6px}.emoji-picker-label{font-size:13px;color:var(--muted);font-family:var(--font);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.emoji-picker-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:var(--card);border:1px solid var(--border);border-radius:8px;cursor:pointer;font-size:24px;transition:border-color .15s,box-shadow .15s;width:fit-content}.emoji-picker-btn:hover,.emoji-picker-btn:focus-visible{border-color:var(--accent);box-shadow:0 0 0 2px #f0c04026}.emoji-picker-current{line-height:1}.emoji-picker-arrow{font-size:10px;color:var(--muted);transition:transform .15s}.emoji-picker-wrapper:focus-within .emoji-picker-arrow{transform:rotate(180deg)}.emoji-picker-dropdown{position:absolute;z-index:1000;margin-top:4px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 32px #00000080;overflow:hidden}.emoji-picker-dropdown em-emoji-picker{--rgb-background: 17, 21, 32 !important;--rgb-color: 232, 237, 247 !important;--rgb-accent: 240, 192, 64 !important;--rgb-input: 22, 28, 45 !important;--rgb-border: 31, 42, 69 !important}.emoji-picker-clear{font-size:11px;color:var(--accent3);margin-top:4px;align-self:flex-start}.category-manager-add-row .emoji-picker-wrapper{flex:0 0 auto}.budget-table{margin-top:8px;font-family:var(--mono);font-size:13px}.budget-table-header{display:grid;grid-template-columns:1fr 100px 30px;gap:8px;padding:6px 8px;color:var(--muted);font-size:10px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);margin-bottom:4px}.budget-table-row{display:grid;grid-template-columns:1fr 100px 30px;gap:8px;align-items:center;padding:6px 8px;border-radius:6px;transition:background .15s}.budget-table-row:hover{background:var(--card)}.budget-item-name{color:var(--text);font-weight:500;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.budget-item-input{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:6px 10px;color:var(--text);font-family:var(--mono);font-size:13px;font-weight:600;width:100%;text-align:right;outline:none;transition:border-color .2s;-moz-appearance:textfield}.budget-item-input::-webkit-inner-spin-button,.budget-item-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.budget-item-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #f0c0401f}.budget-delete-btn{background:none;border:none;cursor:pointer;color:var(--accent3);font-size:16px;line-height:1;padding:4px;border-radius:4px;transition:background .15s;width:26px;height:26px;display:flex;align-items:center;justify-content:center}.budget-delete-btn:hover{background:#e05a6b1f}.budget-table-add-row{padding:8px;display:flex}.budget-add-btn{font-size:12px;color:var(--muted);padding:6px 12px;border:1px dashed var(--border);border-radius:6px;width:100%;text-align:center;transition:border-color .2s,color .2s}.budget-add-btn:hover{border-color:var(--accent);color:var(--accent)}.budget-table-total{display:flex;justify-content:space-between;align-items:center;padding:8px 8px 0;border-top:1px solid var(--border);margin-top:4px;font-size:14px;color:var(--text)}.budget-total-value{font-weight:700;color:var(--accent2);font-family:var(--mono)}
