@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=JetBrains+Mono:wght@400;500&display=swap";*{margin:0;padding:0;box-sizing:border-box}html,body{overflow-x:hidden;width:100%;max-width:100vw}:root{--font: "DM Sans", sans-serif;--mono: "JetBrains Mono", monospace}.app{font-family:var(--font);min-height:100vh;display:flex;transition:background .3s,color .3s;overflow-x:hidden;max-width:100vw}.app.light{--bg: #f5f5f0;--bg2: #ffffff;--bg3: #fafaf8;--border: #e5e5dd;--text: #1a1a1a;--text2: #6b6b63;--text3: #9b9b93;--accent: #2563eb;--accent2: #1d4ed8;--success: #059669;--success-bg: #ecfdf5;--danger: #dc2626;--danger-bg: #fef2f2;--warning: #d97706;--warning-bg: #fffbeb;--info: #0891b2;--info-bg: #ecfeff;--sidebar-bg: #1a1a1a;--sidebar-text: #e5e5dd;--sidebar-hover: #2a2a2a;--sidebar-active: #333333;--card-shadow: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--card-shadow-hover: 0 4px 12px rgba(0,0,0,.08)}.app.dark{--bg: #0f0f0f;--bg2: #1a1a1a;--bg3: #222222;--border: #333333;--text: #e5e5dd;--text2: #9b9b93;--text3: #6b6b63;--accent: #3b82f6;--accent2: #2563eb;--success: #10b981;--success-bg: #064e3b33;--danger: #ef4444;--danger-bg: #7f1d1d33;--warning: #f59e0b;--warning-bg: #78350f33;--info: #06b6d4;--info-bg: #16475533;--sidebar-bg: #0a0a0a;--sidebar-text: #e5e5dd;--sidebar-hover: #1a1a1a;--sidebar-active: #222222;--card-shadow: 0 1px 3px rgba(0,0,0,.3);--card-shadow-hover: 0 4px 12px rgba(0,0,0,.4)}.app.light,.app.dark{color:var(--text);background:var(--bg)}body{background:var(--bg);color:var(--text)}.sidebar{width:240px;min-height:100vh;background:var(--sidebar-bg);color:var(--sidebar-text);display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:100;transition:transform .3s cubic-bezier(.4,0,.2,1)}.sidebar-header{padding:20px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid #333}.logo-icon-sm{color:var(--accent)}.sidebar-title{font-size:18px;font-weight:700;letter-spacing:-.5px}.sidebar-nav{flex:1;padding:12px 8px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;border:none;background:transparent;color:var(--sidebar-text);cursor:pointer;font-size:14px;font-family:var(--font);transition:background .15s;width:100%;text-align:left}.nav-item:hover{background:var(--sidebar-hover)}.nav-item.active{background:var(--sidebar-active);color:var(--accent);font-weight:600}.nav-item-admin{color:#fbbf24}.nav-item-admin.active{color:#fbbf24;background:#fbbf2426}.nav-item-admin:hover{color:#fcd34d}.admin-toast{position:fixed;bottom:24px;right:24px;z-index:300;padding:12px 18px;border-radius:10px;background:var(--bg2);border:1px solid var(--border);color:var(--text);font-size:13px;box-shadow:0 8px 24px #0000002e;animation:toastIn .25s ease-out;max-width:340px}.admin-toast-success{border-color:var(--success);color:var(--success)}.admin-toast-error{border-color:var(--danger);color:var(--danger)}@keyframes toastIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:600px){.admin-toast{left:12px;right:12px;max-width:none;bottom:12px}}.nav-divider{height:1px;background:#333;margin:6px 12px}.sidebar-footer{padding:12px 8px;border-top:1px solid #333;display:flex;flex-direction:column;gap:2px}.guest-badge{text-align:center;padding:6px;margin:4px 8px;border-radius:6px;background:var(--warning);color:#1a1a1a;font-size:11px;font-weight:600}.sidebar-version{margin:8px 8px 0;padding:8px 10px;background:transparent;border:1px solid #2a2a2a;border-radius:8px;color:var(--sidebar-text);cursor:pointer;font-size:11px;font-family:var(--mono);display:flex;align-items:center;gap:8px;opacity:.7;transition:opacity .15s,background .15s,border-color .15s}.sidebar-version:hover{opacity:1;background:var(--sidebar-hover);border-color:var(--accent)}.sidebar-version-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 25%,transparent);flex-shrink:0}.sidebar-version-hint{margin-left:auto;font-size:10px;font-family:var(--font);text-transform:uppercase;letter-spacing:.5px;opacity:.65}.sidebar-overlay{display:none}@media(max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99}}.main{flex:1;margin-left:240px;display:flex;flex-direction:column;min-height:100vh;background:var(--bg)}@media(max-width:768px){.main{margin-left:0}}.topbar{height:56px;padding:0 24px;display:flex;align-items:center;gap:12px;background:var(--bg2);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50}.topbar-title{font-size:16px;font-weight:600;letter-spacing:-.3px;flex:1}.topbar-right{display:flex;align-items:center;gap:8px}.user-name{font-size:13px;color:var(--text2)}.hamburger{display:none}@media(max-width:768px){.hamburger{display:flex}}.content{flex:1;padding:24px;max-width:1100px;width:100%;margin:0 auto;overflow-x:hidden}@media(max-width:768px){.content{padding:16px}}.page-content{animation:fadeIn .25s ease-out;overflow-x:hidden;max-width:100%}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}.page-header h2{font-size:24px;font-weight:700;letter-spacing:-.5px}.header-actions{display:flex;gap:8px}.card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;box-shadow:var(--card-shadow);transition:box-shadow .2s}.card:hover{box-shadow:var(--card-shadow-hover)}.card-metric{padding:20px}.card-metric-label{font-size:13px;color:var(--text2);font-weight:500;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.card-metric-value{font-size:28px;font-weight:700;font-family:var(--mono);letter-spacing:-1px;color:var(--text)}.card-metric-value-sm{font-size:22px}.card-metric-detail{font-size:12px;color:var(--text3);margin-top:4px}.table-actions{display:flex;gap:4px;flex-wrap:nowrap;align-items:center;justify-content:flex-end;white-space:nowrap}.table-actions .btn-icon{width:32px;height:32px;flex-shrink:0}.cat-form-row{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-end}.breakdown{margin-top:10px;display:flex;flex-direction:column;gap:6px}.breakdown-row{display:flex;align-items:center;gap:8px}.breakdown-label{font-size:11px;color:var(--text2);width:78px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.breakdown-track{flex:1;height:5px;border-radius:99px;background:var(--border);overflow:hidden}.breakdown-fill{height:100%;border-radius:99px;transition:width .4s ease}.breakdown-val{font-size:11px;font-family:var(--mono);color:var(--text2);width:80px;text-align:right;flex-shrink:0}.sort-hint{font-size:11px;color:var(--text3);margin-bottom:10px;padding:5px 10px;background:var(--bg2);border-radius:6px;border-left:2px solid var(--border)}.card-danger .card-metric-value{color:var(--danger)}.card-warning .card-metric-value{color:var(--warning)}.card-success .card-metric-value{color:var(--success)}.card-info .card-metric-value{color:var(--info)}.card-chart{padding:20px}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-bottom:24px}@media(max-width:600px){.dashboard-grid{grid-template-columns:1fr;gap:12px}}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:8px;font-size:14px;font-weight:500;font-family:var(--font);cursor:pointer;transition:all .15s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent2)}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text)}.btn-outline:hover{background:var(--bg3)}.btn-ghost{background:transparent;color:var(--text2)}.btn-ghost:hover{background:var(--bg3);color:var(--text)}.btn-sm{padding:5px 10px;font-size:13px}.btn-xs{padding:3px 8px;font-size:12px;border-radius:6px}.btn-full{width:100%;justify-content:center}.btn-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;color:var(--text2);cursor:pointer;border-radius:8px}.btn-icon:hover{background:var(--bg3);color:var(--text)}.btn-icon-danger:hover{background:var(--danger-bg);color:var(--danger)}.form-group{margin-bottom:12px}.form-group label{display:block;font-size:13px;font-weight:500;color:var(--text2);margin-bottom:4px}input,select{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:8px;background:var(--bg3);color:var(--text);font-size:14px;font-family:var(--font);transition:border-color .15s}input:focus,select:focus{outline:none;border-color:var(--accent)}.select-sm{padding:4px 8px;font-size:12px;border-radius:6px;width:auto}.checkbox-row{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:14px;cursor:pointer}.checkbox-row input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px}.table-wrapper{overflow-x:auto}table{width:100%;border-collapse:collapse}th{text-align:left;padding:10px 12px;font-size:12px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border)}td{padding:10px 12px;border-bottom:1px solid var(--border);font-size:14px;vertical-align:middle}tr:hover td{background:var(--bg3)}.row-paid td{opacity:.5}.empty-row{text-align:center;color:var(--text3);font-style:italic;padding:24px}.badge{display:inline-block;padding:2px 8px;border-radius:99px;font-size:11px;font-weight:600;background:var(--bg3);color:var(--text2)}.badge-card{background:var(--info-bg);color:var(--info)}.status{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:99px;font-size:12px;font-weight:600}.status-paid{background:var(--success-bg);color:var(--success)}.status-late{background:var(--danger-bg);color:var(--danger)}.status-pending{background:var(--warning-bg);color:var(--warning)}.text-success{color:var(--success);font-weight:600;font-family:var(--mono)}.text-danger{color:var(--danger);font-weight:600;font-family:var(--mono)}.fixed-list{display:flex;flex-direction:column;gap:8px}.fixed-item{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:14px 16px;transition:all .15s}.fixed-item:hover{box-shadow:var(--card-shadow-hover)}.fixed-paid{border-left:3px solid var(--success);opacity:.7}.fixed-late{border-left:3px solid var(--danger)}.fixed-partial{border-left:3px solid var(--warning)}.pay-fixed-modal{display:flex;flex-direction:column;gap:12px;max-height:calc(90vh - 110px);min-height:0}.pay-fixed-summary-card{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:12px 14px;display:flex;flex-direction:column;gap:8px;flex:0 0 auto}.pay-fixed-summary-row{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.pay-fixed-summary-label{font-size:14px;font-weight:600;color:var(--text)}.pay-fixed-summary-value{font-family:var(--mono);font-weight:700;font-size:15px;color:var(--text)}.pay-fixed-progress{height:6px;border-radius:3px;background:var(--bg2);overflow:hidden}.pay-fixed-progress-fill{height:100%;border-radius:3px;transition:width .25s ease,background .25s ease}.pay-fixed-summary-meta{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;font-size:12px;color:var(--text2)}.pay-fixed-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;flex:0 0 auto}.pay-fixed-search{position:relative;flex:1 1 200px;min-width:0;display:flex;align-items:center}.pay-fixed-search-icon{position:absolute;left:10px;pointer-events:none;font-size:13px;opacity:.7}.pay-fixed-search input{width:100%;padding:8px 32px 8px 30px;font-size:13px;font-family:var(--font);border:1px solid var(--border);border-radius:8px;background:var(--bg2);color:var(--text);transition:border-color .15s}.pay-fixed-search input:focus{outline:none;border-color:var(--accent)}.pay-fixed-search-clear{position:absolute;right:8px;background:transparent;border:none;cursor:pointer;color:var(--text3);font-size:13px;padding:4px;border-radius:4px;transition:background .15s,color .15s}.pay-fixed-search-clear:hover{background:var(--bg3);color:var(--text)}.pay-fixed-list{flex:1 1 auto;min-height:140px;overflow-y:auto;border:1px solid var(--border);border-radius:10px;background:var(--bg2);display:flex;flex-direction:column}.pay-fixed-row{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .15s}.pay-fixed-row:last-child{border-bottom:none}.pay-fixed-row:hover{background:var(--bg3)}.pay-fixed-row.is-checked{background:var(--success-bg)}.pay-fixed-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.pay-fixed-row-info{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:4px}.pay-fixed-row-name{display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:13px}.pay-fixed-row-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:11px;color:var(--text3)}.pay-fixed-row-date{font-family:var(--mono);font-size:11px;color:var(--text3)}.pay-fixed-row-amount{font-family:var(--mono);font-weight:600;font-size:13px;color:var(--danger);white-space:nowrap;flex-shrink:0}.pay-fixed-footer{display:flex;gap:10px;flex:0 0 auto;align-items:stretch;padding-top:4px}.pay-fixed-footer .btn{white-space:nowrap;justify-content:center;padding:10px 16px;font-weight:600}.pay-fixed-footer-cancel{flex:0 0 auto;min-width:110px}.pay-fixed-footer-confirm{flex:1 1 auto;min-width:0}@media(max-width:600px){.pay-fixed-modal{gap:10px;max-height:calc(95vh - 90px)}.pay-fixed-list{min-height:120px}.pay-fixed-summary-row{gap:4px}.pay-fixed-summary-label{font-size:13px}.pay-fixed-summary-value{font-size:14px}.pay-fixed-summary-meta{font-size:11px}.pay-fixed-toolbar{gap:6px}.pay-fixed-toolbar .btn{font-size:11px;padding:6px 10px}.pay-fixed-row{padding:10px;gap:8px}.pay-fixed-row-name,.pay-fixed-row-amount{font-size:13px}.pay-fixed-footer{flex-direction:column-reverse;gap:8px}.pay-fixed-footer .btn,.pay-fixed-footer-cancel,.pay-fixed-footer-confirm{width:100%;min-width:0;flex:0 0 auto}}.plan-goal-expenses-form{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end;padding:12px;border-radius:8px;background:var(--bg3);margin-bottom:16px}.plan-goal-expenses-group-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-radius:6px;gap:8px;flex-wrap:wrap;background:var(--bg3);-webkit-user-select:none;user-select:none}.plan-goal-expenses-group-header.is-clickable{transition:background .15s}.plan-goal-expenses-group-header.is-clickable:hover{background:var(--bg2)}.plan-goal-expenses-group-header.is-clickable:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.plan-goal-expense-row{display:flex;align-items:center;gap:10px;padding:6px 10px;border-radius:6px;background:var(--bg3);flex-wrap:wrap}.plan-goal-expense-row input[type=text]{padding:4px 6px;font-size:13px;font-family:var(--mono);border:1px solid var(--border);border-radius:4px;background:var(--bg2);color:var(--text);text-align:right}.plan-goal-expense-row select{padding:4px 6px;font-size:13px;border-radius:4px;border:1px solid var(--border);background:var(--bg2);color:var(--text)}.fixed-item-main{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}.fixed-item-info{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.fixed-item-info strong{font-size:15px}.fixed-due{font-size:12px;color:var(--text3)}.fixed-item-right{display:flex;align-items:center;gap:10px}.fixed-amount{font-size:16px;font-weight:700;font-family:var(--mono)}.fixed-item-actions{display:flex;align-items:center;gap:8px;margin-top:10px;flex-wrap:wrap}.filter-bar{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap;align-items:center}.search-bar{display:flex;gap:8px;margin-bottom:16px;align-items:center;flex-wrap:wrap}.search-bar input[type=text]{flex:1;min-width:120px}.month-picker{width:auto!important;min-width:120px;max-width:160px;padding:7px 10px;font-size:13px;border:1px solid var(--border);border-radius:8px;background:var(--bg3);color:var(--text);font-family:var(--font);cursor:pointer;flex-shrink:0}.report-evo-bar{display:flex;align-items:center;gap:8;margin-bottom:4}.report-evo-label{font-size:11px;color:var(--text3);width:60px;text-align:right;flex-shrink:0}.report-evo-val{font-size:11px;min-width:80px;text-align:right;font-weight:600;flex-shrink:0}.report-evo-breakdown{margin-left:68px;font-size:11px;color:var(--text3);display:flex;gap:12px;flex-wrap:wrap}.report-card-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border);gap:8px}.report-purchase-dates{font-size:11px;color:var(--text3);display:flex;gap:10px;margin-top:2px;flex-wrap:wrap}.chart-bars{display:flex;flex-direction:column;gap:8px}.chart-bar-row{display:flex;align-items:center;gap:8px}.chart-bar-label{font-size:12px;color:var(--text2);min-width:80px}.chart-bar-track{flex:1;height:8px;background:var(--bg3);border-radius:99px;overflow:hidden}.chart-bar-fill{height:100%;border-radius:99px;background:var(--accent);transition:width .5s ease-out}.chart-bar-val{font-size:12px;font-family:var(--mono);color:var(--text2);min-width:80px;text-align:right}.report-bar-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}.report-bar-label{display:flex;align-items:center;gap:6px;font-size:13px;min-width:100px}.report-bar-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.report-bar-track{flex:1;height:12px;background:var(--bg3);border-radius:99px;overflow:hidden}.report-bar-fill{height:100%;border-radius:99px;transition:width .5s ease-out}.report-bar-vals{display:flex;flex-direction:column;align-items:flex-end;min-width:90px}.report-bar-vals span{font-size:13px;font-family:var(--mono)}.report-bar-pct{font-size:11px;color:var(--text3)}.report-section{padding:20px;margin-bottom:16px;overflow:visible}.report-section-title{font-size:16px;font-weight:600;margin-bottom:12px}.report-filters{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap;align-items:center}.report-filters .month-picker{min-width:120px;max-width:160px}.report-filters select{min-width:120px}.report-total-card{margin-bottom:16px;padding:10px 16px;border-left:3px solid var(--danger)}.report-cat-row{display:flex;align-items:center;gap:10px;cursor:pointer;border-radius:8px;padding:6px 4px;margin-bottom:2px;transition:background .15s}.report-cat-row:hover{background:var(--bg3)}.report-cat-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.biggest-row{align-items:center;padding:6px 0;border-bottom:1px dashed var(--border)}.biggest-row:last-child{border-bottom:none}.biggest-label{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.biggest-rank{color:var(--text3);font-weight:600;flex-shrink:0}.biggest-name{overflow-wrap:anywhere;word-break:break-word;line-height:1.3}.biggest-val{font-family:var(--mono);font-weight:700;flex-shrink:0}.report-cat-arrow{margin-left:4px;color:var(--text3);font-size:12px;transition:transform .2s;flex-shrink:0}.report-cat-detail{margin-left:20px;margin-bottom:12px;border-left:2px solid;padding-left:12px}.report-cat-item{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px;gap:8px}.report-cat-item-info{flex:1;min-width:0}.report-cat-item-name{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.report-cat-item-date{font-size:11px;color:var(--text3)}.report-cat-item-val{font-family:var(--mono);font-weight:600;color:var(--danger);flex-shrink:0}.report-legend{display:flex;gap:16px;margin-bottom:20px;font-size:12px;flex-wrap:wrap}.report-legend-item{display:flex;align-items:center;gap:4px}.report-legend-dot{width:10px;height:10px;border-radius:2px;display:inline-block}.report-chart-wrap{position:relative;padding-bottom:8px;overflow:visible}.report-chart-yaxis{position:absolute;left:0;top:0;bottom:36px;width:54px;display:flex;flex-direction:column;justify-content:space-between;pointer-events:none}.report-chart-yaxis span{font-size:10px;color:var(--text3);font-family:var(--mono);text-align:right;padding-right:6px}.report-chart-area{margin-left:54px;display:flex;align-items:flex-end;gap:6px;height:220px;border-bottom:1px solid var(--border);position:relative}.report-chart-gridline{position:absolute;left:0;right:0;height:1px;background:var(--border);opacity:.5;pointer-events:none}.report-chart-col{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end;position:relative}.report-chart-bars{display:flex;gap:3px;align-items:flex-end;width:100%;justify-content:center;height:100%}.report-chart-bar-income{width:38%;max-width:40px;height:100%;display:flex;flex-direction:column;justify-content:flex-end}.report-chart-bar-expense{width:38%;max-width:40px;display:flex;flex-direction:column-reverse;height:100%;justify-content:flex-start}.report-chart-label{position:absolute;bottom:-22px;font-size:11px;color:var(--text2);text-transform:capitalize;font-weight:500;white-space:nowrap}.report-chart-balances{margin-left:54px;display:flex;gap:6px;margin-top:28px}.report-chart-balance-item{flex:1;text-align:center;font-size:10px;font-family:var(--mono);font-weight:600;cursor:default}.report-averages{border-top:1px solid var(--border);padding-top:12px;margin-top:16px;display:flex;gap:24px;flex-wrap:wrap}.report-avg-label{font-size:12px;color:var(--text3)}.chart-tooltip{position:absolute;z-index:50;pointer-events:none;background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:10px 14px;box-shadow:0 8px 24px #00000026;transform:translate(-50%,-100%);margin-top:-12px;min-width:160px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:tooltipIn .15s ease-out}@keyframes tooltipIn{0%{opacity:0;transform:translate(-50%,-100%) scale(.95)}to{opacity:1;transform:translate(-50%,-100%) scale(1)}}.chart-tooltip-title{font-size:11px;font-weight:700;color:var(--text3);letter-spacing:.5px;margin-bottom:6px}.chart-tooltip-row{display:flex;align-items:center;gap:6px;padding:2px 0}.chart-tooltip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.chart-tooltip-label{font-size:12px;color:var(--text2);flex:1}.chart-tooltip-val{font-size:13px;font-family:var(--mono);font-weight:600;color:var(--text)}.chart-tooltip-footer{margin-top:6px;padding-top:6px;border-top:1px solid var(--border);font-size:13px;font-family:var(--mono);font-weight:700;color:var(--text);text-align:right}.cards-summary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-bottom:20px}.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px}@media(max-width:600px){.cards-grid{grid-template-columns:1fr;gap:12px}}.credit-card-display{padding:24px 24px 56px;border-radius:16px;position:relative;overflow:hidden;min-height:140px;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);color:#fff}.app.dark .credit-card-display{background:linear-gradient(135deg,#2a2a3e,#26314e,#1f4470)}.cc-flag{font-size:11px;text-transform:uppercase;letter-spacing:2px;opacity:.7}.cc-name{font-size:20px;font-weight:700;margin-top:20px;word-break:break-word}.cc-due{font-size:13px;opacity:.7;margin-top:4px}.cc-delete{color:#fff!important}.cc-details{margin-top:12px;border-top:1px solid rgba(255,255,255,.15);padding-top:10px;display:flex;flex-direction:column;gap:4px}.cc-detail-row{display:flex;justify-content:space-between;font-size:13px;opacity:.85;gap:8px}.cc-detail-row.cc-detail-sm{font-size:12px;opacity:.75}.summary-stats,.cards-summary-stats{display:flex;flex-wrap:wrap;gap:8px 14px;margin-top:12px;padding-top:12px;border-top:1px dashed var(--border)}.summary-stat,.cards-summary-stat{display:flex;flex-direction:column;gap:2px;padding:4px 12px 4px 0;border-right:1px solid var(--border)}.summary-stat:last-child,.cards-summary-stat:last-child{border-right:none;padding-right:0}.summary-stat-label,.cards-summary-stat-label{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.04em;font-weight:600}.summary-stat-value,.cards-summary-stat-value{font-family:var(--mono);font-size:14px;font-weight:700;color:var(--text)}.accounts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}@media(max-width:600px){.accounts-grid{grid-template-columns:1fr;gap:12px}}.account-card{padding:20px}.account-name{font-size:14px;color:var(--text2);font-weight:500}.account-balance{font-size:24px;font-weight:700;font-family:var(--mono);margin-top:8px;color:var(--success)}.account-card-v2{position:relative;overflow:hidden;padding:20px;border-radius:16px;color:#fff;border:none;min-height:170px;display:flex;flex-direction:column;gap:8px;box-shadow:0 4px 14px #0000002e;transition:transform .18s,box-shadow .18s}.account-card-v2:hover{transform:translateY(-2px);box-shadow:0 8px 22px #00000040}.account-card-decoration{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(circle at 100% 0%,rgba(255,255,255,.12) 0,transparent 38%),radial-gradient(circle at 0% 100%,rgba(255,255,255,.07) 0,transparent 45%)}.account-card-top{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.account-card-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff}.account-card-label{font-size:10px;font-weight:700;letter-spacing:2px;opacity:.65}.account-card-name{position:relative;z-index:1;font-size:16px;font-weight:600;opacity:.92;letter-spacing:.2px}.account-card-balance{position:relative;z-index:1;display:flex;align-items:center;gap:8px;cursor:pointer;margin-top:auto}.account-card-value{font-size:26px;font-weight:700;font-family:var(--mono);letter-spacing:-.5px}.account-card-value.is-negative{color:#fecaca}.account-card-edit-icon{opacity:.55;transition:opacity .15s}.account-card-balance:hover .account-card-edit-icon{opacity:1}.account-card-edit{position:relative;z-index:1;display:flex;gap:6px;align-items:center;margin-top:auto}.account-card-edit input{flex:1;font-family:var(--mono);font-size:18px;font-weight:700;background:#ffffff2e;border:1px solid rgba(255,255,255,.3);color:#fff;padding:6px 10px;border-radius:8px}.account-card-edit input::placeholder{color:#ffffff8c}.account-card-edit input:focus{outline:none;border-color:#ffffffb3}.account-card-edit-btn{width:32px;height:32px;border:none;border-radius:8px;background:#ffffff2e;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s}.account-card-edit-btn:hover{background:#ffffff4d}.account-card-share{position:relative;z-index:1;display:flex;align-items:center;gap:8px;margin-top:4px}.account-card-share-track{flex:1;height:6px;border-radius:99px;background:#ffffff2e;overflow:hidden}.account-card-share-fill{height:100%;border-radius:99px;transition:width .4s ease}.account-card-share-label{font-size:10px;opacity:.75;font-family:var(--mono);white-space:nowrap}@media(max-width:600px){.account-card-v2{padding:14px;min-height:140px}.account-card-value{font-size:20px}.account-card-name{font-size:14px}.account-card-icon{width:30px;height:30px}}.alert-card{display:flex;align-items:flex-start;gap:12px;padding:16px 20px;margin-bottom:16px;border-radius:12px}.alert-card p{font-size:14px;margin-top:4px}.alert-ok{background:var(--success-bg);color:var(--success);border:1px solid var(--success)}.alert-warn{background:var(--warning-bg);color:var(--warning);border:1px solid var(--warning)}.alert-critical{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger)}.savings-rate{font-size:40px;font-weight:700;font-family:var(--mono);color:var(--accent)}.quick-actions{display:flex;gap:10px;flex-wrap:wrap}.info-box{padding:10px 14px;border-radius:8px;background:var(--info-bg);color:var(--info);font-size:13px}.empty-state{text-align:center;padding:40px;color:var(--text3);font-size:14px}.emergency-btns{display:flex;gap:4px;margin-top:8px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200;padding:16px}.modal-content{background:var(--bg2);border:1px solid var(--border);border-radius:16px;width:100%;max-width:440px;max-height:90vh;overflow-y:auto;animation:modalIn .2s ease-out}.modal-wide{max-width:640px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.modal-header h3{font-size:16px;font-weight:600}.modal-body{padding:20px}@keyframes modalIn{0%{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.changelog-list{display:flex;flex-direction:column;gap:24px}.changelog-entry{padding-bottom:20px;border-bottom:1px solid var(--border)}.changelog-entry:last-child{border-bottom:none;padding-bottom:0}.changelog-entry-header{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:6px}.changelog-version{font-size:18px;font-weight:700;font-family:var(--mono);color:var(--text);letter-spacing:-.3px}.changelog-current{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:2px 8px;border-radius:99px;background:var(--accent);color:#fff}.changelog-date{font-size:12px;color:var(--text3);font-family:var(--mono);margin-left:auto}.changelog-title{font-size:14px;color:var(--text2);margin-bottom:12px;font-weight:500}.changelog-changes{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.changelog-change{display:flex;align-items:flex-start;gap:10px;font-size:13px;line-height:1.5}.changelog-tag{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;padding:2px 8px;border-radius:99px;flex-shrink:0;margin-top:1px;min-width:64px;text-align:center}.changelog-text{flex:1;color:var(--text)}@media(max-width:600px){.changelog-version{font-size:16px}.changelog-date{font-size:11px}.changelog-change{font-size:12px;gap:6px;flex-wrap:wrap}.changelog-tag{font-size:9px;min-width:56px;padding:2px 6px}}.login-page{width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);position:relative;overflow:hidden}.login-bg-shapes{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.shape{position:absolute;border-radius:50%;opacity:.08}.shape-1{width:400px;height:400px;background:var(--accent);top:-100px;right:-100px}.shape-2{width:300px;height:300px;background:var(--success);bottom:-50px;left:-50px}.shape-3{width:200px;height:200px;background:var(--warning);top:40%;left:60%}.login-card{background:var(--bg2);border:1px solid var(--border);border-radius:20px;padding:40px;width:100%;max-width:400px;position:relative;box-shadow:var(--card-shadow)}.login-logo{text-align:center;margin-bottom:28px}.logo-icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:16px;background:var(--accent);color:#fff;margin-bottom:12px}.login-logo h1{font-size:24px;font-weight:700;letter-spacing:-.5px}.login-subtitle{font-size:13px;color:var(--text3);margin-top:4px}.login-hint{font-size:12px;color:var(--text3);text-align:center;margin-top:16px}.login-divider{text-align:center;margin:16px 0;position:relative}.login-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border)}.login-divider span{background:var(--bg2);padding:0 12px;position:relative;font-size:12px;color:var(--text3)}.theme-toggle-login{position:absolute;top:16px;right:16px}.alert{padding:8px 12px;border-radius:8px;font-size:13px;margin-bottom:12px}.alert-error{background:var(--danger-bg);color:var(--danger)}.alert-success{background:var(--success-bg);color:var(--success)}.balance-display{font-size:32px;font-weight:700;font-family:var(--mono);color:var(--accent);text-align:center;margin:16px 0}.balance-buttons{display:flex;gap:8px;justify-content:center}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:12px}.loading-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.calc-wrap{position:fixed;z-index:9999;width:260px;background:var(--bg1);border:1px solid var(--border);border-radius:16px;box-shadow:0 20px 60px #00000059;overflow:hidden;-webkit-user-select:none;user-select:none}.calc-titlebar{display:flex;align-items:center;justify-content:space-between;padding:10px 12px 8px;background:var(--bg2);border-bottom:1px solid var(--border);cursor:grab}.calc-titlebar:active{cursor:grabbing}.calc-title{font-size:12px;font-weight:600;color:var(--text2);display:flex;align-items:center}.calc-close{background:none;border:none;color:var(--text3);cursor:pointer;display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;transition:background .15s,color .15s}.calc-close:hover{background:var(--danger-bg);color:var(--danger)}.calc-display{padding:12px 16px 8px;background:var(--bg2);text-align:right;min-height:68px;display:flex;flex-direction:column;justify-content:flex-end}.calc-expr{font-size:11px;color:var(--text3);font-family:var(--mono);min-height:16px;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:flex;align-items:center;justify-content:space-between;gap:6px}.calc-paste-btn{display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border);border-radius:4px;color:var(--text3);cursor:pointer;padding:2px 4px;flex-shrink:0;transition:all .15s}.calc-paste-btn:hover{background:var(--bg3);color:var(--text)}.calc-value{font-size:28px;font-weight:600;font-family:var(--mono);color:var(--text);line-height:1.1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border-top:1px solid var(--border)}.calc-btn{background:var(--bg1);border:none;color:var(--text);font-size:16px;font-weight:500;padding:16px 0;cursor:pointer;transition:background .1s;font-family:var(--mono)}.calc-btn:hover{background:var(--bg2)}.calc-btn:active{background:var(--border)}.calc-btn-fn{background:var(--bg2);color:var(--text2);font-size:15px}.calc-btn-fn:hover{background:var(--border)}.calc-btn-op{background:var(--bg2);color:var(--accent);font-size:18px;font-weight:700}.calc-btn-op:hover{background:color-mix(in srgb,var(--accent) 15%,var(--bg2))}.calc-btn-eq{background:var(--accent);color:#fff;font-size:18px;font-weight:700}.calc-btn-eq:hover{filter:brightness(1.1)}.calc-btn-zero{grid-column:span 1}.plan-income-card{display:flex;align-items:center;gap:14px;padding:16px 20px;background:var(--bg2);border:1px solid var(--border);border-radius:12px;margin-bottom:20px;cursor:pointer;transition:border-color .15s}.plan-income-card:hover{border-color:var(--accent)}.plan-income-icon{width:40px;height:40px;background:color-mix(in srgb,var(--success) 15%,transparent);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.plan-income-info{display:flex;flex-direction:column;flex:1}.plan-income-label{font-size:11px;font-weight:600;color:var(--text3);letter-spacing:.05em}.plan-income-value{font-size:22px;font-weight:700;color:var(--success);font-family:var(--mono)}.plan-income-hint{font-size:12px;color:var(--text3);flex-shrink:0}.plan-mode-toggle{display:inline-flex;background:var(--bg2);border:1px solid var(--border);border-radius:8px;overflow:hidden;margin-bottom:20px}.plan-mode-btn{padding:8px 18px;font-size:13px;font-weight:500;border:none;background:transparent;color:var(--text2);cursor:pointer;transition:background .15s,color .15s}.plan-mode-btn.active{background:var(--text);color:var(--bg);font-weight:600}.plan-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:24px}@media(max-width:800px){.plan-grid{grid-template-columns:1fr}}.plan-chart-card,.plan-controls-card{padding:28px}.plan-section-title{font-size:16px;font-weight:600;margin-bottom:24px}.plan-donut-wrap{position:relative;display:flex;justify-content:center;align-items:center;margin-bottom:24px}.plan-donut-center{position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:center}.plan-donut-value{font-size:26px;font-weight:700;font-family:var(--mono);color:var(--text)}.plan-donut-label{font-size:13px;color:var(--text3)}.plan-legend{display:flex;flex-wrap:wrap;gap:8px 20px;margin-bottom:20px}.plan-legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text2)}.plan-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.plan-reset-btn{width:100%}.plan-sliders{display:flex;flex-direction:column;gap:20px}.plan-slider-row{position:relative;padding-right:28px}.plan-slider-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.plan-slider-name{font-size:14px;font-weight:500}.plan-slider-input-wrap{display:flex;align-items:center;gap:4px}.plan-slider-input{width:72px;padding:4px 8px;border-radius:6px;border:1px solid var(--border);background:var(--bg2);color:var(--text);font-family:var(--mono);font-size:14px;text-align:right;font-weight:600}.plan-slider-input:focus{outline:none;border-color:var(--accent)}.plan-slider-unit{font-size:12px;color:var(--text3);min-width:16px}.plan-slider-delete{position:absolute;right:0;top:50%;transform:translateY(-50%);width:22px;height:22px;opacity:0;transition:opacity .15s}.plan-slider-row:hover .plan-slider-delete{opacity:1}.plan-slider-track-wrap{padding-right:0}.plan-slider-range{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:8px;border-radius:99px;background:linear-gradient(to right,var(--fill-color) var(--fill-pct),var(--border) var(--fill-pct));outline:none;cursor:pointer}.plan-slider-range::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--fill-color);border:2px solid var(--bg2);box-shadow:0 1px 4px #0000004d;cursor:pointer}.plan-slider-range::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--fill-color);border:2px solid var(--bg2);box-shadow:0 1px 4px #0000004d;cursor:pointer}.plan-allocated-row{display:flex;justify-content:space-between;align-items:center;margin-top:20px;padding:14px 0;border-top:1px solid var(--border);font-size:14px;color:var(--text2)}.plan-save-btn{width:100%;margin-top:16px;padding:12px 0;border:none;border-radius:8px;background:#eab308;color:#000;font-size:15px;font-weight:600;cursor:pointer;transition:filter .15s}.plan-save-btn:hover{filter:brightness(1.1)}@media(max-width:600px){html,body,.app,.main,.content,.page-content{max-width:100vw!important;overflow-x:hidden!important}.content{padding:10px 12px}.page-header{margin-bottom:12px;gap:6px}.page-header h2{font-size:18px}.header-actions{width:100%}.header-actions .btn{flex:1;justify-content:center;font-size:12px;padding:6px 8px}.topbar{padding:0 12px;height:48px}.topbar-title{font-size:14px}.user-name{display:none}.card{border-radius:10px}.card-metric{padding:12px}.card-metric-value{font-size:20px!important}.card-metric-value-sm{font-size:17px!important}.card-metric-label,.card-metric-detail{font-size:11px}.card-chart{padding:12px}.table-actions{justify-content:flex-end}.cat-form-row .form-group{width:100%!important;min-width:unset!important}.cat-form-row .btn{width:100%}.table-wrapper{overflow-x:hidden}.table-wrapper table thead{display:none}.table-wrapper table,.table-wrapper table tbody,.table-wrapper table tr,.table-wrapper table td{display:block;width:100%}.table-wrapper table tr{padding:10px;margin-bottom:8px;border:1px solid var(--border);border-radius:10px;background:var(--bg2);position:relative}.table-wrapper table tr:hover td{background:transparent}.table-wrapper table td{padding:3px 0;border-bottom:none;font-size:13px;display:flex;justify-content:space-between;align-items:center;word-break:break-word}.table-wrapper table td:before{content:attr(data-label);font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.3px;min-width:70px;flex-shrink:0}.table-wrapper table td:first-child{font-weight:600;font-size:13px;padding-bottom:6px;border-bottom:1px solid var(--border);margin-bottom:6px}.table-wrapper table td:last-child{padding-top:8px;border-top:1px solid var(--border);margin-top:4px;justify-content:flex-end}.row-paid{opacity:.5}.empty-row{display:block!important;text-align:center;border:none}.search-bar{flex-direction:row;flex-wrap:wrap;gap:6px;width:100%}.search-bar input[type=text]{flex:1 1 100%;min-width:0;max-width:100%;box-sizing:border-box}.search-bar .month-picker{flex:0 0 auto;width:auto!important;min-width:110px;max-width:160px}.search-bar .btn{flex-shrink:0}.filter-bar{gap:4px;flex-wrap:wrap}.filter-bar .btn{padding:5px 8px;font-size:11px}.filter-bar .btn-xs{padding:4px 6px;font-size:11px}.search-bar .cat-filter{flex:1 1 140px;min-width:0}.cat-filter-trigger{min-width:0!important;max-width:100%!important;width:100%;padding:7px 10px;font-size:12px}.cat-filter-trigger-label{font-size:12px}.cat-filter-pop{min-width:0!important;max-width:calc(100vw - 32px)!important;width:calc(100vw - 32px);left:auto;right:0}input,select,textarea{font-size:16px!important;max-width:100%;box-sizing:border-box}.month-picker{font-size:14px!important;padding:6px 8px;min-width:110px;max-width:140px}.dashboard-grid{grid-template-columns:1fr!important;gap:10px}.cards-summary-grid{grid-template-columns:1fr!important;gap:10px!important}.fixed-item{padding:10px 12px}.fixed-item-main,.fixed-item-info{gap:6px}.fixed-item-info strong{font-size:13px}.fixed-amount{font-size:14px}.fixed-item-actions{gap:4px}.fixed-item-actions .btn{font-size:11px;padding:4px 8px}.fixed-item-actions select{font-size:11px;padding:3px 6px;width:auto!important}.fixed-item-right{gap:6px}.cards-grid{grid-template-columns:1fr!important;gap:12px}.credit-card-display{padding:14px 14px 46px;min-height:auto;box-sizing:border-box}.cc-switch{bottom:8px;left:10px;font-size:10px;padding:3px 8px 3px 9px}.cc-switch-track{width:24px;height:14px}.cc-switch-thumb{width:10px;height:10px}.cc-switch.is-on .cc-switch-thumb{left:12px}.cc-name{font-size:15px;margin-top:12px;word-break:break-word}.cc-flag{font-size:10px}.cc-due{font-size:11px}.cc-details{gap:6px}.cc-detail-row{font-size:12px;flex-wrap:nowrap;gap:8px;align-items:baseline}.cc-detail-row>span:first-child{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis}.cc-detail-row>span:last-child{flex:0 0 auto;font-size:12px}.summary-stats,.cards-summary-stats{display:flex;flex-direction:column;gap:6px;margin-top:10px;padding-top:10px;border-top:1px dashed var(--border)}.summary-stat,.cards-summary-stat{display:flex;flex-direction:row;justify-content:space-between;align-items:baseline;gap:8px;padding:0;border-right:none}.summary-stat-label,.cards-summary-stat-label{font-size:11px}.summary-stat-value,.cards-summary-stat-value{font-size:13px;text-align:right}.accounts-grid{grid-template-columns:1fr!important;gap:10px}.account-balance{font-size:18px}.account-card-v2{width:100%;box-sizing:border-box;min-height:auto;padding:14px}.account-card-balance{flex-wrap:wrap;row-gap:4px}.account-card-value{font-size:clamp(16px,6vw,22px);word-break:break-word;overflow-wrap:anywhere;line-height:1.1;flex:1 1 auto;min-width:0}.account-card-name{word-break:break-word;overflow-wrap:anywhere}.account-card-edit{flex-wrap:wrap;row-gap:6px}.account-card-edit input{min-width:0;flex:1 1 100%;font-size:16px}.account-card-share-label{font-size:9px}.account-card-toggle{font-size:11px!important;padding:6px 8px!important}.quick-actions{gap:6px}.quick-actions .btn{flex:1;justify-content:center;font-size:12px;padding:8px 10px}.sort-hint{font-size:10px;padding:4px 8px}.modal-overlay{padding:6px}.modal-content{max-height:95vh;border-radius:12px;max-width:100vw}.modal-header{padding:12px 14px}.modal-body{padding:12px}.modal-body input,.modal-body select{max-width:100%!important}.modal-wide{max-width:100%}.report-bar-row{gap:4px;min-width:0!important;overflow:hidden}.report-bar-label{min-width:0!important;flex:0 1 auto;font-size:12px;gap:4px;overflow:hidden;max-width:35%}.report-bar-label span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.report-bar-track{flex:1;height:10px;min-width:40px}.report-bar-vals{min-width:60px;flex-shrink:0}.report-bar-vals span{font-size:11px}.report-bar-pct{font-size:10px}.chart-bar-row{gap:4px}.chart-bar-label{min-width:50px;font-size:11px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chart-bar-val{min-width:55px;font-size:11px;flex-shrink:0}.breakdown,.breakdown-row{gap:4px}.breakdown-label{width:55px;font-size:10px}.breakdown-track{min-width:30px}.breakdown-val{width:60px;font-size:10px}.alert-card{padding:10px 12px;flex-direction:column;gap:8px}.alert-card svg{flex-shrink:0}.alert-card p{font-size:12px;word-break:break-word;line-height:1.4}.alert-card>div{min-width:0;width:100%}.alert-card strong{font-size:13px}.savings-rate{font-size:28px}.info-box{font-size:12px;padding:8px 12px;word-break:break-word}.login-card{padding:20px 16px;margin:10px}.emergency-btns{flex-wrap:wrap;gap:4px}.plan-income-card{flex-wrap:wrap;padding:12px;gap:8px}.plan-income-hint{width:100%;font-size:11px}.plan-income-value{font-size:17px}.plan-mode-toggle{width:100%;display:flex}.plan-mode-btn{flex:1;text-align:center;padding:8px 10px;font-size:12px}.plan-chart-card,.plan-controls-card{padding:14px}.plan-section-title{font-size:14px;margin-bottom:14px}.plan-donut-value{font-size:18px}.plan-legend{gap:6px 10px}.plan-legend-item{font-size:11px}.plan-slider-name{font-size:12px}.plan-slider-input{width:55px;font-size:12px;padding:3px 6px}.plan-slider-row{padding-right:22px}.plan-slider-delete{opacity:1;width:20px;height:20px}.plan-allocated-row{font-size:12px}.plan-goal-expenses-form{padding:10px;gap:8px}.plan-goal-expenses-form .form-group{flex:1 1 100%!important;min-width:0!important}.plan-goal-expenses-form .btn{width:100%}.plan-goal-expenses-group-header{flex-direction:column;align-items:stretch;gap:6px;padding:10px 12px}.plan-goal-expenses-group-header>div{font-size:12px;gap:8px;flex-wrap:wrap}.plan-goal-expense-row{gap:6px;padding:8px 10px}.plan-goal-expense-row>span:first-child{flex:1 1 100%!important}.plan-goal-expense-row input[type=text]{width:80px!important;font-size:13px}.plan-goal-expense-row select{flex:1;min-width:0;font-size:13px}.report-section{padding:12px;margin-bottom:10px;overflow:visible}.report-section-title{font-size:14px;margin-bottom:10px}.report-filters{flex-direction:row;flex-wrap:wrap;gap:6px;width:100%}.report-filters .month-picker{flex-shrink:0;width:auto!important;min-width:110px;max-width:140px}.report-filters .select-sm{flex:1;min-width:0!important;max-width:100%;box-sizing:border-box}.report-filters .btn{flex-shrink:0}.report-total-card{padding:10px 12px}.report-total-card .card-metric-value{font-size:18px!important}.report-cat-row{gap:4px;padding:8px 2px}.report-cat-name{font-size:12px;max-width:80px}.report-cat-arrow{font-size:10px}.report-cat-detail{margin-left:6px;padding-left:8px}.report-cat-item{flex-wrap:wrap;gap:4px;padding:4px 0}.report-cat-item-name,.report-cat-item-val{font-size:12px}.report-chart-wrap{overflow:visible;max-width:100%}.report-chart-yaxis{width:30px}.report-chart-yaxis span{font-size:8px;padding-right:2px}.report-chart-area{margin-left:30px;height:160px;gap:2px;min-width:0}.report-chart-bar-income,.report-chart-bar-expense{max-width:18px;width:42%!important}.report-chart-bars{gap:1px}.report-chart-label{font-size:8px;bottom:-16px}.report-chart-col{min-width:0;flex:1}.report-chart-balances{margin-left:30px;gap:2px;margin-top:22px}.report-chart-balance-item{font-size:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1}.report-averages{gap:8px;flex-direction:column}.report-avg-label{font-size:11px}.report-legend{gap:6px 10px;font-size:10px;flex-wrap:wrap}.report-legend-item{font-size:10px}.chart-tooltip{min-width:110px;padding:6px 8px;font-size:11px}.biggest-row{flex-wrap:nowrap!important;align-items:flex-start;gap:8px}.biggest-label{flex:1 1 auto!important;min-width:0!important;max-width:none!important;overflow:hidden;gap:6px}.biggest-rank{flex-shrink:0;color:var(--text3);font-weight:600;font-size:12px}.biggest-name{flex:1 1 auto;min-width:0;font-size:12px;white-space:normal;overflow-wrap:anywhere;word-break:break-word;max-width:none!important;line-height:1.3}.biggest-val{flex:0 0 auto!important;min-width:70px!important;text-align:right}.biggest-val span{font-size:12px}.cat-form-row{flex-direction:column}.cat-form-row>*{width:100%!important;min-width:unset!important}.balance-display{font-size:22px}.balance-buttons{flex-wrap:wrap}.calc-wrap{width:220px}.calc-value{font-size:22px}.calc-btn{padding:12px 0;font-size:14px}.badge{font-size:10px;padding:1px 6px}.select-sm{width:100%!important;min-width:unset!important}.inv-grid{grid-template-columns:1fr!important}.guest-badge{font-size:10px;padding:4px;margin:4px 6px}}.cat-filter{position:relative}.cat-filter-trigger{display:inline-flex;align-items:center;gap:6px;min-width:200px;max-width:260px;padding:7px 12px;border:1px solid var(--border);border-radius:8px;background:var(--bg2, #fff);color:var(--text);font-size:13px;cursor:pointer;transition:border-color .15s,box-shadow .15s,background .15s}.cat-filter-trigger:hover{border-color:var(--accent, #3b82f6)}.cat-filter-trigger.is-open{border-color:var(--accent, #3b82f6);box-shadow:0 0 0 3px #3b82f626}.cat-filter-trigger-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left}.cat-filter-trigger-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:var(--accent, #3b82f6);color:#fff;font-size:11px;font-weight:700;margin-left:4px}.cat-filter-caret{opacity:.55;transition:transform .2s}.cat-filter-trigger.is-open .cat-filter-caret{transform:rotate(180deg)}.cat-filter-pop{position:absolute;top:calc(100% + 6px);left:0;min-width:280px;max-width:320px;background:var(--bg, #fff);border:1px solid var(--border, #e5e7eb);border-radius:12px;box-shadow:0 10px 32px #0000002e,0 2px 8px #00000014;z-index:60;overflow:hidden;animation:cat-pop-in .14s ease-out}@keyframes cat-pop-in{0%{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.cat-filter-pop-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border, #e5e7eb);background:var(--bg2, #f9fafb)}.cat-filter-pop-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text2)}.cat-filter-pop-clear{font-size:12px;color:var(--accent, #3b82f6);background:transparent;border:0;padding:4px 8px;border-radius:6px;cursor:pointer;font-weight:600}.cat-filter-pop-clear:hover{background:#3b82f61a}.cat-filter-pop-list{max-height:280px;overflow-y:auto;padding:6px}.cat-filter-pop-empty{padding:18px 14px;text-align:center;font-size:13px;color:var(--text3)}.cat-filter-pop-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;cursor:pointer;font-size:13px;color:var(--text);transition:background .12s;-webkit-user-select:none;user-select:none}.cat-filter-pop-item:hover{background:var(--bg2, #f3f4f6)}.cat-filter-pop-item.is-checked{background:#3b82f614;color:var(--text);font-weight:600}.cat-filter-pop-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent, #3b82f6);cursor:pointer;flex-shrink:0}.cat-filter-pop-item-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cat-filter-pop-footer{display:flex;justify-content:flex-end;gap:8px;padding:8px 12px;border-top:1px solid var(--border, #e5e7eb);background:var(--bg2, #f9fafb)}.cat-filter-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:transparent;z-index:55}.app.dark .cat-filter-trigger{background:#ffffff0a}.app.dark .cat-filter-pop{background:#1f2937;border-color:#374151}.app.dark .cat-filter-pop-header,.app.dark .cat-filter-pop-footer{background:#ffffff08;border-color:#374151}.app.dark .cat-filter-pop-item:hover{background:#ffffff0f}.app.dark .cat-filter-pop-item.is-checked{background:#60a5fa2e}.cc-actions{position:absolute;top:12px;right:12px;display:flex;gap:6px;z-index:2}.cc-edit,.cc-delete{background:#ffffff1f!important;color:#fff!important;border:1px solid rgba(255,255,255,.18)!important;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.cc-edit:hover{background:#ffffff38!important}.cc-delete:hover{background:#f8717180!important}.cc-edit-action{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.25);background:#ffffff26;color:#fff;border-radius:8px;cursor:pointer;transition:background .15s;flex-shrink:0}.cc-edit-action:hover{background:#ffffff47}.cc-name-clickable{cursor:pointer;display:inline-flex;align-items:center;gap:8px;padding:2px 4px;margin:16px -4px 0;border-radius:6px;transition:background .15s}.cc-name-clickable:hover{background:#ffffff14}.cc-name-edit-icon{opacity:0;transition:opacity .15s}.cc-name-clickable:hover .cc-name-edit-icon{opacity:.7}.cc-name-edit{display:flex;align-items:center;gap:6px;margin-top:16px}.cc-name-edit input{flex:1;min-width:0;font-size:18px;font-weight:700;background:#ffffff2e;border:1px solid rgba(255,255,255,.3);color:#fff;padding:6px 10px;border-radius:8px}.cc-name-edit input::placeholder{color:#ffffff8c}.cc-name-edit input:focus{outline:none;border-color:#ffffffb3}.cc-color-pop{position:absolute;top:50px;right:12px;z-index:5;background:var(--bg2);color:var(--text);border:1px solid var(--border);border-radius:10px;padding:12px;width:220px;box-shadow:0 10px 32px #00000040,0 2px 8px #0000001a;animation:cat-pop-in .14s ease-out}.cc-color-pop-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text3);margin-bottom:8px}.cc-color-pop-presets{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:10px}.cc-color-swatch{width:100%;aspect-ratio:1 / 1;border-radius:6px;border:2px solid transparent;cursor:pointer;transition:transform .12s,border-color .12s}.cc-color-swatch:hover{transform:scale(1.08)}.cc-color-swatch.is-selected{border-color:var(--text)}.cc-color-pop-hex{display:flex;align-items:center;gap:6px;padding:6px 0 10px;border-top:1px dashed var(--border)}.cc-color-pop-hex label{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.04em;font-weight:600}.cc-color-pop-hex input[type=text]{flex:1;min-width:0;padding:4px 8px;font-family:var(--mono);font-size:12px;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--text);text-transform:uppercase}.cc-color-pop-hex input[type=color]{width:32px;height:32px;border:1px solid var(--border);border-radius:6px;cursor:pointer;padding:0;background:transparent}.cc-color-pop-close{width:100%;padding:6px;border:1px solid var(--border);border-radius:6px;background:var(--bg3);color:var(--text2);font-size:12px;cursor:pointer;transition:background .15s}.cc-color-pop-close:hover{background:var(--bg)}.cc-switch{position:absolute;bottom:12px;left:12px;display:inline-flex;align-items:center;gap:8px;padding:4px 8px 4px 10px;background:#00000038;border:1px solid rgba(255,255,255,.1);border-radius:999px;cursor:pointer;font-size:11px;font-weight:600;color:#ffffffd9;-webkit-user-select:none;user-select:none;z-index:2;transition:background .15s,border-color .15s}.cc-switch:hover{background:#00000052;border-color:#fff3}.cc-switch input[type=checkbox]{position:absolute;opacity:0;pointer-events:none;width:0;height:0}.cc-switch-label{white-space:nowrap;letter-spacing:.2px}.cc-switch-track{position:relative;width:28px;height:16px;background:#ffffff40;border-radius:999px;transition:background .2s;flex-shrink:0}.cc-switch-thumb{position:absolute;top:2px;left:2px;width:12px;height:12px;background:#fff;border-radius:50%;box-shadow:0 1px 3px #00000040;transition:left .2s,background .2s}.cc-switch.is-on .cc-switch-track{background:#10b981}.cc-switch.is-on .cc-switch-thumb{left:14px}.cc-switch.is-off{opacity:.85}.cc-switch:focus-within{box-shadow:0 0 0 3px #ffffff2e}.credit-card-display.cc-dimmed{filter:saturate(.35) brightness(.85);opacity:.78}
