@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap";:root{--font: "Plus Jakarta Sans", system-ui, -apple-system, sans-serif;--accent: #6366F1;--accent-dark: #4F46E5;--accent-light: #EEF2FF;--accent-glow: rgba(99, 102, 241, .2);--bg: #F8FAFC;--surface: #FFFFFF;--surface2: #F1F5F9;--border: rgba(15, 23, 42, .07);--border2: rgba(15, 23, 42, .13);--text: #0F172A;--text2: #64748B;--text3: #94A3B8;--green: #10B981;--green-dark: #059669;--green-light: #D1FAE5;--red: #EF4444;--red-dark: #DC2626;--red-light: #FEE2E2;--orange: #F59E0B;--orange-dark: #D97706;--orange-light: #FEF3C7;--purple: #8B5CF6;--purple-light: #EDE9FE;--radius: 14px;--radius-sm: 10px;--radius-xs: 6px;--shadow: 0 1px 2px rgba(15,23,42,.04), 0 2px 8px rgba(15,23,42,.04);--shadow-md: 0 4px 16px rgba(15,23,42,.08), 0 1px 4px rgba(15,23,42,.04);--shadow-lg: 0 8px 32px rgba(15,23,42,.12), 0 2px 8px rgba(15,23,42,.06);--sidebar-w: 220px;--topbar-h: 56px;--mobile-nav-h: 64px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-tap-highlight-color:transparent;scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;min-height:100dvh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img,svg{display:block;flex-shrink:0}button{font-family:var(--font);cursor:pointer;border:none;background:none}input,select,textarea{font-family:var(--font)}a{color:inherit;text-decoration:none}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.94) translateY(6px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes slideUpSheet{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes navPop{0%{transform:scale(.75)}60%{transform:scale(1.15)}to{transform:scale(1)}}@keyframes progressFill{0%{width:0}}.app{display:flex;flex-direction:column;height:100dvh;overflow:hidden}.topbar{display:flex;align-items:center;justify-content:space-between;height:var(--topbar-h);padding:0 20px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;gap:12px;flex-shrink:0}.logo{font-size:22px;font-weight:800;letter-spacing:-1px;color:var(--text);flex-shrink:0}.logo span{color:var(--accent)}.topbar-right{display:flex;align-items:center;gap:8px;flex:1;justify-content:flex-end;min-width:0}.month-nav{display:flex;align-items:center;gap:2px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:2px}.month-nav-btn{width:30px;height:30px;border-radius:7px;background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text2);transition:background .15s,color .15s}.month-nav-btn:hover{background:var(--border2);color:var(--text)}.month-nav-btn svg{width:16px;height:16px}.month-display{font-size:13px;font-weight:600;color:var(--text);padding:0 6px;white-space:nowrap}.month-short{display:none}.topbar-action-btn{display:flex;align-items:center;gap:5px;white-space:nowrap}.btn-label-text{display:inline}.sync-indicator{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-xs);color:var(--text3);cursor:default}.sync-indicator.syncing svg{animation:spin 1s linear infinite;color:var(--accent)}.sync-indicator.error svg{color:var(--red)}.sync-indicator.synced svg{color:var(--green)}.dark-toggle{width:34px;height:34px;border-radius:var(--radius-sm);background:var(--surface2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text2);transition:background .15s,color .15s,border-color .15s;flex-shrink:0}.dark-toggle:hover{background:var(--border2);color:var(--text)}.content-wrap{display:flex;flex:1;min-height:0;overflow:hidden}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:12px 10px;overflow-y:auto;overflow-x:hidden;gap:2px}.nav-divider{height:1px;background:var(--border);margin:6px 4px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;color:var(--text2);transition:background .15s,color .15s;cursor:pointer;border:none;background:none;width:100%;text-align:left;text-decoration:none}.nav-item:hover{background:var(--surface2);color:var(--text)}.nav-item.active{background:var(--accent-light);color:var(--accent);font-weight:600}.nav-item.active svg{color:var(--accent)}.nav-icon{width:18px;height:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-footer{margin-top:auto;padding-top:12px}.sidebar-user{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:var(--radius-sm);background:var(--surface2);margin-bottom:8px;border:1px solid var(--border)}.sidebar-user-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent-light);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--accent)}.sidebar-user-email{font-size:11px;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.main{flex:1;overflow-y:auto;overflow-x:hidden;padding:24px;scroll-behavior:smooth}.main>*{animation:fadeSlideUp .28s ease}.page-title{font-size:22px;font-weight:800;color:var(--text);letter-spacing:-.4px;line-height:1.2}.page-sub{font-size:13px;color:var(--text2);margin-top:4px;margin-bottom:20px}.text-muted{color:var(--text3);font-size:13px}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,box-shadow .15s,transform .15s,border-color .15s,color .15s,opacity .15s;border:1.5px solid transparent;line-height:1;white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none!important}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover:not(:disabled){background:var(--accent-dark);border-color:var(--accent-dark);transform:translateY(-1px);box-shadow:0 4px 14px #6366f166}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:none}.btn-ghost{background:transparent;color:var(--text2);border-color:var(--border2)}.btn-ghost:hover:not(:disabled){background:var(--surface2);color:var(--text);border-color:var(--border2)}.btn-danger{background:var(--red-light);color:var(--red-dark);border-color:transparent}.btn-danger:hover:not(:disabled){background:var(--red);color:#fff;transform:translateY(-1px)}.btn-finish{background:var(--green-light);color:var(--green-dark);border-color:transparent}.btn-finish:hover:not(:disabled){background:var(--green);color:#fff;transform:translateY(-1px);box-shadow:0 4px 14px #10b98166}.btn-sm{padding:6px 12px;font-size:12px;border-radius:var(--radius-xs)}.btn-icon{padding:7px;border-radius:var(--radius-xs)}.form-group{margin-bottom:14px}.form-label{display:block;font-size:12px;font-weight:600;color:var(--text2);margin-bottom:6px;text-transform:uppercase;letter-spacing:.4px}.form-control{width:100%;height:40px;padding:0 12px;border:1.5px solid var(--border2);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:13px;font-family:var(--font);transition:border-color .15s,box-shadow .15s;outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none}.form-control:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.form-control::placeholder{color:var(--text3)}.input{width:100%;height:40px;padding:0 12px;border:1.5px solid var(--border2);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:13px;font-family:var(--font);transition:border-color .15s,box-shadow .15s;outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.input::placeholder{color:var(--text3)}.form-row{display:flex;gap:12px;flex-wrap:wrap}.form-row-2>*{flex:1;min-width:120px}select.form-control,select.input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:36px}.type-toggle{display:flex;border-radius:var(--radius-sm);overflow:hidden;border:1.5px solid var(--border2);background:var(--surface2)}.type-toggle-btn{flex:1;padding:9px 12px;font-size:13px;font-weight:600;border:none;background:transparent;color:var(--text3);cursor:pointer;transition:background .15s,color .15s}.type-toggle-btn.active.entrada{background:var(--green-light);color:var(--green-dark)}.type-toggle-btn.active.saida{background:var(--red-light);color:var(--red-dark)}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:box-shadow .2s}.panel:last-child{margin-bottom:0}.panel-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);gap:8px}.panel-title{font-size:14px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:7px}.panel-body{padding:16px}.panel-body.no-pad{padding:0}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;position:relative;overflow:hidden;box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease;animation:fadeSlideUp .3s ease both}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card:before{content:"";position:absolute;inset:0 0 auto 0;height:3px}.stat-card.green:before{background:var(--green)}.stat-card.red:before{background:var(--red)}.stat-card.accent:before{background:var(--accent)}.stat-card.orange:before{background:var(--orange)}.stat-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--text3);margin-bottom:10px}.stat-value{font-size:22px;font-weight:800;letter-spacing:-.5px;line-height:1;margin-bottom:6px;color:var(--text)}.stat-card.green .stat-value{color:var(--green-dark)}.stat-card.red .stat-value{color:var(--red-dark)}.stat-card.accent .stat-value{color:var(--accent)}.stat-card.orange .stat-value{color:var(--orange-dark)}.stat-sub{font-size:11px;color:var(--text3)}.daily-budget-card{background:linear-gradient(135deg,var(--accent-light) 0%,#F0F4FF 100%);border:1px solid rgba(99,102,241,.18);border-radius:var(--radius);padding:16px 20px;margin-bottom:16px;display:flex;align-items:center;gap:16px;animation:fadeSlideUp .3s ease}.daily-budget-label{font-size:12px;font-weight:600;color:var(--accent);white-space:nowrap}.daily-budget-val{font-size:24px;font-weight:800;color:var(--accent);letter-spacing:-.5px}.daily-budget-sub{font-size:11px;color:var(--text3);margin-top:2px}.alert{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;margin-bottom:14px;animation:fadeSlideUp .25s ease}.alert-danger{background:var(--red-light);color:var(--red-dark)}.alert-warning{background:var(--orange-light);color:var(--orange-dark)}.alert-success{background:var(--green-light);color:var(--green-dark)}.alert-info{background:var(--accent-light);color:var(--accent-dark)}.badge{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;border-radius:99px;font-size:11px;font-weight:700;white-space:nowrap;line-height:1.4}.badge-gray{background:var(--surface2);color:var(--text2)}.badge-blue{background:var(--accent-light);color:var(--accent)}.badge-green{background:var(--green-light);color:var(--green-dark)}.badge-red{background:var(--red-light);color:var(--red-dark)}.badge-orange{background:var(--orange-light);color:var(--orange-dark)}.badge-purple{background:var(--purple-light);color:var(--purple)}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table thead th{text-align:left;padding:10px 14px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text3);background:var(--surface2);border-bottom:1px solid var(--border)}.data-table tbody td{padding:11px 14px;border-bottom:1px solid var(--border);vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr{transition:background .12s}.data-table tbody tr:hover{background:var(--surface2)}.text-right{text-align:right!important}.td-amount{font-weight:700;font-variant-numeric:tabular-nums}.td-amount.neg{color:var(--red-dark)}.td-amount.pos{color:var(--green-dark)}.actions{display:flex;gap:4px;justify-content:flex-end}.progress{height:8px;background:var(--surface2);border-radius:99px;overflow:hidden}.progress-fill{height:100%;border-radius:99px;transition:width .6s cubic-bezier(.34,1.56,.64,1)}.filter-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}.filter-chip{padding:5px 14px;border-radius:99px;font-size:12px;font-weight:600;cursor:pointer;border:1.5px solid var(--border2);background:var(--surface);color:var(--text2);transition:all .15s;-webkit-user-select:none;user-select:none}.filter-chip:hover{border-color:var(--accent);color:var(--accent)}.filter-chip.active{background:var(--accent);border-color:var(--accent);color:#fff}.chip-group{display:flex;flex-wrap:wrap;gap:6px}.chip{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:99px;background:var(--surface2);border:1px solid var(--border2);font-size:12px;font-weight:600;color:var(--text2);transition:background .15s}.chip:hover{background:var(--border2)}.kw-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 10px 5px 12px;border-radius:99px;background:var(--surface2);border:1px solid var(--border);font-size:12px;transition:background .15s}.kw-chip:hover{background:var(--border2)}.kw-word{font-weight:700;color:var(--accent)}.kw-arrow{color:var(--text3);font-size:11px}.kw-cat{font-weight:500;color:var(--text2)}.kw-remove{margin-left:2px;color:var(--text3);cursor:pointer;font-size:11px;line-height:1;transition:color .15s;background:none;border:none;padding:0 2px}.kw-remove:hover{color:var(--red)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 20px;gap:10px;animation:fadeIn .3s ease}.empty-icon{width:60px;height:60px;border-radius:18px;background:var(--surface2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:26px;margin-bottom:4px}.empty-text{font-size:14px;color:var(--text3);text-align:center;line-height:1.6}.chart-wrap{width:100%;height:200px;position:relative}.legend{display:flex;flex-wrap:wrap;gap:8px 16px;margin-top:12px}.legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text2)}.legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.fab{display:none;position:fixed;right:20px;bottom:calc(var(--mobile-nav-h) + 16px);width:52px;height:52px;border-radius:50%;background:var(--accent);color:#fff;font-size:25px;font-weight:300;line-height:1;box-shadow:0 6px 20px #6366f173;border:none;cursor:pointer;align-items:center;justify-content:center;z-index:120;padding-bottom:5px;transition:transform .2s,box-shadow .2s}.fab:hover{transform:scale(1.08);box-shadow:0 8px 28px #6366f18c}.fab:active{transform:scale(.95)}.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:var(--mobile-nav-h);background:var(--surface);border-top:1px solid var(--border);align-items:stretch;z-index:110;padding:0 4px;box-shadow:0 -4px 16px #0f172a0f}.mobile-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;font-size:10px;font-weight:600;color:var(--text3);padding:8px 4px;border:none;background:none;cursor:pointer;text-decoration:none;border-radius:var(--radius-sm);margin:6px 2px;transition:color .15s,background .15s;-webkit-tap-highlight-color:transparent}.mobile-nav-item svg{transition:transform .25s cubic-bezier(.34,1.56,.64,1)}.mobile-nav-item:active svg{transform:scale(.85)}.mobile-nav-item.active{color:var(--accent)}.mobile-nav-item.active svg{animation:navPop .3s cubic-bezier(.34,1.56,.64,1);color:var(--accent)}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;z-index:130;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.bottom-sheet{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-radius:20px 20px 0 0;padding:0 20px 32px;z-index:131;animation:slideUpSheet .32s cubic-bezier(.32,.72,0,1);max-height:88dvh;overflow-y:auto}.sheet-handle{width:36px;height:4px;background:var(--border2);border-radius:99px;margin:14px auto 20px}.sheet-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text3);margin-bottom:10px}.sheet-month-btns{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:8px}.sheet-month-btn{display:flex;align-items:center;justify-content:center;gap:7px;padding:13px;border-radius:var(--radius-sm);font-size:13px;font-weight:700;cursor:pointer;border:none;transition:all .15s;-webkit-tap-highlight-color:transparent}.sheet-month-btn.iniciar{background:var(--accent-light);color:var(--accent)}.sheet-month-btn.finalizar{background:var(--green-light);color:var(--green-dark)}.sheet-month-btn.iniciar:hover{background:var(--accent);color:#fff}.sheet-month-btn.finalizar:hover{background:var(--green);color:#fff}.sheet-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:8px}.sheet-grid-item{display:flex;flex-direction:column;align-items:center;gap:7px;padding:14px 8px;border-radius:var(--radius-sm);background:var(--surface2);border:1px solid var(--border);font-size:11px;font-weight:600;color:var(--text2);cursor:pointer;transition:background .15s,color .15s,transform .15s;-webkit-tap-highlight-color:transparent;text-align:center}.sheet-grid-item:hover{background:var(--accent-light);color:var(--accent);transform:translateY(-1px)}.sheet-grid-item:active{transform:scale(.95)}.sheet-grid-icon{width:44px;height:44px;border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text2);transition:background .15s,color .15s}.sheet-grid-item:hover .sheet-grid-icon{background:var(--accent-light);color:var(--accent);border-color:#6366f140}.sheet-footer{margin-top:16px;padding-top:16px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:8px}.sheet-user-email{font-size:12px;color:var(--text3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sheet-logout-btn{display:flex;align-items:center;gap:5px;padding:7px 12px;border-radius:var(--radius-xs);background:var(--red-light);color:var(--red-dark);font-size:12px;font-weight:600;border:none;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s;flex-shrink:0}.sheet-logout-btn:hover{background:var(--red);color:#fff}.parcela-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px;box-shadow:var(--shadow);transition:box-shadow .2s,transform .2s;animation:fadeSlideUp .3s ease both}.parcela-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.parcela-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:8px}.parcela-name{font-weight:700;font-size:14px;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.parcela-meta{display:flex;flex-wrap:wrap;gap:6px 14px;margin-top:10px}.parcela-meta-item{font-size:12px;color:var(--text2)}.parcela-meta-item strong{color:var(--text)}.parcela-actions{display:flex;gap:6px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.parcelas-resumo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.meta-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px;box-shadow:var(--shadow);animation:fadeSlideUp .3s ease both;transition:box-shadow .2s,transform .2s}.meta-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.meta-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px;gap:10px}.meta-name{font-weight:700;font-size:14px;color:var(--text)}.meta-desc{font-size:12px;color:var(--text2);margin-top:3px}.reserva-main{gap:16px}.reserva-result{background:var(--accent-light);border:1px solid rgba(99,102,241,.15);border-radius:var(--radius);padding:20px;margin-bottom:16px;animation:fadeSlideUp .3s ease}.reserva-result-title{font-size:13px;font-weight:700;color:var(--accent);margin-bottom:14px}.reserva-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.reserva-item-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--text3);margin-bottom:4px}.reserva-item-val{font-size:18px;font-weight:800;letter-spacing:-.4px}.credit-card{border-radius:var(--radius);padding:20px;color:#fff;position:relative;overflow:hidden;box-shadow:0 8px 24px #0000002e;margin-bottom:0}.credit-card:after{content:"";position:absolute;top:-40%;right:-20%;width:200px;height:200px;border-radius:50%;background:#ffffff0f;pointer-events:none}.cc-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.cc-name{font-size:18px;font-weight:800;letter-spacing:-.3px}.cc-chip{width:32px;height:24px;background:#ffffff59;border-radius:4px}.cc-amounts{display:flex;gap:20px;flex-wrap:wrap;margin-bottom:16px}.cc-amount-label{font-size:10px;font-weight:600;opacity:.7;text-transform:uppercase;letter-spacing:.4px;margin-bottom:3px}.cc-amount-val{font-size:17px;font-weight:800;letter-spacing:-.3px}.cc-bar-wrap{margin-bottom:12px}.cc-bar{height:4px;background:#ffffff40;border-radius:99px;overflow:hidden}.cc-bar-fill{height:100%;border-radius:99px;transition:width .4s ease}.cc-bar-label{font-size:10px;opacity:.7;margin-top:5px}.cc-dates{display:flex;gap:20px}.cc-date-item{font-size:11px;opacity:.7;display:flex;flex-direction:column;gap:1px}.cc-date-item strong{font-size:14px;opacity:1}.historico-resumo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;padding:14px 16px;border-bottom:1px solid var(--border);background:var(--surface2)}.mobile-card-list{display:none}.m-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:10px;box-shadow:var(--shadow);animation:fadeSlideUp .25s ease both;transition:box-shadow .2s}.m-card:hover{box-shadow:var(--shadow-md)}.m-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:8px}.m-card-desc{font-weight:700;font-size:14px;color:var(--text);flex:1;min-width:0}.m-card-amount{font-weight:800;font-size:15px;white-space:nowrap}.m-card-amount.neg{color:var(--red-dark)}.m-card-amount.pos{color:var(--green-dark)}.m-card-meta{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px}.m-card-actions{display:flex;gap:6px;padding-top:10px;border-top:1px solid var(--border)}.lanc-mobile-total{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;background:var(--surface2);border-radius:var(--radius);font-size:13px;font-weight:700;color:var(--text2);margin-bottom:8px}.lanc-mobile-total .neg{color:var(--red-dark)}.lanc-mobile-total .pos{color:var(--green-dark)}.lanc-total-row td{padding-top:12px;padding-bottom:12px;border-top:2px solid var(--border2);background:var(--surface2)}.lanc-total-label{font-size:13px;font-weight:700;color:var(--text2);text-align:right;padding-right:16px}.overlay{display:none}.overlay.open,.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .18s ease;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}.modal{background:var(--surface);border-radius:18px;box-shadow:var(--shadow-lg);width:100%;max-width:480px;max-height:90dvh;overflow-y:auto;animation:scaleIn .22s cubic-bezier(.34,1.56,.64,1)}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface);z-index:1;border-radius:18px 18px 0 0}.modal-title{font-size:16px;font-weight:700;color:var(--text)}.modal-close{width:30px;height:30px;border-radius:50%;background:var(--surface2);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text3);transition:background .15s,color .15s;flex-shrink:0}.modal-close:hover{background:var(--red-light);color:var(--red)}.modal-body{padding:18px 20px}.modal-footer{padding:14px 20px 18px;display:flex;gap:10px;justify-content:flex-end;border-top:1px solid var(--border);background:var(--surface2);border-radius:0 0 18px 18px}.flex-between{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.mt-4{margin-top:16px}.charts-grid{display:grid}.quick-launch{display:flex;align-items:center;gap:8px;margin-bottom:8px;background:var(--surface);border:1.5px solid var(--border2);border-radius:var(--radius-sm);padding:8px 12px;transition:border-color .15s,box-shadow .15s}.quick-launch:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.quick-launch-input{flex:1;border:none;background:transparent;font-size:13px;color:var(--text);outline:none;min-width:0}.quick-launch-input::placeholder{color:var(--text3)}.quick-launch-hint{font-size:11px;font-weight:700;color:var(--text3);background:var(--surface2);border:1px solid var(--border2);border-radius:5px;padding:2px 7px;white-space:nowrap;flex-shrink:0;letter-spacing:.3px}.quick-suggestion{margin-bottom:14px}.quick-sug-chip{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:9px 16px;background:var(--surface);border:1.5px solid var(--accent);border-radius:var(--radius-sm);font-size:12px;font-weight:600;color:var(--accent);cursor:pointer;transition:background .12s,color .12s,transform .1s;font-family:var(--font);text-align:left;flex-wrap:wrap}.quick-sug-chip:hover{background:var(--accent-light);transform:translateY(-1px)}.quick-sug-chip:active{transform:translateY(0)}.config-page-body{display:flex;flex-direction:column;gap:16px}.budget-gauge-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:14px 16px;margin-bottom:16px;box-shadow:var(--shadow)}.budget-gauge-header{display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:600;color:var(--text2);margin-bottom:8px}.budget-gauge-pct{font-size:15px;font-weight:800;color:var(--text)}.budget-gauge-footer{display:flex;justify-content:space-between;font-size:11px;color:var(--text3);margin-top:6px}.config-backup-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border);gap:12px}.config-backup-info{display:flex;align-items:flex-start;gap:10px;flex:1;min-width:0}body.dark{--bg: #0F172A;--surface: #1E293B;--surface2: #334155;--border: rgba(255,255,255,.07);--border2: rgba(255,255,255,.13);--text: #F1F5F9;--text2: #94A3B8;--text3: #64748B;--shadow: 0 1px 2px rgba(0,0,0,.2), 0 2px 8px rgba(0,0,0,.2);--shadow-md: 0 4px 16px rgba(0,0,0,.3), 0 1px 4px rgba(0,0,0,.2);--shadow-lg: 0 8px 32px rgba(0,0,0,.4), 0 2px 8px rgba(0,0,0,.3);--accent-glow: rgba(99,102,241,.3)}body.dark .form-control,body.dark .input{background:var(--surface2);border-color:var(--border2)}body.dark select.form-control,body.dark select.input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E")}body.dark .credit-card{box-shadow:0 8px 24px #0006}.type-btn{flex:1;padding:10px 12px;font-size:13px;font-weight:700;border:none;background:transparent;color:var(--text3);cursor:pointer;transition:background .15s,color .15s;font-family:var(--font)}.type-btn.active.saida{background:var(--red-light);color:var(--red-dark)}.type-btn.active.entrada{background:var(--green-light);color:var(--green-dark)}.chip.active{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}.lanc-modal{background:var(--surface);border-radius:20px;box-shadow:var(--shadow-lg);width:min(440px,calc(100vw - 24px));max-height:calc(100dvh - 40px);display:flex;flex-direction:column;overflow:hidden;animation:scaleIn .18s cubic-bezier(.34,1.4,.64,1)}.lanc-modal-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);flex-shrink:0}.lanc-modal-body{padding:14px 16px;flex:1;overflow:hidden}.lanc-modal-footer{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border);flex-shrink:0}.lanc-modal-footer .btn{flex:1;justify-content:center;height:40px;font-size:13px}.lanc-row{display:flex;gap:8px}.lanc-field{display:flex;flex-direction:column;flex:1;margin-bottom:10px}.lanc-input{height:36px!important;padding-top:0!important;padding-bottom:0!important;font-size:13px!important}.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:5px}.cat-chip{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 4px;border-radius:9px;border:1.5px solid var(--border2);background:var(--surface2);color:var(--text2);cursor:pointer;transition:border-color .12s,background .12s,color .12s;font-family:var(--font)}.cat-chip:hover{border-color:var(--accent);background:var(--accent-light);color:var(--accent)}.cat-chip.active{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}.cat-chip-icon{font-size:17px;line-height:1}.cat-chip-name{font-size:10px;font-weight:600;text-align:center;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.lanc-check-row{display:flex;align-items:center;gap:8px;padding:5px 10px;background:var(--surface2);border-radius:8px;cursor:pointer;font-size:10px;font-weight:600;color:var(--text2);flex-shrink:0}.lanc-check-row input[type=checkbox]{width:15px;height:15px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}@media (max-width: 960px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.sidebar{display:none}.main{padding:16px;padding-bottom:calc(var(--mobile-nav-h) + 80px)}.mobile-nav,.fab{display:flex}.mobile-card-list{display:block}.desktop-table,.month-full{display:none}.month-short{display:block}.btn-label-text{display:none}.topbar{padding:0 14px;gap:6px}.topbar-action-btn{padding:7px 10px}.stats-grid{grid-template-columns:1fr 1fr;gap:10px}.stat-value{font-size:18px}.stat-card{padding:14px}.charts-grid,.reserva-main{grid-template-columns:1fr!important}.parcelas-resumo-grid{grid-template-columns:1fr;gap:10px}.historico-resumo-grid{grid-template-columns:repeat(2,1fr)}.page-title{font-size:18px}.daily-budget-card{flex-direction:column;align-items:flex-start;gap:4px}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr 1fr;gap:8px}.stat-value{font-size:16px}.sheet-grid{grid-template-columns:repeat(3,1fr)}.reserva-grid{grid-template-columns:1fr 1fr}}.login-root{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0b1120;padding:20px;position:relative;overflow:hidden;font-family:var(--font)}.login-glow{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;opacity:.25}.login-glow-1{width:480px;height:480px;background:radial-gradient(circle,#6366F1 0%,transparent 70%);top:-160px;left:-100px}.login-glow-2{width:360px;height:360px;background:radial-gradient(circle,#8B5CF6 0%,transparent 70%);bottom:-120px;right:-80px}.login-wrapper{width:100%;max-width:400px;position:relative;z-index:1}.login-brand{text-align:center;margin-bottom:32px}.login-logo-icon{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;background:var(--accent);border-radius:20px;margin-bottom:16px;box-shadow:0 0 48px #6366f180,0 4px 16px #6366f14d}.login-brand-name{font-size:36px;font-weight:900;color:#f1f5f9;letter-spacing:-1px;margin:0 0 6px}.login-brand-dot{color:var(--accent)}.login-brand-sub{color:#64748b;font-size:13px;margin:0}.login-card{background:#1e293b;border-radius:24px;border:1px solid rgba(255,255,255,.08);padding:28px;box-shadow:0 0 80px #6366f114,0 8px 40px #00000080}.login-tabs{display:flex;gap:4px;background:#0f172a;border-radius:12px;padding:4px;margin-bottom:24px}.login-tab{flex:1;padding:10px 0;border-radius:9px;border:none;font-weight:600;font-size:13px;cursor:pointer;background:transparent;color:#64748b;transition:all .15s;font-family:var(--font)}.login-tab.active{background:#334155;color:#f1f5f9;box-shadow:0 1px 4px #0000004d}.login-form{display:flex;flex-direction:column;gap:16px}.login-field{display:flex;flex-direction:column;gap:6px}.login-label{font-size:12px;font-weight:600;color:#94a3b8;letter-spacing:.3px}.login-input-wrap{position:relative;display:flex;align-items:center}.login-input-icon{position:absolute;left:13px;color:#475569;pointer-events:none}.login-input{width:100%;background:#0f172a;border:1.5px solid rgba(255,255,255,.08);border-radius:10px;padding:11px 13px 11px 38px;font-size:14px;color:#f1f5f9;font-family:var(--font);outline:none;transition:border-color .15s,box-shadow .15s;box-sizing:border-box}.login-input::placeholder{color:#475569}.login-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6366f133}.login-eye-btn{position:absolute;right:10px;background:none;border:none;cursor:pointer;color:#475569;display:flex;padding:4px}.login-eye-btn:hover{color:#94a3b8}.login-submit-btn{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;padding:13px 20px;background:var(--accent);color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:700;font-family:var(--font);cursor:pointer;transition:background .15s,transform .1s,box-shadow .15s;box-shadow:0 4px 20px #6366f166;margin-top:4px}.login-submit-btn:hover:not(:disabled){background:var(--accent-dark);transform:translateY(-1px);box-shadow:0 6px 24px #6366f180}.login-submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-divider{display:flex;align-items:center;gap:12px}.login-divider span{flex:1;height:1px;background:#ffffff12}.login-divider small{font-size:11px;color:#475569;font-weight:600}.login-magic-btn{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;padding:12px 20px;background:transparent;border:1.5px solid rgba(255,255,255,.1);border-radius:12px;font-size:13px;font-weight:600;color:#94a3b8;font-family:var(--font);cursor:pointer;transition:all .15s}.login-magic-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:#6366f10f}.login-magic-btn:disabled{opacity:.5;cursor:not-allowed}.login-magic-sent{text-align:center;padding:16px 0 8px}.login-magic-icon{font-size:44px;margin-bottom:16px}.login-magic-title{font-size:17px;font-weight:700;color:#f1f5f9;margin-bottom:8px}.login-magic-desc{color:#64748b;font-size:13px;line-height:1.6;margin-bottom:20px}.login-magic-desc strong{color:#94a3b8}.login-back-btn{background:none;border:none;color:var(--accent);font-size:13px;font-weight:600;cursor:pointer;font-family:var(--font)}.login-back-btn:hover{text-decoration:underline}.login-footer{text-align:center;font-size:12px;color:#334155;margin-top:20px}
