:root{--bg-color:#1a1625;--surface-color:#ffffff1a;--surface-alt:#ffffff26;--primary-color:#9d59ff;--primary-glow:#9d59ff4d;--text-primary:#fff;--text-secondary:#d4d4d8;--accent-blue:#0a84ff;--accent-green:#30d158;--accent-red:#ff453a;--accent-orange:#ff9f0a;--radius-xl:20px;--radius-lg:12px;--radius-md:8px;--radius-sm:4px;--blur:24px;--border-color:#ffffff26;--shadow-main:0 8px 32px 0 #0006;--font-main:"SF Pro Display", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif}*{box-sizing:border-box;-webkit-font-smoothing:antialiased;margin:0;padding:0}html{font-size:15px}body{background-color:var(--bg-color);color:var(--text-primary);font-family:var(--font-main);min-height:100vh;overflow-x:hidden}.glass{background:var(--surface-color);-webkit-backdrop-filter:blur(var(--blur));border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-main)}.glass-panel{-webkit-backdrop-filter:blur(24px);box-shadow:var(--shadow-main);border-radius:var(--radius-lg);background:#ffffff1a;border:1px solid #ffffff26}.glass-header{-webkit-backdrop-filter:blur(40px);background:#ffffff1a;border-bottom:1px solid #ffffff26}.glass-modal{-webkit-backdrop-filter:blur(40px);box-shadow:var(--shadow-main);border-radius:var(--radius-xl);background:#ffffff26;border:1px solid #fff3}.glass-modal-overlay{-webkit-backdrop-filter:blur(12px);background:#00000080}.glass-input{-webkit-backdrop-filter:blur(12px);color:var(--text-primary);border-radius:var(--radius-md);background:#ffffff1a;border:1px solid #ffffff26}.glass-card{-webkit-backdrop-filter:blur(24px);box-shadow:var(--shadow-main);border-radius:var(--radius-lg);background:#ffffff26;border:1px solid #fff3}.glow{box-shadow:0 0 20px var(--primary-glow)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#fff3}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:.5s forwards fadeIn}.sidebar{z-index:100;flex-direction:column;width:240px;height:calc(100vh - 40px);margin:20px;padding:16px 12px;display:flex;position:sticky;top:20px}.sidebar-header{margin-bottom:12px;padding:0 8px}.logo-container{flex-direction:column;align-items:center;gap:8px;display:flex}.logo-img{object-fit:contain;width:180px;height:180px}.logo-text h1{letter-spacing:-.5px;font-size:16px;font-weight:800}.logo-text span{color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;font-size:9px}.sidebar-nav{flex-direction:column;flex:1;gap:4px;display:flex}.nav-item{border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:9px 12px;font-size:13px;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;position:relative}.nav-item:hover{color:var(--text-primary);background:#ffffff0d}.nav-item.active{color:var(--primary-color);background:#9d59ff26}.active-indicator{background:var(--primary-color);width:6px;height:6px;box-shadow:0 0 10px var(--primary-glow);border-radius:50%;position:absolute;right:12px}.sidebar-footer{flex-direction:column;gap:12px;margin-top:auto;padding:0 8px;display:flex}.export-btn{background:var(--primary-color);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;padding:12px;font-weight:600;transition:scale .2s}.export-btn:hover{scale:1.02}.user-profile{border-top:1px solid var(--border-color);align-items:center;gap:12px;padding-top:16px;display:flex}.user-avatar{background:var(--primary-color);color:#fff;border:2px solid var(--border-color);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:14px;font-weight:700;display:flex}.user-info p{font-size:14px;font-weight:600}.user-info span{color:var(--text-secondary);font-size:11px}@media (width<=1024px){.sidebar{width:80px;padding:32px 12px}.sidebar-header,.user-info,.nav-item span,.logo-container div,.export-btn{display:none}.nav-item{justify-content:center;padding:16px}}@media (width<=768px){.sidebar{border-radius:0 var(--radius-lg) var(--radius-lg) 0;z-index:150;width:280px;height:100vh;margin:0;padding:32px 16px;transition:left .3s;position:fixed;top:0;left:-300px}.sidebar.open{left:0}.sidebar-header,.user-info,.nav-item span,.logo-container div,.export-btn{display:revert}.nav-item{justify-content:flex-start;padding:14px 16px}}.layout{background:radial-gradient(circle at 100% 0,#9d59ff0d,#0000 400px),radial-gradient(circle at 0 100%,#9d59ff0d,#0000 400px);gap:0;min-height:100vh;display:flex}.main-content{flex-direction:column;flex:1;max-width:calc(100vw - 280px);padding:12px 24px;display:flex}.top-bar{border-radius:var(--radius-md);justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;padding:8px 16px;display:flex}.search-bar input{border:1px solid var(--border-color);border-radius:var(--radius-sm);color:#fff;background:#ffffff08;outline:none;width:240px;padding:6px 14px;font-size:13px}.hamburger-btn{cursor:pointer;background:0 0;border:none;flex-direction:column;flex-shrink:0;gap:5px;padding:6px;display:none}.hamburger-btn span{background:var(--text-primary);border-radius:2px;width:22px;height:2px;display:block}.sidebar-overlay{z-index:99;background:#0000008c;display:none;position:fixed;inset:0}.mobile-bottom-nav{display:none}.mobile-nav-item{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;flex-direction:column;flex:1;align-items:center;gap:4px;padding:8px 12px;font-size:10px;font-weight:600;transition:color .2s;display:flex}.mobile-nav-item.active{color:var(--primary-color)}.top-actions{align-items:center;gap:16px;display:flex}.top-btn{color:var(--text-secondary);cursor:pointer;border:none;border:1px solid var(--border-color);background:0 0;border-radius:50%;padding:8px}.profile-pill{border-radius:100px;align-items:center;gap:12px;padding:4px 4px 4px 16px;font-size:13px;font-weight:500;display:flex}.topbar-avatar{background:var(--primary-color);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;font-weight:700;display:flex}.content-area{flex:1}@media (width<=1024px){.main-content{max-width:calc(100vw - 120px)}}@media (width<=768px){.layout{flex-direction:column}.main-content{max-width:100vw;padding:12px 12px 80px}.hamburger-btn{display:flex}.search-bar{flex:1}.search-bar input{width:100%}.profile-name{display:none}.sidebar-overlay{display:block}.mobile-bottom-nav{z-index:200;padding:6px 0 env(safe-area-inset-bottom,6px);border-radius:20px 20px 0 0;justify-content:space-around;display:flex;position:fixed;bottom:0;left:0;right:0}}.balance-card{background:linear-gradient(135deg, var(--surface-color) 0%, #0c4a6e73 100%);border:1px solid var(--border-color);border-radius:var(--radius-xl);color:var(--text-primary);box-shadow:var(--shadow-main);padding:20px}.balance-card-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin-bottom:6px;font-size:11px}.balance-card-value{margin-bottom:10px;font-size:32px;font-weight:700}.balance-card-value.positive{color:var(--accent-green)}.balance-card-value.negative{color:var(--accent-red)}.balance-card-breakdown{color:var(--text-secondary);gap:18px;font-size:12px;display:flex}.balance-card-breakdown strong{font-weight:600}.balance-card-breakdown .received strong{color:var(--accent-green)}.balance-card-breakdown .expenses strong{color:var(--accent-red)}.balance-card.loading{opacity:.6}@media (width<=640px){.balance-card-value{font-size:26px}.balance-card-breakdown{flex-direction:column;gap:4px}}.dashboard-container{flex-direction:column;gap:32px;padding-bottom:40px;display:flex}.dashboard-top-grid{grid-template-columns:2fr 1fr;gap:24px;display:grid}.chart-card{flex-direction:column;gap:16px;padding:20px;display:flex}.chart-header h3,.summary-card h3,.section-header h3,.activity-header h3{margin-bottom:2px;font-size:16px;font-weight:700}.chart-header span,.summary-card p,.activity-header p{color:var(--text-secondary);letter-spacing:.5px;font-size:13px;font-weight:600}.chart-main{flex:1;justify-content:space-between;align-items:center;display:flex}.category-legend{flex-direction:column;gap:16px;display:flex}.legend-item{border-radius:var(--radius-md);background:#ffffff05;align-items:center;gap:10px;min-width:210px;padding:10px 14px;display:flex}.dot{border-radius:50%;width:8px;height:8px}.legend-item .name{flex:1;font-size:14px;font-weight:500}.legend-item .val{font-size:14px;font-weight:600}.legend-item .perc{color:var(--text-secondary);font-size:12px}.chart-viz{width:180px;height:180px;position:relative}.chart-center{text-align:center;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.chart-center h2{font-size:24px;font-weight:800}.chart-center p{color:var(--text-secondary);letter-spacing:1px;font-size:10px;font-weight:700}.summary-card{background:linear-gradient(135deg,#9d59ff1a,#1a1a24b3);padding:20px}.economy-value{margin:20px 0}.economy-value h2{margin-bottom:8px;font-size:34px;font-weight:800}.pill{background:var(--surface-alt);color:var(--primary-color);border-radius:100px;padding:6px 12px;font-size:11px;font-weight:700;display:inline-block}.progress-bar-container{margin-top:auto}.progress-bar{background:linear-gradient(90deg, var(--primary-color), var(--accent-blue));border-radius:100px;height:8px;margin-bottom:12px;box-shadow:0 0 15px #9d59ff66}.progress-labels{color:var(--text-secondary);justify-content:space-between;font-size:10px;font-weight:700;display:flex}.cards-row{grid-template-columns:repeat(4,1fr);gap:20px;margin-top:16px;display:grid}.category-card{flex-direction:column;gap:12px;padding:16px;display:flex}.cat-top{justify-content:space-between;align-items:flex-start;display:flex}.icon-box{background:#ffffff0d;border-radius:12px;padding:10px;display:flex}.status-pill{border-radius:100px;padding:4px 8px;font-size:9px;font-weight:700}.status-pill.in{color:var(--accent-green);background:#30d1581a}.status-pill.over{color:var(--accent-red);background:#ff453a1a}.category-card h4{color:var(--text-secondary);font-size:16px}.cat-value h3{font-size:20px}.cat-value small{color:var(--text-secondary);font-size:14px}.cat-progress{background:#ffffff0d;border-radius:100px;height:4px;overflow:hidden}.cat-progress .bar{background:var(--primary-color);height:100%}.recent-activity{padding:20px}.activity-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.filter-btn{background:var(--surface-alt);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;border-radius:100px;padding:10px 20px;font-size:12px;font-weight:700}.transactions-list{flex-direction:column;display:flex}.transaction-item{border-top:1px solid var(--border-color);align-items:center;gap:16px;padding:12px 0;display:flex}.t-id{color:var(--text-secondary);width:40px;font-family:monospace;font-size:12px}.t-icon-box{color:var(--primary-color);background:#ffffff08;border-radius:12px;padding:10px}.t-info{flex-direction:column;flex:1;display:flex}.t-info strong{font-size:15px}.t-info span{color:var(--text-secondary);font-size:12px}.t-amount{text-align:right;flex-direction:column;display:flex}.t-amount strong{font-size:15px}.t-amount span{font-size:10px;font-weight:700}.t-amount.up{color:var(--accent-red)}.t-amount.down{color:var(--accent-green)}.t-amount.stable{color:var(--text-secondary)}@media (width<=1280px){.dashboard-top-grid{grid-template-columns:1fr}.cards-row{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.chart-card,.recent-activity{padding:20px}.legend-item{min-width:0}.economy-value h2{font-size:36px}}@media (width<=640px){.cards-row{grid-template-columns:1fr}.chart-main{flex-direction:column;align-items:center;gap:24px}.legend-item{min-width:100%}.chart-viz{width:180px;height:180px}.t-id{display:none}.transaction-item{gap:12px}.dashboard-container{gap:20px}.summary-card{padding:20px}}.new-entry-container{max-width:800px;margin:0 auto;padding:40px 0}.new-entry-header{text-align:center;margin-bottom:24px}.new-entry-header h1{margin-bottom:4px;font-size:22px;font-weight:800}.new-entry-header p{color:var(--text-secondary);font-size:14px}.form-card{padding:20px}.form-grid{grid-template-columns:1.5fr 1fr;gap:24px;margin-bottom:24px;display:grid}.input-group.full-width{grid-column:1/-1;margin-bottom:24px}.input-group label{color:var(--text-secondary);letter-spacing:1px;font-size:10px;font-weight:700}.input-wrapper,.select-wrapper{border:1px solid var(--border-color);border-radius:var(--radius-md);background:#ffffff08;align-items:center;gap:10px;padding:10px 14px;transition:border-color .2s;display:flex}.input-wrapper:focus-within,.select-wrapper:focus-within{border-color:var(--primary-color)}.input-wrapper input,.input-wrapper textarea,.select-wrapper select{color:#fff;background:0 0;border:none;outline:none;width:100%;font-family:inherit;font-size:15px}.input-wrapper.amount input{font-size:20px;font-weight:700}.input-wrapper.amount span{color:var(--primary-color);font-size:16px;font-weight:600}.select-wrapper{cursor:pointer;position:relative}.select-wrapper select{appearance:none;cursor:pointer}.select-wrapper select option{color:#fff;background:#1a1a24}.select-icon{color:var(--text-secondary);pointer-events:none;position:absolute;right:16px}.input-wrapper.textarea textarea{resize:vertical;min-height:120px}.toggle-group{border-radius:var(--radius-md);background:#9d59ff0d;justify-content:space-between;align-items:center;margin-bottom:24px;padding:14px;display:flex}.toggle-info{align-items:center;gap:16px;display:flex}.toggle-info .text{flex-direction:column;display:flex}.toggle-info strong{font-size:14px}.toggle-info span{color:var(--text-secondary);font-size:11px}.form-actions{gap:16px;display:flex}.save-btn{background:var(--primary-color);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;flex:1;padding:12px;font-size:15px;font-weight:700;transition:transform .2s}.save-btn:active{transform:scale(.98)}.cancel-btn{border:1px solid var(--border-color);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;background:#ffffff08;flex:.5;padding:16px;font-weight:600}.switch{width:44px;height:24px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.slider{cursor:pointer;background-color:#ffffff1a;border-radius:34px;transition:all .4s;position:absolute;inset:0}.slider:before{content:"";background-color:#fff;border-radius:50%;width:18px;height:18px;transition:all .4s;position:absolute;bottom:3px;left:3px}input:checked+.slider{background-color:var(--primary-color)}input:checked+.slider:before{transform:translate(20px)}@media (width<=768px){.new-entry-container{padding:20px 0}.new-entry-header{margin-bottom:28px}.new-entry-header h1{font-size:24px}}@media (width<=640px){.form-grid{grid-template-columns:1fr}.form-actions{flex-direction:column}.form-card{padding:20px 16px}.toggle-group{flex-direction:column;align-items:flex-start;gap:12px}}.login-container{background:var(--bg-color);justify-content:center;align-items:center;width:100vw;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-visual{z-index:0;position:absolute;inset:0}.blur-circle{filter:blur(120px);opacity:.15;border-radius:50%;width:500px;height:500px;position:absolute}.blur-circle.primary{background:var(--primary-color);top:-100px;right:-100px}.blur-circle.secondary{background:var(--accent-blue);bottom:-150px;left:-100px}.login-card{z-index:10;flex-direction:column;gap:24px;width:420px;padding:36px 48px;display:flex;position:relative}.login-header{text-align:center;flex-direction:column;align-items:center;gap:8px;display:flex}.login-logo{flex-direction:column;align-items:center;gap:8px;display:flex}.logo-img-large{object-fit:contain;width:160px;height:auto}.login-header h1{letter-spacing:-.5px;font-size:28px;font-weight:800}.login-header p{color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;font-size:13px;font-weight:600}.auth-error{color:var(--accent-red);border-radius:var(--radius-sm);text-align:center;background:#ff453a1a;padding:12px;font-size:13px}.login-form{flex-direction:column;gap:24px;display:flex}.input-field{flex-direction:column;gap:8px;display:flex}.input-field label{color:var(--text-secondary);letter-spacing:1px;font-size:10px;font-weight:700}.input-box{border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);background:#ffffff08;align-items:center;gap:12px;padding:14px 16px;transition:all .2s;display:flex}.input-box:focus-within{border-color:var(--primary-color);color:var(--primary-color)}.input-box input{color:#fff;background:0 0;border:none;outline:none;width:100%;font-size:15px}.auth-submit{background:var(--primary-color);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;justify-content:center;align-items:center;gap:12px;margin-top:12px;padding:16px;font-size:16px;font-weight:700;transition:transform .2s;display:flex}.auth-submit:active{transform:scale(.98)}.auth-submit:disabled{opacity:.5;cursor:not-allowed}.login-footer{text-align:center}.toggle-auth{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;font-size:13px;font-weight:500;transition:color .2s}.toggle-auth:hover{color:var(--text-primary)}@media (width<=480px){.login-card{width:calc(100% - 40px);padding:32px 24px}}.calendar-view{flex-direction:column;gap:24px;display:flex}.calendar-header{justify-content:space-between;align-items:center;display:flex}.month-selector{align-items:center;gap:24px;display:flex}.month-selector h2{min-width:150px;font-size:18px;font-weight:800}.nav-btns{gap:8px;display:flex}.nav-btns button{background:var(--surface-alt);border:1px solid var(--border-color);color:#fff;cursor:pointer;border-radius:12px;padding:8px;transition:all .2s}.nav-btns button:hover{background:#ffffff0d}.add-event-btn{background:var(--primary-color);color:#fff;cursor:pointer;border:none;border-radius:100px;align-items:center;gap:8px;padding:10px 20px;font-weight:700;display:flex}.calendar-grid{padding:16px}.weekday-header{text-align:center;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;grid-template-columns:repeat(7,1fr);margin-bottom:16px;font-size:13px;font-weight:700;display:grid}.days-container{grid-template-columns:repeat(7,1fr);gap:8px;display:grid}.day-cell{aspect-ratio:1;background:#ffffff05;border:1px solid #0000;border-radius:12px;flex-direction:column;justify-content:space-between;padding:8px;transition:all .2s;display:flex}.day-cell:not(.empty):hover{border-color:var(--border-color);background:#ffffff0d}.day-cell.today{border-color:var(--primary-color);background:#9d59ff1a}.day-cell.today .day-number{color:var(--primary-color)}.day-cell.empty{visibility:hidden}.day-number{font-size:13px;font-weight:700}.day-chips{flex-direction:column;gap:3px;margin-top:4px;display:flex}.expense-chip{color:#fff;white-space:nowrap;text-overflow:ellipsis;cursor:pointer;border-radius:6px;max-width:100%;padding:2px 6px;font-size:10px;font-weight:600;line-height:1.4;transition:opacity .2s;overflow:hidden}.expense-chip:hover{opacity:.8}.expense-chip.chip-pago{opacity:.35;text-decoration:line-through}.upcoming-events{padding:16px}.upcoming-events h3{margin-bottom:16px;font-size:16px}.events-list{flex-direction:column;gap:16px;display:flex}.event-item{border-radius:var(--radius-md);background:#ffffff05;align-items:center;gap:20px;padding:12px 16px;display:flex}.event-date{background:var(--surface-alt);border-radius:12px;flex-direction:column;align-items:center;min-width:50px;padding:8px;display:flex}.event-date span{font-size:18px;font-weight:800}.event-date small{color:var(--text-secondary);text-transform:uppercase;font-size:10px}.event-info{flex-direction:column;flex:1;display:flex}.event-info strong{font-size:15px}.event-info span{color:var(--text-secondary);font-size:12px}.event-amount{color:var(--primary-color);font-size:16px;font-weight:700}@media (width<=768px){.day-cell{padding:8px}.day-number{font-size:13px}.month-selector h2{min-width:140px;font-size:18px}.calendar-header{flex-direction:column;align-items:flex-start;gap:12px}.calendar-grid{padding:16px}.upcoming-events{padding:20px}}@media (width<=480px){.days-container{gap:4px}.day-cell{border-radius:10px;padding:6px}.day-number{font-size:12px}.expense-chip{font-size:9px}.weekday-header{font-size:11px}.month-selector{gap:12px}.month-selector h2{min-width:110px;font-size:16px}.add-event-btn span{display:none}}.reports-view{flex-direction:column;gap:24px;display:flex}.report-summary-cards{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.rcard{border-radius:var(--radius-lg,12px);align-items:center;gap:12px;padding:12px 16px;display:flex}.rcard div{flex-direction:column;gap:4px;display:flex}.rcard span{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:12px}.rcard h3{font-size:16px;font-weight:800}.report-section{border-radius:var(--radius-lg,12px);padding:16px 20px}.report-section h3{margin-bottom:12px;font-size:15px;font-weight:700}.report-section-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.report-section-header h3{margin-bottom:0}.filter-tabs{gap:8px;display:flex}.report-table{border-collapse:collapse;width:100%;font-size:14px}.report-table th{text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color);padding:10px 14px;font-size:12px}.report-table td{border-bottom:1px solid #ffffff0a;padding:10px 14px}.report-table tr:last-child td{border-bottom:none}.export-btn-page{background:var(--primary-color);color:#fff;cursor:pointer;border:none;border-radius:100px;padding:10px 24px;font-size:14px;font-weight:700}@media (width<=768px){.report-summary-cards{grid-template-columns:repeat(2,1fr)}.report-section{padding:20px 16px}.report-section-header{flex-direction:column;align-items:flex-start;gap:12px}.filter-tabs{flex-wrap:wrap}}@media (width<=480px){.report-summary-cards{grid-template-columns:1fr}.report-section{overflow-x:auto}.report-table{min-width:460px}}.settings-container{flex-direction:column;gap:24px;padding:8px 0 40px;display:flex}.settings-header h1{margin-bottom:4px;font-size:1.6rem;font-weight:600}.settings-header p{color:var(--text-secondary);font-size:.9rem}.settings-tabs{background:var(--surface-alt);border-radius:var(--radius-md);gap:8px;width:fit-content;padding:4px;display:flex}.settings-tab{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;padding:10px 16px;font-size:.9rem;transition:all .2s;display:flex}.settings-tab:hover{color:var(--text-primary)}.settings-tab.active{background:var(--primary-color);color:#fff;box-shadow:0 0 12px var(--primary-glow)}.settings-card{flex-direction:column;gap:20px;padding:24px;display:flex}.settings-card h2{font-size:1.15rem;font-weight:600}.settings-form{flex-direction:column;gap:16px;display:flex}.input-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.input-group{flex-direction:column;gap:6px;display:flex}.input-group label{letter-spacing:.06em;color:var(--text-secondary);font-size:.72rem;font-weight:600}.input-wrapper{background:var(--surface-alt);border:1px solid var(--border-color);border-radius:var(--radius-md);align-items:center;padding:10px 14px;transition:border-color .2s;display:flex}.input-wrapper:focus-within{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-glow)}.input-wrapper input,.input-wrapper select,.input-wrapper textarea{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:.95rem}.input-wrapper.readonly input{color:var(--text-secondary)}.input-wrapper.color{gap:10px}.input-wrapper.color input[type=color]{cursor:pointer;background:0 0;border:none;width:28px;height:28px;padding:0}.color-hex{color:var(--text-secondary);font-family:monospace;font-size:.85rem}.select-wrapper{position:relative}.select-wrapper select{background:var(--surface-alt);border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;color:var(--text-primary);appearance:none;cursor:pointer;padding:10px 14px;font-family:inherit;font-size:.95rem}.select-wrapper select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-glow);outline:none}.radio-stack{flex-direction:column;gap:8px;display:flex}.radio-row{background:var(--surface-alt);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;align-items:center;gap:10px;padding:10px 14px;font-size:.9rem;transition:all .2s;display:flex}.radio-row:hover{border-color:var(--primary-color)}.radio-row.active{border-color:var(--primary-color);box-shadow:0 0 0 2px var(--primary-glow)}.radio-row input[type=radio]{accent-color:var(--primary-color)}.toggle-row{cursor:pointer;align-items:center;gap:10px;font-size:.9rem;display:flex}.toggle-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary-color)}.settings-actions{align-items:center;gap:12px;margin-top:8px;display:flex}.btn-primary{background:var(--primary-color);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;align-items:center;gap:8px;padding:10px 18px;font-size:.9rem;font-weight:500;transition:transform .1s,box-shadow .2s;display:inline-flex}.btn-primary:hover{box-shadow:0 0 16px var(--primary-glow)}.btn-primary:active{transform:translateY(1px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-ghost{border:1px solid var(--border-color);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;background:0 0;padding:10px 18px;font-size:.9rem}.btn-ghost:hover{color:var(--text-primary);border-color:var(--text-secondary)}.settings-feedback{font-size:.85rem}.settings-feedback.ok{color:var(--accent-green)}.settings-feedback.err{color:var(--accent-red)}.settings-loading,.settings-empty{text-align:center;color:var(--text-secondary);padding:20px;font-size:.9rem}.settings-error{color:var(--accent-red);border-radius:var(--radius-md);background:#ff453a1a;border:1px solid #ff453a4d;padding:10px 14px;font-size:.85rem}.categories-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.category-filters{flex-wrap:wrap;gap:6px;display:flex}.filter-tab{background:var(--surface-alt);border:1px solid var(--border-color);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;padding:6px 12px;font-size:.8rem;transition:all .2s}.filter-tab:hover{color:var(--text-primary)}.filter-tab.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.category-list{flex-direction:column;gap:8px;list-style:none;display:flex}.category-row{background:var(--surface-alt);border:1px solid var(--border-color);border-radius:var(--radius-md);grid-template-columns:16px 1fr auto;align-items:center;gap:14px;padding:14px 16px;transition:border-color .2s;display:grid}.category-row:hover{border-color:#9d59ff40}.category-row.archived{opacity:.55}.category-swatch{width:12px;height:12px;box-shadow:0 0 0 2px var(--border-color);border-radius:50%}.category-main{flex-direction:column;gap:4px;min-width:0;display:flex}.category-title{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.category-title strong{font-size:.95rem;font-weight:600}.category-type{text-transform:uppercase;letter-spacing:.06em;border-radius:var(--radius-sm);color:var(--text-secondary);background:#ffffff0f;padding:2px 8px;font-size:.7rem}.category-type.type-expense{color:var(--accent-red);background:#ff453a1f}.category-type.type-income{color:var(--accent-green);background:#30d1581f}.category-type.type-both{color:var(--accent-blue);background:#0a84ff1f}.badge-muted{text-transform:uppercase;letter-spacing:.06em;border-radius:var(--radius-sm);color:var(--text-secondary);background:#ffffff0a;padding:2px 8px;font-size:.7rem}.category-meta{color:var(--text-secondary);gap:14px;font-size:.8rem;display:flex}.category-actions{gap:6px;display:flex}.icon-btn{border-radius:var(--radius-sm);border:1px solid var(--border-color);width:34px;height:34px;color:var(--text-secondary);cursor:pointer;background:0 0;justify-content:center;align-items:center;transition:all .15s;display:flex}.icon-btn:hover{color:var(--text-primary);border-color:var(--primary-color)}.icon-btn.danger:hover{color:var(--accent-red);border-color:var(--accent-red)}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#00000080;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{flex-direction:column;gap:18px;width:100%;max-width:520px;padding:24px;display:flex}.modal-header{justify-content:space-between;align-items:center;display:flex}.modal-header h3{font-size:1.1rem;font-weight:600}@media (width<=640px){.input-row{grid-template-columns:1fr}.categories-toolbar{flex-direction:column;align-items:stretch}.category-row{grid-template-columns:12px 1fr}.category-actions{grid-column:1/-1;justify-content:flex-end}}.income-modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:900;background:#0000008c;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.income-modal{background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-main);width:100%;max-width:460px;max-height:92vh;padding:20px;overflow-y:auto}.income-modal header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.income-modal header h2{color:var(--text-primary);margin:0;font-size:18px}.income-modal-close{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:0;padding:4px}.income-modal-close:hover{background:var(--surface-alt)}.income-form{gap:12px;display:grid}.income-form label{color:var(--text-secondary);gap:4px;font-size:12px;display:grid}.income-form input,.income-form select,.income-form textarea{background:var(--surface-alt);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-main);box-sizing:border-box;width:100%;padding:10px 12px;font-size:14px}.income-form input:focus,.income-form select:focus,.income-form textarea:focus{outline:2px solid var(--primary-color);outline-offset:0}.income-form-row{grid-template-columns:1fr 1fr;gap:8px;display:grid}.income-status-toggle{gap:6px;display:flex}.income-status-toggle button{border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--surface-alt);color:var(--text-secondary);cursor:pointer;flex:1;padding:10px;font-size:14px;font-weight:500}.income-status-toggle button.active.recebido{background:var(--accent-green);color:#fff;border-color:var(--accent-green)}.income-status-toggle button.active.previsto{background:var(--accent-orange);color:#fff;border-color:var(--accent-orange)}.income-form-actions{gap:8px;margin-top:8px;display:flex}.income-form-actions button{border-radius:var(--radius-md);cursor:pointer;border:0;flex:1;padding:12px;font-size:14px;font-weight:600}.income-form-cancel{background:var(--surface-alt);color:var(--text-secondary)}.income-form-submit{background:var(--accent-green);color:#fff}.income-form-submit:disabled{opacity:.6;cursor:not-allowed}.income-form-error{border:1px solid var(--accent-red);color:var(--accent-red);border-radius:var(--radius-md);background:#ff47571f;padding:8px 12px;font-size:13px}@media (width<=640px){.income-form-row{grid-template-columns:1fr}}.toast-container{z-index:1000;pointer-events:none;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.toast{background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-main);pointer-events:auto;min-width:260px;max-width:420px;color:var(--text-primary);align-items:center;gap:12px;padding:12px 16px;animation:.22s ease-out toast-in;display:flex}.toast.toast-success{border-left:3px solid var(--accent-green)}.toast.toast-error{border-left:3px solid var(--accent-red)}.toast-message{flex:1;font-size:14px}.toast-action{color:var(--primary-color);cursor:pointer;background:0 0;border:0;padding:4px 8px;font-size:13px;font-weight:600}.toast-action:hover{text-decoration:underline}@keyframes toast-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.incomes-page{gap:16px;padding:4px 0 24px;display:grid}.incomes-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.incomes-header h1{color:var(--text-primary);margin:0;font-size:22px}.incomes-btn-new{background:var(--accent-green);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:0;align-items:center;gap:6px;padding:10px 16px;font-size:14px;font-weight:600;display:inline-flex}.incomes-totals{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.incomes-total-card{border-radius:var(--radius-lg);border:1px solid var(--border-color);color:var(--text-primary);padding:14px}.incomes-total-card .label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin-bottom:4px;font-size:10px}.incomes-total-card .value{font-size:20px;font-weight:700}.incomes-total-card.received{background:#22c55e26}.incomes-total-card.received .value{color:var(--accent-green)}.incomes-total-card.planned{background:#fb923c1f}.incomes-total-card.planned .value{color:var(--accent-orange)}.incomes-total-card.total{background:var(--surface-color)}.incomes-filters{gap:8px;padding-bottom:4px;display:flex;overflow-x:auto}.incomes-filters select,.incomes-filters input[type=date]{background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:13px;font-family:var(--font-main);flex-shrink:0;padding:6px 10px}.incomes-custom-range{color:var(--text-secondary);align-items:center;gap:6px;font-size:12px;display:flex}.incomes-list{gap:12px;display:grid}.incomes-group{background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:12px 14px}.incomes-group-header{text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);border-bottom:1px solid var(--border-color);justify-content:space-between;margin-bottom:4px;padding-bottom:8px;font-size:11px;display:flex}.incomes-group-header strong{color:var(--accent-green);font-weight:600}.income-row{border-bottom:1px solid var(--border-color);color:var(--text-primary);justify-content:space-between;align-items:center;padding:10px 0;display:flex}.income-row:last-child{border-bottom:0}.income-row .info{gap:2px;display:grid}.income-row .info strong{color:var(--text-primary);font-size:14px}.income-row .info small{color:var(--text-secondary);font-size:11px}.income-row .right{align-items:center;gap:10px;display:flex}.income-row .amount{font-weight:600}.income-row.recebido .amount{color:var(--accent-green)}.income-row.previsto .amount{color:var(--accent-orange)}.income-row-actions{position:relative}.income-row-menu-btn{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:0;padding:4px 8px}.income-row-menu-btn:hover{background:var(--surface-alt)}.income-row-menu{background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-main);z-index:10;min-width:140px;padding:4px;position:absolute;top:100%;right:0}.income-row-menu button{text-align:left;width:100%;color:var(--text-primary);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:0;padding:8px 10px;font-size:13px;display:block}.income-row-menu button:hover{background:var(--surface-alt)}.income-row-menu button.danger{color:var(--accent-red)}.income-mark-received{background:var(--accent-green);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:0;padding:6px 10px;font-size:12px;font-weight:600}.incomes-empty{background:var(--surface-color);border:1px dashed var(--border-color);border-radius:var(--radius-lg);text-align:center;color:var(--text-secondary);padding:32px}.incomes-empty button{background:var(--accent-green);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:0;margin-top:12px;padding:8px 14px;font-weight:600}@media (width<=640px){.incomes-totals{grid-template-columns:1fr}.incomes-header{flex-direction:column;align-items:stretch}}.placeholder-view{text-align:center;flex-direction:column;justify-content:center;gap:16px;min-height:400px;padding:64px;display:flex}.placeholder-view h2{color:var(--primary-color);font-size:24px;font-weight:800}.placeholder-view p{color:var(--text-secondary)}.view-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.view-header h1{font-size:22px;font-weight:800}.view-actions{background:#ffffff08;border-radius:100px;gap:8px;padding:4px;display:flex}.filter-tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:100px;padding:8px 16px;font-size:13px;font-weight:600}.filter-tab.active{background:var(--surface-alt);color:#fff;box-shadow:0 4px 12px #0003}.expenses-list{flex-direction:column;display:flex}.expense-row{border-bottom:1px solid var(--border-color);align-items:center;padding:14px 20px;transition:background .2s;display:flex}.expense-row:last-child{border-bottom:none}.expense-row:hover{background:#ffffff03}.exp-info{flex-direction:column;flex:1;display:flex}.exp-info strong{margin-bottom:2px;font-size:14px}.exp-info span{color:var(--text-secondary);font-size:11px}.exp-status{text-align:center;width:150px}.status-tag{border-radius:100px;padding:4px 12px;font-size:10px;font-weight:700}.status-tag.pago{color:var(--accent-green);background:#30d1581a}.status-tag.pendente{color:var(--accent-orange);background:#ff9f0a1a}.exp-amount{text-align:right;width:140px}.exp-amount strong{color:var(--primary-color);font-size:16px}.delete-btn{color:var(--accent-red);cursor:pointer;opacity:0;background:#ff453a1a;border:none;border-radius:8px;margin-left:16px;padding:8px 12px;font-size:11px;font-weight:700;transition:opacity .2s}.expense-row:hover .delete-btn{opacity:1}.loading-state{min-height:400px;color:var(--text-secondary);justify-content:center;align-items:center;font-weight:600;display:flex}.empty-msg{text-align:center;color:var(--text-secondary);padding:40px}
