:root{--bg-primary:#f5f7fa;--bg-secondary:#fff;--bg-card:#fff;--bg-input:#f0f2f5;--text-primary:#1a1a2e;--text-secondary:#5f6b7a;--text-muted:#9ca3af;--accent:#3abc8f;--accent-hover:#2fa87d;--accent-light:#3abc8f1a;--green:#22c55e;--red:#ef4444;--yellow:#d97706;--border:#e2e8f0;--radius:10px;--shadow-sm:0 1px 2px #0000000d;--shadow:0 1px 4px #00000014, 0 1px 2px #0000000a;--sat:env(safe-area-inset-top,0px);--sar:env(safe-area-inset-right,0px);--sab:env(safe-area-inset-bottom,0px);--sal:env(safe-area-inset-left,0px);--tab-bar-height:60px;--tab-bar-total:calc(var(--tab-bar-height) + var(--sab))}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}.app-layout{flex-direction:column;min-height:100dvh;display:flex}.sidebar{display:none}.mobile-topbar{padding:0 16px;padding-top:var(--sat);height:calc(52px + var(--sat));background:var(--bg-secondary);border-bottom:1px solid var(--border);z-index:20;box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.mobile-topbar-logo{height:28px}.mobile-menu-btn{cursor:pointer;border-radius:var(--radius);-webkit-tap-highlight-color:transparent;background:0 0;border:none;justify-content:center;align-items:center;width:40px;height:40px;padding:8px;display:flex}.drawer-backdrop{z-index:30;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006;position:fixed;inset:0}.mobile-drawer{background:var(--bg-secondary);z-index:40;width:240px;padding-top:var(--sat);padding-bottom:var(--sab);flex-direction:column;transition:transform .25s;display:flex;position:fixed;top:0;bottom:0;right:0;transform:translate(100%);box-shadow:-4px 0 20px #00000026}.mobile-drawer.open{transform:translate(0)}.drawer-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px;display:flex}.drawer-user{color:var(--text-primary);font-size:15px;font-weight:600}.drawer-close{background:var(--bg-input);cursor:pointer;width:32px;height:32px;color:var(--text-secondary);border:none;border-radius:50%;font-size:18px;line-height:1}.drawer-logout{border-radius:var(--radius);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;margin:16px;padding:12px 16px;font-size:14px}.drawer-logout:hover{border-color:var(--red);color:var(--red)}.main-content{padding:16px;padding-bottom:calc(var(--tab-bar-total) + 16px);padding-left:calc(16px + var(--sal));padding-right:calc(16px + var(--sar));flex:1;max-width:100%;overflow-x:hidden}.bottom-tabs{height:var(--tab-bar-total);padding-bottom:var(--sab);background:var(--bg-secondary);border-top:1px solid var(--border);z-index:20;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 8px #0000000f}.bottom-tab{color:var(--text-muted);-webkit-tap-highlight-color:transparent;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding-bottom:2px;font-size:10px;font-weight:500;text-decoration:none;transition:color .15s;display:flex}.bottom-tab.active{color:var(--accent)}.bottom-tab-icon{font-size:20px;line-height:1}.bottom-tab-label{letter-spacing:.2px;font-size:10px}h2{font-size:20px;font-weight:700}h3{font-size:15px;font-weight:600}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:20px;display:flex}.page-header h2{font-size:20px;font-weight:700}.page-header-actions{flex-shrink:0;gap:8px;display:flex}.page-header-actions .btn,.page-header .btn{width:auto}.page-header .controls{flex-wrap:wrap;gap:8px;display:flex}.page-header .controls select{width:auto;margin-top:0}.section{margin-bottom:28px}.section-label{align-items:center;gap:8px;margin-bottom:10px;display:flex}.section-count{background:var(--bg-input);border:1px solid var(--border);min-width:20px;height:20px;color:var(--text-secondary);border-radius:99px;justify-content:center;align-items:center;padding:0 5px;font-size:11px;font-weight:600;display:inline-flex}label{color:var(--text-secondary);margin-bottom:14px;font-size:13px;font-weight:500;display:block}input,select{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text-primary);appearance:none;margin-top:4px;padding:11px 12px;font-size:16px;display:block}input:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light);outline:none}.btn{border-radius:var(--radius);cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;justify-content:center;align-items:center;min-height:44px;padding:11px 20px;font-size:15px;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff;width:100%}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{cursor:not-allowed;background:#9dd6c0}.btn-secondary{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;min-height:44px;padding:11px 20px;font-size:15px}.btn-secondary:hover{border-color:var(--accent)}.btn-danger{color:var(--red);border:1px solid var(--red);background:0 0}.btn-danger:hover{background:var(--red);color:#fff}.btn-sm,.btn.btn-sm{min-height:34px;padding:6px 14px;font-size:13px}.btn-link{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:0;font-size:13px}.btn-link:hover{color:var(--text-primary)}.link-btn{color:var(--accent);cursor:pointer;font-size:inherit;background:0 0;border:none;padding:0;text-decoration:underline}.link-btn:hover{color:var(--accent-hover)}.btn-icon{border:1px solid var(--border);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border-radius:8px;justify-content:center;align-items:center;font-size:15px;transition:all .15s;display:inline-flex}.btn-icon:hover{background:var(--bg-input);color:var(--accent);border-color:var(--accent)}.btn-icon-danger:hover{color:var(--red);border-color:var(--red);background:#ef44440f}.btn-icon+.btn-icon{margin-left:6px}.badge{background:var(--bg-input);border:1px solid var(--border);border-radius:99px;padding:2px 10px;font-size:12px;font-weight:500;display:inline-block}.badge.income{color:var(--green);border-color:var(--green);background:#22c55e14}.badge.expense{color:var(--red);border-color:var(--red);background:#ef444414}.category-badge{border-radius:99px;padding:2px 10px;font-size:12px;font-weight:500;display:inline-block}.freq-badge{letter-spacing:.2px;white-space:nowrap;border-radius:99px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-block}.positive{color:var(--green)}.negative{color:var(--red)}.muted{color:var(--text-muted)}.alert{border-radius:var(--radius);margin-bottom:12px;padding:12px 16px;font-size:14px}.alert-error{border:1px solid var(--red);color:var(--red);background:#ef444414}.alert-warning{border:1px solid var(--yellow);color:var(--yellow);background:#d9770614}.alert-cards{gap:10px;margin-bottom:20px;display:grid}.alert-card{border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid;align-items:flex-start;gap:12px;padding:14px 16px;display:flex}.alert-card-warning{background:#d977060f;border-color:#d977064d}.alert-card-icon{flex-shrink:0;margin-top:1px;font-size:18px}.alert-card-body{flex:1}.alert-card-title{margin-bottom:2px;font-size:14px;font-weight:600}.alert-card-detail{color:var(--text-secondary);font-size:13px}.alert-card-date{color:var(--text-muted);margin-top:3px;font-size:12px}.alert-card-items{flex-wrap:wrap;gap:5px;margin-top:6px;display:flex}.alert-item-chip{white-space:nowrap;border-radius:99px;align-items:center;gap:3px;padding:2px 7px;font-size:11px;font-weight:600;display:inline-flex}.alert-item-chip.income{color:var(--green);background:#22c55e1a}.alert-item-chip.expense{color:var(--red);background:#ef44441a}.toast-container{bottom:calc(var(--tab-bar-total) + 12px);z-index:9999;pointer-events:none;flex-direction:column;gap:8px;max-width:calc(100vw - 24px);display:flex;position:fixed;right:12px}.toast{pointer-events:all;border:1px solid var(--border);background:#fff;border-radius:10px;align-items:center;gap:10px;max-width:360px;padding:12px 14px;font-size:14px;font-weight:500;animation:.25s cubic-bezier(.34,1.56,.64,1) toast-in;display:flex;box-shadow:0 4px 16px #00000024}.toast.toast-out{animation:.3s forwards toast-out}@keyframes toast-in{0%{opacity:0;transform:translate(24px)scale(.96)}to{opacity:1;transform:none}}@keyframes toast-out{0%{opacity:1}to{opacity:0;transform:translate(24px)scale(.96)}}.toast-icon{text-align:center;flex-shrink:0;width:18px;font-size:15px}.toast-message{flex:1}.toast-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0;font-size:18px;line-height:1}.toast-success{border-left:4px solid var(--green)}.toast-success .toast-icon{color:var(--green)}.toast-error{border-left:4px solid var(--red)}.toast-error .toast-icon{color:var(--red)}.toast-warning{border-left:4px solid var(--yellow)}.toast-warning .toast-icon{color:var(--yellow)}.toast-info{border-left:4px solid #3b82f6}.toast-info .toast-icon{color:#3b82f6}.table-wrap{width:100%}.data-table{background:var(--bg-card);border-radius:var(--radius);width:100%;overflow:hidden}@media (width<=639px){.data-table thead{display:none}.data-table,.data-table tbody{display:block}.data-table tr{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:10px;display:block;overflow:hidden}.data-table tr:hover{background:var(--bg-card)}.data-table td{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:8px;padding:9px 14px;font-size:14px;display:flex}.data-table td:last-child{border-bottom:none}.data-table td[data-label]:before{content:attr(data-label);text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);white-space:nowrap;flex-shrink:0;font-size:11px;font-weight:600}.data-table td.td-name{background:var(--bg-input);justify-content:space-between;padding:12px 14px;font-size:15px;font-weight:600}.data-table td.td-name:before{display:none}.data-table td.td-actions{justify-content:flex-end;padding:10px 14px}.data-table td.td-actions:before,.row-editing-marker{display:none}.row-editing{display:block!important}.row-editing td{border-bottom:none!important;padding:14px!important;display:block!important}.empty-row{text-align:center!important;padding:20px 14px!important;display:block!important}}@media (width>=640px){.data-table{border:1px solid var(--border);box-shadow:var(--shadow-sm)}.data-table th{text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;background:var(--bg-input);border-bottom:1px solid var(--border);padding:11px 14px;font-size:11px}.data-table td{border-bottom:1px solid var(--border);padding:11px 14px;font-size:14px}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover{background:var(--bg-input)}.data-table .btn+.btn{margin-left:6px}.td-name{font-weight:500}.td-actions{white-space:nowrap;width:1%}.empty-row{color:var(--text-secondary);font-size:14px;padding:24px 14px!important}}.row-editing-marker td{background:var(--accent);border:none!important;height:3px!important;padding:0!important}.row-editing,.row-editing:hover{background:var(--accent-light)!important}.row-editing td{border-bottom:2px solid var(--accent)!important;padding:12px 14px!important}.row-new{background:#3abc8f0f!important}.inline-edit-form{flex-direction:column;gap:8px;display:flex}.inline-edit-form input,.inline-edit-form select{width:100%;margin-top:0;font-size:16px}.ie-field-prefix{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);align-items:stretch;margin-top:4px;display:flex;overflow:hidden}.ie-field-prefix span{color:var(--text-secondary);border-right:1px solid var(--border);white-space:nowrap;align-items:center;padding:0 10px;font-size:15px;font-weight:500;display:flex}.ie-field-prefix input{background:var(--bg-input);flex:1;box-shadow:none!important;border:none!important;border-radius:0!important;margin-top:0!important}.ie-field-prefix input:focus{outline:none}.ie-actions{gap:8px;display:flex}.ie-actions .btn{flex:1}.ie-name{font-size:16px!important}@media (width>=640px){.inline-edit-form{flex-flow:wrap;align-items:flex-end}.inline-edit-form input,.inline-edit-form select{width:auto;height:34px;padding:0 10px;font-size:13px}.inline-edit-form .ie-name{flex:2;min-width:150px;font-size:13px!important}.inline-edit-form select{min-width:120px}.inline-edit-form input[type=date]{min-width:130px}.inline-edit-form input[type=number]{min-width:80px}.ie-field-prefix{height:34px;margin-top:0}.ie-field-prefix span{font-size:13px}.ie-actions{flex:none;margin-left:auto}.ie-actions .btn{flex:none}}.cat-select{width:100%;position:relative}.cat-select-trigger{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;min-height:44px;color:var(--text-primary);-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;align-items:center;gap:8px;padding:0 12px;font-size:15px;transition:border-color .15s,box-shadow .15s;display:flex}.cat-select-trigger:hover,.cat-select-trigger.open{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.cat-select-trigger:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light);outline:none}.cat-placeholder{color:var(--text-muted);flex:1}.cat-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.cat-chevron{color:var(--text-muted);flex-shrink:0;margin-left:auto;font-size:10px}.cat-clear{text-align:center;background:var(--border);width:18px;height:18px;color:var(--text-secondary);cursor:pointer;border-radius:50%;flex-shrink:0;font-size:12px;line-height:18px}.cat-clear:hover{background:var(--red);color:#fff}.cat-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.cat-dropdown{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);z-index:1000;min-width:200px;animation:.12s dropdown-in;position:absolute;top:calc(100% + 4px);left:0;right:0;box-shadow:0 8px 24px #0000001f}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}.cat-search{border-bottom:1px solid var(--border);padding:8px}.cat-search-input{background:var(--bg-input);border:1px solid var(--border);border-radius:calc(var(--radius) - 2px);width:100%;height:40px;color:var(--text-primary);-webkit-appearance:none;margin-top:0;padding:0 10px;font-size:16px;display:block}.cat-search-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-light);outline:none}.cat-options{max-height:220px;padding:4px 0;overflow-y:auto}.cat-option{cursor:pointer;color:var(--text-primary);-webkit-tap-highlight-color:transparent;align-items:center;gap:8px;min-height:44px;padding:10px 12px;font-size:14px;transition:background .1s;display:flex}.cat-option:hover,.cat-option.active{background:var(--bg-input)}.cat-option.selected{background:var(--accent-light)}.cat-option.selected .cat-name{color:var(--accent);font-weight:500}.cat-check{color:var(--accent);margin-left:auto;font-size:12px}.cat-option-none .cat-none-label{color:var(--text-muted);font-style:italic}.cat-option-create{border-top:1px solid var(--border);color:var(--accent)}.cat-option-create:hover,.cat-option-create.active{background:var(--accent-light)}.cat-create-icon{flex-shrink:0;font-size:14px;font-weight:600}.cat-saving{color:var(--text-muted);margin-left:auto;font-size:11px}.cat-empty{color:var(--text-muted);text-align:center;padding:14px;font-size:14px}@media (width>=640px){.cat-select{flex:1;min-width:140px}.cat-select-trigger{min-height:34px;font-size:13px}.cat-search-input{height:32px;font-size:13px}.cat-option{min-height:34px;padding:8px 12px;font-size:13px}}.account-summary-cards{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;margin-bottom:20px;display:grid}.summary-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;box-shadow:var(--shadow-sm);-webkit-tap-highlight-color:transparent;padding:14px;transition:all .15s}.summary-card:hover,.summary-card:active{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.summary-card.selected{border-color:var(--accent);background:var(--accent-light)}.card-label{color:var(--text-secondary);margin-bottom:4px;font-size:12px}.card-balance{font-size:22px;font-weight:700}.card-change{margin-top:2px;font-size:12px}.card-change.positive{color:var(--green)}.card-change.negative{color:var(--red)}.runway-indicator{border-radius:var(--radius);border:1px solid #0000;align-items:center;gap:8px;margin-bottom:14px;padding:10px 14px;font-size:13px;font-weight:500;display:flex}.runway-ok{color:var(--green);background:#22c55e14;border-color:#22c55e40}.runway-warn{color:var(--yellow);background:#d9770614;border-color:#d977064d}.runway-indicator strong{font-weight:700}.chart-container{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:20px;padding:16px;overflow:hidden}.chart-legend{justify-content:flex-end;gap:16px;padding:0 4px 10px;display:flex}.chart-legend-item{color:var(--text-secondary);align-items:center;gap:6px;font-size:12px;display:flex}.chart-legend-swatch{border-radius:2px;width:20px;height:2px;display:inline-block}.chart-legend-actual{background:#3abc8f}.chart-legend-projected{background:#94a3b8;border-top:2px dashed #94a3b8;height:0}.upcoming-events{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px;overflow-x:auto}.upcoming-events h3{margin-bottom:12px;font-size:15px}.upcoming-events table{border-collapse:collapse;width:100%;min-width:300px}.upcoming-events th{text-align:left;color:var(--text-secondary);text-transform:uppercase;border-bottom:1px solid var(--border);padding:8px 10px;font-size:11px}.upcoming-events td{border-bottom:1px solid var(--border);padding:8px 10px;font-size:13px}.activity-divider{letter-spacing:.5px;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border);padding:6px 16px;font-size:11px;font-weight:700}.activity-divider-past{background:var(--bg-input)}.activity-divider-today{background:var(--accent-light);color:var(--accent)}.activity-item{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:10px 14px;font-size:14px;transition:background .15s;display:flex}.activity-item:last-child{border-bottom:none}.activity-item.completed{background:#22c55e0f}.activity-item.overdue{background:#d977060d}.activity-check{border:2px solid var(--border);background:var(--bg-card);cursor:pointer;color:#0000;-webkit-tap-highlight-color:transparent;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;font-weight:700;transition:all .15s;display:inline-flex}.activity-check:hover{border-color:var(--accent);color:var(--accent)}.activity-check.checked{background:var(--green);border-color:var(--green);color:#fff}.activity-item.overdue .activity-check{border-color:var(--yellow)}.activity-item.overdue .activity-check:hover{border-color:var(--yellow);color:var(--yellow)}.activity-date{color:var(--text-secondary);white-space:nowrap;flex-shrink:0;min-width:90px;font-size:12px}.activity-name{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex;overflow:hidden}.activity-name>span:first-child{white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.activity-account{color:var(--text-muted);font-size:11px;display:block}.activity-amount-col{text-align:right;flex-shrink:0}.activity-amount{white-space:nowrap;align-items:center;gap:4px;font-weight:600;display:inline-flex}.activity-amount-projected{color:var(--text-muted);font-size:12px;text-decoration:line-through}.activity-amount-arrow{color:var(--text-muted);font-size:11px}.activity-amount-actual{color:inherit}.activity-edit-hint{color:var(--text-muted);opacity:0;margin-left:4px;font-size:10px;transition:opacity .15s}.activity-item.completed .activity-amount:hover .activity-edit-hint{opacity:1}.activity-item.completed .activity-amount:hover{opacity:.85}.activity-edit-row{align-items:center;gap:4px;display:inline-flex}.activity-edit-prefix{color:var(--text-secondary);font-size:13px;font-weight:500}.activity-edit-input{border:1px solid var(--accent);background:var(--bg-card);border-radius:6px;width:80px;height:28px;margin-top:0;padding:0 6px;font-size:13px;display:inline-block}.activity-edit-save,.activity-edit-cancel{cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:12px;display:inline-flex}.activity-edit-save{background:var(--green);color:#fff}.activity-edit-cancel{background:var(--bg-input);color:var(--text-muted)}.activity-overdue-tag{text-transform:uppercase;letter-spacing:.3px;color:var(--yellow);background:#d977061a;border:1px solid #d977064d;border-radius:99px;flex-shrink:0;padding:1px 6px;font-size:10px;font-weight:700}@media (width<=400px){.activity-date,.activity-account{display:none}}.data-grid{grid-template-columns:1fr;gap:14px;display:grid}.data-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:18px}.data-card-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.data-card-header h3{font-size:15px}.data-card-balance{margin-bottom:14px;font-size:26px;font-weight:700}.data-card-actions{gap:8px;display:flex}@media (width>=640px){.data-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}.form-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:20px;padding:20px}.form-card h3{margin-bottom:16px;font-size:15px}.form-card .btn-primary{width:auto}.form-actions{flex-wrap:wrap;gap:10px;margin-top:8px;display:flex}.auth-page{background:var(--bg-primary);min-height:100dvh;padding:16px;padding-top:calc(16px + var(--sat));padding-bottom:calc(16px + var(--sab));justify-content:center;align-items:center;display:flex}.auth-card{background:var(--bg-card);border:1px solid var(--border);width:100%;max-width:420px;box-shadow:var(--shadow);border-radius:14px;padding:28px 24px}.auth-card .logo{height:34px;margin-bottom:8px}.auth-card h2{margin-bottom:20px;font-size:20px}.auth-switch{color:var(--text-secondary);text-align:center;margin-top:16px;font-size:13px}.auth-switch a,.auth-switch .btn-link{color:var(--accent)}.auth-desc{color:var(--text-secondary);margin-bottom:16px;font-size:14px;line-height:1.5}.auth-2fa-hint{color:var(--text-secondary);margin-bottom:16px;font-size:14px}.forgot-row{text-align:right;margin-top:-4px;margin-bottom:12px}.forgot-link{color:var(--accent);font-size:13px;text-decoration:none}.forgot-link:hover{text-decoration:underline}.reset-sent{color:var(--text-secondary);margin-bottom:8px;font-size:14px;line-height:1.6}.reset-sent strong{color:var(--text-primary)}.alert-info{color:#60a5fa;border-radius:var(--radius);word-break:break-all;background:#3b82f61a;border:1px solid #3b82f64d;margin-bottom:12px;padding:10px 14px;font-size:13px}.stub-link-box{line-height:1.6}.stub-reset-link{color:#60a5fa;word-break:break-all;font-size:12px}.input-with-status{position:relative}.input-with-status input{padding-right:36px}.input-status{align-items:center;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.input-status.available{color:#22c55e}.input-status.taken{color:#ef4444}.input-status.checking{color:var(--text-secondary)}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:.8s linear infinite spin}.btn-ghost{color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;background:0 0;min-height:44px;padding:11px 20px;font-size:15px}.btn-ghost:hover{border-color:var(--text-secondary);color:var(--text-primary)}.btn-danger-outline{color:#ef4444;border-radius:var(--radius);cursor:pointer;background:0 0;border:1px solid #ef4444;min-height:44px;padding:11px 20px;font-size:15px}.btn-danger-outline:hover{color:#fff;background:#ef4444}.btn-danger{color:#fff;border-radius:var(--radius);cursor:pointer;background:#ef4444;border:none;min-height:44px;padding:11px 20px;font-size:15px}.btn-danger:hover{background:#dc2626}.tfa-icon{vertical-align:middle;color:var(--text-secondary);margin-right:6px}.tfa-icon.enabled{color:#22c55e}h3 .tfa-icon{display:inline}.tfa-panel{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);margin-top:16px;padding:16px}.tfa-label{color:var(--text-secondary);margin-bottom:12px;font-size:14px}.tfa-label.tfa-success{color:#22c55e;font-weight:600}.tfa-type-btns{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.tfa-type-btn{border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-card);cursor:pointer;text-align:left;flex-direction:column;align-items:flex-start;gap:2px;padding:12px 14px;transition:border-color .15s,background .15s;display:flex}.tfa-type-btn:hover{border-color:var(--accent)}.tfa-type-btn.active{border-color:var(--accent);background:#6366f114}.tfa-type-icon{margin-bottom:2px;font-size:18px}.tfa-type-name{color:var(--text-primary);font-size:14px;font-weight:600}.tfa-type-desc{color:var(--text-secondary);font-size:12px}.tfa-actions{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.tfa-qr{justify-content:center;margin:12px 0;display:flex}.tfa-qr img{border:4px solid #fff;border-radius:8px}.tfa-secret{color:var(--text-secondary);text-align:center;font-size:12px}.tfa-secret code{background:var(--bg-input);letter-spacing:1px;border-radius:4px;padding:2px 6px}.tfa-code-form{flex-direction:column;gap:8px;display:flex}.tfa-code-input{letter-spacing:8px;text-align:center;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-input);color:var(--text-primary);appearance:none;width:100%;padding:10px;font-size:24px}.setup-card{background:var(--bg-card);border:1px solid var(--border);width:100%;max-width:560px;box-shadow:var(--shadow);border-radius:14px;padding:24px 20px}.setup-card .logo{height:32px;margin-bottom:8px}.setup-steps{flex-wrap:wrap;gap:6px;margin-bottom:20px;display:flex}.setup-step{color:var(--text-muted);background:var(--bg-input);border:1px solid #0000;border-radius:20px;align-items:center;gap:5px;padding:5px 10px;font-size:12px;display:flex}.setup-step.active{color:var(--accent);border-color:var(--accent);background:var(--accent-light)}.setup-step.done{color:var(--green)}.step-number{font-weight:600}.setup-section h3{margin-bottom:12px;font-size:15px}.template-row{border-radius:var(--radius);background:var(--bg-input);border:1px solid #0000;margin-bottom:8px;padding:10px 12px;transition:border-color .15s}.template-row.enabled{border-color:var(--accent);background:var(--accent-light)}.template-name{font-weight:500}.template-fields{flex-wrap:wrap;align-items:center;gap:10px;margin-top:8px;padding-left:28px;display:flex}.template-fields input{border:1px solid var(--border);border-radius:var(--radius);background:#fff;width:110px;padding:6px 8px;font-size:14px}.template-freq{color:var(--text-secondary);font-size:12px}.review-summary{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);padding:14px}.review-block{margin-bottom:10px}.review-block:last-child{margin-bottom:0}.review-block h4{color:var(--accent);margin-bottom:4px;font-size:12px}.review-block p{color:var(--text-secondary);margin:2px 0;font-size:13px}.legal-acceptance{margin:12px 0}.legal-doc-item{margin-bottom:10px}.checkbox-label{cursor:pointer;align-items:center;gap:10px;font-size:14px;display:flex}.checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer;flex-shrink:0;appearance:auto!important;-webkit-appearance:checkbox!important;margin-top:0!important}.pw-requirements{flex-direction:column;gap:4px;margin:0;padding:8px 0 4px;list-style:none;display:flex}.pw-req{color:var(--text-secondary);align-items:center;gap:6px;font-size:12px;transition:color .15s;display:flex}.pw-req.met{color:#22c55e}.pw-req-icon{flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;display:flex}.pw-req-dot{background:var(--text-muted,var(--text-secondary));opacity:.5;border-radius:50%;width:5px;height:5px;display:inline-block}.pw-mismatch{color:#ef4444;margin-top:4px;font-size:12px;display:block}.rate-limit-caption{color:var(--text-secondary);text-align:center;margin-top:6px;font-size:12px}.legal-content{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);white-space:pre-wrap;max-height:200px;margin-top:8px;padding:12px;font-size:12px;overflow-y:auto}.loading{text-align:center;color:var(--text-secondary);padding:60px}.empty-state{text-align:center;color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:48px 24px}.recharts-tooltip-cursor{stroke:#00000014}@media (width>=768px){.app-layout{flex-direction:row}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border);z-index:10;width:220px;box-shadow:var(--shadow);flex-direction:column;flex-shrink:0;display:flex;position:fixed;top:0;bottom:0;left:0}.mobile-topbar{display:none}.mobile-drawer,.drawer-backdrop{display:none!important}.bottom-tabs{display:none}.sidebar-brand{border-bottom:1px solid var(--border);align-items:center;padding:18px 20px;display:flex}.sidebar-brand img{height:30px;display:block}.nav-links{flex:1;padding:10px 0;list-style:none;overflow-y:auto}.nav-links li a{color:var(--text-secondary);border-left:3px solid #0000;align-items:center;gap:10px;padding:10px 20px;font-size:14px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.nav-links li a:hover{color:var(--text-primary);background:var(--bg-input)}.nav-links li a.active{color:var(--accent);background:var(--accent-light);border-left-color:var(--accent)}.nav-icon{text-align:center;flex-shrink:0;width:18px;font-size:15px}.nav-label{flex:1}.sidebar-footer{border-top:1px solid var(--border);padding:14px 20px;font-size:13px}.sidebar-footer .user-name{color:var(--text-secondary);margin-bottom:4px;display:block}.main-content{max-width:1420px;margin-left:220px;padding:28px 32px}.toast-container{bottom:20px;right:20px}input,select,.btn{font-size:14px}.btn-primary{width:auto}}.alert-dismiss{cursor:pointer;color:var(--text-muted);background:0 0;border:none;flex-shrink:0;align-self:flex-start;padding:0 0 0 8px;font-size:20px;line-height:1}.alert-dismiss:hover{color:var(--text-primary)}.upcoming-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;display:flex}.upcoming-header-left{align-items:center;gap:10px;display:flex}.upcoming-header-left h3{font-size:15px;font-weight:600}.upcoming-days-select{width:auto;height:32px;margin-top:0;padding:5px 10px;font-size:13px}.upcoming-toggle-label{color:var(--text-secondary);cursor:pointer;align-items:center;gap:6px;margin-bottom:0;font-size:13px;display:flex}.upcoming-toggle-label input{width:16px;height:16px;margin-top:0;display:inline-block}.upcoming-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:20px;overflow:hidden}.upcoming-item{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:11px 16px;font-size:14px;display:flex}.upcoming-item:last-child{border-bottom:none}.upcoming-item-type{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:12px;font-weight:700;display:inline-flex}.upcoming-item-type.income{color:var(--green);background:#22c55e1f}.upcoming-item-type.expense{color:var(--red);background:#ef44441a}.upcoming-item-date{color:var(--text-secondary);flex:1;font-size:13px}.upcoming-item-amount{white-space:nowrap;font-weight:600}.upcoming-item-balance{color:var(--text-muted);white-space:nowrap;font-size:12px}@media (width<=400px){.upcoming-item-balance{display:none}}.upcoming-empty-inline{text-align:center;color:var(--text-muted);padding:24px;font-size:14px}.profile-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:16px;padding:20px}.profile-section h3{margin-bottom:4px;font-size:15px;font-weight:600}.profile-section-desc{color:var(--text-secondary);margin-bottom:16px;font-size:13px}.profile-section-muted{background:var(--bg-input)}.profile-form{max-width:480px}.profile-form-actions{margin-top:4px}.profile-form-actions .btn{width:auto}.profile-info-row{justify-content:space-between;align-items:center;padding:8px 0;font-size:14px;display:flex}.profile-info-label{color:var(--text-secondary)}.profile-info-value{font-weight:500}.sidebar-profile-link{align-items:center;gap:8px;margin-bottom:8px;text-decoration:none;display:flex}.sidebar-avatar{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:700;display:inline-flex}.sidebar-profile-link .user-name{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;display:block;overflow:hidden}.sidebar-profile-link:hover .user-name{color:var(--accent)}.drawer-menu-item{color:var(--text-primary);border-bottom:1px solid var(--border);padding:14px 20px;font-size:14px;text-decoration:none;display:block}.drawer-menu-item:hover{background:var(--bg-input);color:var(--accent)}.sidebar-footer-links{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.sidebar-footer-link{color:var(--text-muted);font-size:12px;text-decoration:none;transition:color .15s}.sidebar-footer-link:hover{color:var(--accent)}.plan-badge{vertical-align:middle;border-radius:99px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-block}.plan-badge-free{background:var(--bg-input);color:var(--text-secondary);border:1px solid var(--border)}.plan-badge-advanced{background:var(--accent-light);color:var(--accent);border:1px solid var(--accent)}.usage-grid{gap:10px;margin-top:14px;display:grid}.usage-row-header{justify-content:space-between;align-items:center;margin-bottom:5px;font-size:13px;display:flex}.usage-row-header span:first-child{color:var(--text-secondary)}.usage-bar-track{background:var(--bg-input);border-radius:99px;height:6px;overflow:hidden}.usage-bar-fill{background:var(--accent);border-radius:99px;height:100%;transition:width .4s}.usage-bar-fill.warn{background:var(--red)}.text-secondary{color:var(--text-secondary)}.interval-toggle{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:20px;display:inline-flex;overflow:hidden}.interval-btn{cursor:pointer;color:var(--text-secondary);-webkit-tap-highlight-color:transparent;background:0 0;border:none;align-items:center;gap:6px;padding:8px 18px;font-size:14px;font-weight:500;transition:background .15s,color .15s;display:flex}.interval-btn.active{background:var(--accent);color:#fff}.interval-btn:not(.active):hover{background:var(--bg-input)}.interval-discount{color:var(--green);background:#22c55e26;border-radius:99px;padding:1px 6px;font-size:11px;font-weight:700}.plan-cards{grid-template-columns:1fr;gap:14px;margin-bottom:20px;display:grid}@media (width>=560px){.plan-cards{grid-template-columns:1fr 1fr}}.plan-card{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);box-shadow:var(--shadow-sm);flex-direction:column;padding:20px;display:flex}.plan-card-featured{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent), var(--shadow)}.plan-card-current{opacity:.85}.plan-card-header{margin-bottom:16px}.plan-card-name{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:13px;font-weight:600;display:block}.plan-card-price{color:var(--text-primary);font-size:28px;font-weight:800;line-height:1.1;display:block}.plan-card-per{color:var(--text-muted);font-size:14px;font-weight:400}.plan-card-billed{color:var(--text-muted);margin-top:4px;font-size:12px;display:block}.plan-features{flex:1;margin-bottom:20px;list-style:none}.plan-features li{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:5px 0;font-size:13px;display:flex}.plan-features li:last-child{border-bottom:none}.feature-check{color:var(--text-muted);flex-shrink:0;font-size:12px}.feature-check.accent{color:var(--accent)}.plan-card-current-badge{text-align:center;color:var(--text-muted);border:1px dashed var(--border);border-radius:var(--radius);margin-top:auto;padding:10px;font-size:13px;font-weight:600}.billing-note{color:var(--text-muted);text-align:center;background:var(--bg-input);border-radius:var(--radius);padding:12px;font-size:13px}.modal-backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:9000;background:#00000073;justify-content:center;align-items:center;padding:16px;animation:.2s fade-in;display:flex;position:fixed;inset:0}.modal-box{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;width:100%;max-width:420px;padding:24px;animation:.25s cubic-bezier(.34,1.56,.64,1) slide-up;box-shadow:0 20px 60px #0003}.modal-box h3{margin-bottom:4px;font-size:17px;font-weight:700}.modal-actions{flex-direction:column;gap:8px;margin-top:20px;display:flex}.modal-actions .btn{width:100%}.checkout-modal{max-width:400px}.checkout-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.checkout-header h3{margin-bottom:2px;font-size:17px;font-weight:700}.checkout-subhead{color:var(--text-muted);font-size:13px}.checkout-test-badge{letter-spacing:.5px;text-transform:uppercase;color:var(--yellow);background:#d977061a;border:1px solid #d977064d;border-radius:99px;flex-shrink:0;margin-top:2px;padding:3px 8px;font-size:10px;font-weight:700}.checkout-summary{background:var(--bg-input);border-radius:var(--radius);justify-content:space-between;align-items:baseline;margin-bottom:4px;padding:12px 14px;font-size:14px;font-weight:500;display:flex}.checkout-price{font-size:20px;font-weight:800}.checkout-period{color:var(--text-muted);font-size:13px;font-weight:400}.checkout-permо{color:var(--text-muted);text-align:right;margin-bottom:16px;font-size:12px}.checkout-form{flex-direction:column;gap:10px;margin:16px 0 8px;display:flex}.checkout-form label{color:var(--text-secondary);font-size:13px;font-weight:500;display:block}.checkout-card-row{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);align-items:center;margin-top:4px;display:flex;overflow:hidden}.checkout-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text-primary);margin-top:4px;padding:10px 12px;font-family:Courier New,monospace;font-size:14px;display:block}.checkout-card-row .checkout-input{border:none;border-radius:0;flex:1;margin-top:0}.checkout-card-brand{color:var(--text-muted);letter-spacing:.5px;flex-shrink:0;padding:0 12px;font-size:11px;font-weight:700}.checkout-two-col{gap:10px;display:flex}.checkout-two-col label{flex:1}.checkout-secure-note{color:var(--text-muted);text-align:center;margin-bottom:12px;font-size:12px}.checkout-pay-btn{width:100%;margin-bottom:8px}.checkout-cancel-link{text-align:center;width:100%;padding:8px 0;font-size:13px;display:block}.checkout-processing{justify-content:center;align-items:center;gap:8px;display:flex}.checkout-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.7s linear infinite spin}.checkout-success{text-align:center;padding:16px 0}.checkout-success-icon{width:56px;height:56px;color:var(--green);background:#22c55e1f;border-radius:50%;justify-content:center;align-items:center;margin-bottom:14px;font-size:26px;font-weight:700;display:inline-flex}.checkout-success h3{margin-bottom:6px;font-size:18px;font-weight:700}.checkout-success p{color:var(--text-secondary);font-size:14px}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-header h3{font-size:16px;font-weight:700}.modal-close{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:4px;transition:color .15s,background .15s;display:flex}.modal-close:hover{color:var(--text-primary);background:var(--bg-input)}.form-fields{flex-direction:column;gap:14px;margin-bottom:20px;display:flex}.form-field{flex-direction:column;gap:5px;display:flex}.form-field>span{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px;font-size:12px;font-weight:600}.form-field-optional{text-transform:none;letter-spacing:0;color:var(--text-muted);font-weight:400}.form-row-2{grid-template-columns:1fr 1fr;gap:12px;display:grid}.modal-box-form{max-width:480px;max-height:90vh;overflow-y:auto}.modal-box-sm{max-width:360px}.confirm-modal-message{color:var(--text-secondary);margin-bottom:20px;font-size:14px;line-height:1.6}.quick-add-note{color:var(--text-muted);margin-bottom:16px;font-size:12px;line-height:1.5}.quick-add-note a{color:var(--accent)}.upcoming-header-actions{gap:6px;display:flex}.btn-quick-add{cursor:pointer;white-space:nowrap;border:1px solid #0000;border-radius:99px;align-items:center;gap:4px;padding:5px 10px;font-size:12px;font-weight:600;transition:all .15s;display:inline-flex}.btn-quick-add.income{color:var(--green);background:#22c55e1a;border-color:#22c55e40}.btn-quick-add.income:hover{background:#22c55e2e;border-color:#22c55e66}.btn-quick-add.expense{color:var(--red);background:#ef444414;border-color:#ef444433}.btn-quick-add.expense:hover{background:#ef444424;border-color:#ef444459}.spending-section-header{justify-content:space-between;align-items:center;margin-bottom:2px;display:flex}.spending-section h3{margin-bottom:0;font-size:15px}.spending-chart{flex-direction:column;display:flex}.spending-donut{width:100%}.spending-chart-empty{text-align:center;color:var(--text-muted);padding:40px 0;font-size:14px}.spending-legend{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.spending-legend-item{cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:8px;align-items:center;gap:10px;padding:8px 10px;transition:background .12s;display:flex}.spending-legend-item:hover,.spending-legend-item.active{background:var(--bg-hover)}.spending-legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.spending-legend-name{color:var(--text-primary);flex:1;font-size:13px;font-weight:500}.spending-legend-amount{color:var(--text-primary);flex-shrink:0;font-size:13px;font-weight:600}.spending-legend-pct{color:var(--text-muted);text-align:right;flex-shrink:0;min-width:34px;font-size:11px}@media (width>=600px){.spending-chart{flex-direction:row;align-items:center;gap:8px}.spending-donut{flex-shrink:0;width:280px}.spending-legend{flex:1}}.paywall-preview{border-radius:12px;position:relative;overflow:hidden}.paywall-blur{filter:blur(6px);opacity:.5;pointer-events:none;-webkit-user-select:none;user-select:none}.paywall-overlay{background:rgba(var(--bg-card-rgb,255,255,255), .5);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:24px;display:flex;position:absolute;inset:0}.paywall-badge{background:var(--accent);color:#fff;text-transform:uppercase;letter-spacing:.5px;border-radius:20px;align-items:center;gap:6px;padding:5px 12px;font-size:12px;font-weight:700;display:inline-flex}.paywall-overlay p{color:var(--text-secondary);max-width:240px;margin:0;font-size:14px}.paywall-overlay .btn{min-width:160px}.freq-select-row{flex-wrap:wrap;gap:8px;display:flex}.freq-select-row select{flex:1;min-width:0}.item-list{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.item-list-empty{color:var(--text-muted);text-align:center;padding:20px 16px;font-size:14px}.item-card{border-bottom:1px solid var(--border);cursor:pointer;-webkit-tap-highlight-color:transparent;outline:none;align-items:center;gap:12px;padding:12px 16px;transition:background .12s;display:flex}.item-card:last-child{border-bottom:none}.item-card:hover{background:var(--bg-hover)}.item-card:focus-visible{box-shadow:inset 0 0 0 2px var(--accent)}.item-card-body{flex:1;min-width:0}.item-card-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:3px;font-size:14px;font-weight:600;overflow:hidden}.item-card-meta{color:var(--text-muted);flex-wrap:wrap;align-items:center;gap:4px;font-size:12px;display:flex}.meta-dot{color:var(--border)}.item-card-right{flex-shrink:0;align-items:center;gap:10px;display:flex}.item-card-amount{text-align:right;min-width:80px;font-size:14px;font-weight:700}.item-card-amount.positive{color:var(--green)}.item-card-amount.negative{color:var(--red)}.item-card-actions{gap:4px;display:flex}@media (width<=479px){.item-card{flex-wrap:wrap;gap:8px}.item-card-right{justify-content:space-between;width:100%}.item-card-amount{text-align:left}}.cancel-over-limit-notice{border-radius:var(--radius);background:#d977060f;border:1px solid #d977064d;margin:12px 0;padding:14px}.cancel-notice-title{color:var(--yellow);margin-bottom:8px;font-size:13px;font-weight:600}.cancel-notice-list{margin:0 0 10px;list-style:none}.cancel-notice-list li{color:var(--text-secondary);padding:3px 0;font-size:13px}.cancel-notice-list li:before{content:"· ";color:var(--yellow)}.cancel-notice-body{color:var(--text-secondary);margin:0;font-size:13px;line-height:1.5}.cancel-notice-body strong{color:var(--text-primary)}.over-limit-tag{text-transform:uppercase;letter-spacing:.3px;color:var(--red);vertical-align:middle;background:#ef44441a;border:1px solid #ef444440;border-radius:99px;margin-left:6px;padding:1px 6px;font-size:10px;font-weight:700;display:inline-block}.upgrade-backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:9100;background:#00000073;justify-content:center;align-items:center;padding:16px;animation:.2s fade-in;display:flex;position:fixed;inset:0}.upgrade-modal{background:var(--bg-card);border:1px solid var(--border);text-align:center;border-radius:16px;width:100%;max-width:360px;padding:32px 24px;animation:.25s cubic-bezier(.34,1.56,.64,1) slide-up;box-shadow:0 20px 60px #0003}.upgrade-icon{margin-bottom:12px;font-size:44px;line-height:1}.upgrade-modal h3{margin-bottom:10px;font-size:18px;font-weight:700}.upgrade-modal p{color:var(--text-secondary);margin-bottom:4px;font-size:14px;line-height:1.6}.upgrade-modal .btn-primary{width:100%}.calendar-page .page-header{margin-bottom:0}.calendar-nav{align-items:center;gap:10px;display:flex}.cal-month-title{text-align:center;min-width:180px;font-size:18px;font-weight:700}.cal-nav-btn{background:var(--bg-input);border:1px solid var(--border);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;transition:background .15s;display:flex}.cal-nav-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.cal-today-btn{margin-left:4px}.cal-grid-wrapper{padding-bottom:8px;overflow-x:auto}.cal-grid{background:var(--border);border:1px solid var(--border);border-radius:var(--radius);grid-template-columns:repeat(7,minmax(0,1fr));gap:1px;min-width:560px;margin-top:14px;display:grid;overflow:hidden}.cal-weekday{background:var(--bg-card);text-align:center;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:8px 6px;font-size:11px;font-weight:700}.cal-day{background:var(--bg-card);min-height:100px;padding:6px;position:relative}.cal-day-other-month{background:var(--bg-sidebar);opacity:.6}.cal-day-today{background:var(--accent-light)}.cal-day-today .cal-day-num{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-weight:700;display:inline-flex}.cal-day-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.cal-day-num{color:var(--text-secondary);font-size:12px;font-weight:600;line-height:1}.cal-day-net{font-size:10px;font-weight:700}.cal-day-net.positive{color:var(--green)}.cal-day-net.negative{color:var(--red)}.cal-day-items{flex-direction:column;gap:3px;display:flex}.cal-item{cursor:pointer;text-align:left;border:none;border-radius:4px;justify-content:space-between;align-items:center;gap:4px;width:100%;padding:2px 5px;font-size:11px;transition:opacity .15s,filter .15s;display:flex;overflow:hidden}.cal-item:hover{filter:brightness(1.1)}.cal-item.completed{opacity:.45;text-decoration:line-through}.cal-item-income{color:var(--green);background:#22c55e26}.cal-item-expense{color:var(--red);background:#ef44441f}.cal-item-name{white-space:nowrap;text-overflow:ellipsis;flex:1;font-weight:500;overflow:hidden}.cal-item-amount{flex-shrink:0;font-size:10px;font-weight:700}.cal-legend{flex-wrap:wrap;gap:10px;margin-top:12px;padding:0 2px;display:flex}.cal-legend-item{color:var(--text-muted);align-items:center;gap:5px;font-size:11px;display:flex}.cal-legend-item:before{content:"";border-radius:2px;width:10px;height:10px;display:inline-block}.cal-legend-item.income:before{background:#22c55e66}.cal-legend-item.expense:before{background:#ef44444d}.cal-legend-item.completed:before{background:var(--border);opacity:.5}@media (width<=639px){.cal-month-title{min-width:140px;font-size:15px}.cal-day{min-height:70px;padding:4px}.cal-item{padding:1px 4px;font-size:10px}.cal-item-amount{display:none}}@media (width>=1024px){.sidebar{width:240px}.main-content{margin-left:240px}}
